Skip to content

Commit

Permalink
load: move env var profile detection to option (#446)
Browse files Browse the repository at this point in the history
Instead of reading `COMPOSE_PROFILES` environment variable directly
during `load()`, rely exclusively on `opts.Profiles`.

A new loader option, `WithDefaultProfiles`, allows passing profile
name(s) via varargs. If none are provided, it will fallback to using
any profiles set via `COMPOSE_PROFILES`.

This improves purity of the loader and fixes issues with profiles
being ignored for `include` (docker/compose#10906).

Signed-off-by: Milas Bowman <[email protected]>
  • Loading branch information
milas authored Aug 29, 2023
1 parent 1be5aca commit 8c4b79e
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 6 deletions.
16 changes: 13 additions & 3 deletions cli/options.go
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ func WithEnv(env []string) ProjectOptionsFn {
}
}

// WithDiscardEnvFiles sets discards the `env_file` section after resolving to
// WithDiscardEnvFile sets discards the `env_file` section after resolving to
// the `environment` section
func WithDiscardEnvFile(o *ProjectOptions) error {
o.loadOptions = append(o.loadOptions, loader.WithDiscardEnvFiles)
Expand All @@ -209,6 +209,15 @@ func WithLoadOptions(loadOptions ...func(*loader.Options)) ProjectOptionsFn {
}
}

// WithDefaultProfiles uses the provided profiles (if any), and falls back to
// profiles specified via the COMPOSE_PROFILES environment variable otherwise.
func WithDefaultProfiles(profile ...string) ProjectOptionsFn {
if len(profile) == 0 {
profile = strings.Split(os.Getenv(consts.ComposeProfiles), ",")
}
return WithProfiles(profile)
}

// WithProfiles sets profiles to be activated
func WithProfiles(profiles []string) ProjectOptionsFn {
return func(o *ProjectOptions) error {
Expand All @@ -228,8 +237,9 @@ func WithOsEnv(o *ProjectOptions) error {
return nil
}

// WithEnvFile set an alternate env file
// deprecated - use WithEnvFiles
// WithEnvFile sets an alternate env file.
//
// Deprecated: use WithEnvFiles instead.
func WithEnvFile(file string) ProjectOptionsFn {
var files []string
if file != "" {
Expand Down
3 changes: 0 additions & 3 deletions loader/loader.go
Original file line number Diff line number Diff line change
Expand Up @@ -360,9 +360,6 @@ func load(ctx context.Context, configDetails types.ConfigDetails, opts *Options,
}
}

if profiles, ok := project.Environment[consts.ComposeProfiles]; ok && len(opts.Profiles) == 0 {
opts.Profiles = strings.Split(profiles, ",")
}
project.ApplyProfiles(opts.Profiles)

err := project.ResolveServicesEnvironment(opts.discardEnvFiles)
Expand Down

0 comments on commit 8c4b79e

Please sign in to comment.