Skip to content

Commit

Permalink
pkg/utils: Ensure that the distro CLI and config file option is valid
Browse files Browse the repository at this point in the history
Currently, if an invalid or unsupported string is specified as the
distro on the command line or in the configuration file, then it would
silently fallback to Fedora.  This shouldn't happen.

It should only fallback to Fedora when no distro was specified and
there's no supported Toolbox image matching the host operating system.
If a distro was explicitly specified then it should either be supported
or it should error out.

containers#937
  • Loading branch information
debarshiray committed Jul 31, 2022
1 parent c2034e1 commit 0f070c1
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 4 deletions.
8 changes: 4 additions & 4 deletions src/pkg/utils/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -250,10 +250,6 @@ func getDefaultImageForDistro(distro, release string) string {
panic("distro not specified")
}

if _, supportedDistro := supportedDistros[distro]; !supportedDistro {
distro = distroFallback
}

distroObj, supportedDistro := supportedDistros[distro]
if !supportedDistro {
panicMsg := fmt.Sprintf("failed to find %s in the list of supported distributions", distro)
Expand Down Expand Up @@ -708,6 +704,10 @@ func ResolveContainerAndImageNames(container, distroCLI, imageCLI, releaseCLI st
}
}

if _, ok := supportedDistros[distro]; !ok {
return "", "", "", fmt.Errorf("distribution %s is unsupported", distro)
}

if distro != distroDefault && releaseCLI == "" && !viper.IsSet("general.release") {
return "", "", "", fmt.Errorf("release not found for non-default distribution %s", distro)
}
Expand Down
10 changes: 10 additions & 0 deletions test/system/101-create.bats
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,16 @@ teardown() {
assert_output --regexp "Created[[:blank:]]+fedora-toolbox-32"
}

@test "create: Try to create a container based on unsupported distribution" {
local distro="foo"

run $TOOLBOX -y create -d "$distro"

assert_failure
assert_line --index 0 "Error: distribution foo is unsupported"
assert [ ${#lines[@]} -eq 1 ]
}

@test "create: Try to create a container based on non-existent image" {
run $TOOLBOX -y create -i foo.org/bar

Expand Down

0 comments on commit 0f070c1

Please sign in to comment.