Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions changelog/fragments/bugfix-generate-no-project-name.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
entries:
- description: >
Project version now determines how package name is retrieved for a project
kind: bugfix
18 changes: 3 additions & 15 deletions internal/cmd/operator-sdk/generate/bundle/bundle.go
Original file line number Diff line number Diff line change
Expand Up @@ -105,21 +105,9 @@ https://github.com/operator-framework/operator-registry/#manifest-format
const defaultRootDir = "bundle"

// setDefaults sets defaults useful to all modes of this subcommand.
func (c *bundleCmd) setDefaults() error {
if projutil.HasProjectFile() {
cfg, err := projutil.ReadConfig()
if err != nil {
return err
}
if c.packageName == "" {
c.packageName = cfg.ProjectName
}
c.layout = projutil.GetProjectLayout(cfg)
} else {
if c.packageName == "" {
return fmt.Errorf("package name is required if PROJECT config file is not present")
}
c.layout = "unknown"
func (c *bundleCmd) setDefaults() (err error) {
if c.packageName, c.layout, err = genutil.GetPackageNameAndLayout(c.packageName); err != nil {
return err
}
return nil
}
Expand Down
35 changes: 35 additions & 0 deletions internal/cmd/operator-sdk/generate/internal/genutil.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import (
"strings"

"github.com/blang/semver"
"github.com/operator-framework/operator-sdk/internal/util/projutil"
apiextv1 "k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1"
apiextv1beta1 "k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1beta1"
"sigs.k8s.io/controller-runtime/pkg/client"
Expand Down Expand Up @@ -158,3 +159,37 @@ func IsExist(path string) bool {
_, err := os.Stat(path)
return err == nil || errors.Is(err, os.ErrExist)
}

// GetPackageNameAndLayout returns packageName and layout, if any, for a project.
// These values are determined by project version and whether a PROJECT file exists.
func GetPackageNameAndLayout(defaultPackageName string) (packageName string, layout string, _ error) {
packageName = defaultPackageName
if projutil.HasProjectFile() {
cfg, err := projutil.ReadConfig()
if err != nil {
return "", "", err
}
if packageName == "" {
switch {
case cfg.IsV2():
wd, err := os.Getwd()
if err != nil {
return "", "", err
}
packageName = strings.ToLower(filepath.Base(wd))
default:
if cfg.ProjectName == "" {
return "", "", errors.New("--package-name must be set if \"projectName\" is not set in the PROJECT config file")
}
packageName = cfg.ProjectName
}
}
layout = projutil.GetProjectLayout(cfg)
} else {
if packageName == "" {
return "", "", errors.New("--package-name must be set if PROJECT config file is not present")
}
layout = "unknown"
}
return packageName, layout, nil
}
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ import (
"github.com/operator-framework/operator-sdk/internal/generate/clusterserviceversion/bases"
"github.com/operator-framework/operator-sdk/internal/generate/collector"
genpkg "github.com/operator-framework/operator-sdk/internal/generate/packagemanifest"
"github.com/operator-framework/operator-sdk/internal/util/projutil"
)

const (
Expand Down Expand Up @@ -78,21 +77,9 @@ https://github.com/operator-framework/operator-registry/#manifest-format
const defaultRootDir = "packagemanifests"

// setDefaults sets command defaults.
func (c *packagemanifestsCmd) setDefaults() error {
if projutil.HasProjectFile() {
cfg, err := projutil.ReadConfig()
if err != nil {
return err
}
if c.packageName == "" {
c.packageName = cfg.ProjectName
}
c.layout = projutil.GetProjectLayout(cfg)
} else {
if c.packageName == "" {
return fmt.Errorf("package name is required if PROJECT config file is not present")
}
c.layout = "unknown"
func (c *packagemanifestsCmd) setDefaults() (err error) {
if c.packageName, c.layout, err = genutil.GetPackageNameAndLayout(c.packageName); err != nil {
return err
}

if c.inputDir == "" {
Expand All @@ -103,6 +90,7 @@ func (c *packagemanifestsCmd) setDefaults() error {
c.outputDir = defaultRootDir
}
}

return nil
}

Expand Down