mirror of
https://github.com/containers/podman.git
synced 2025-06-19 08:09:12 +08:00

...make sure podman rejects being called with incompatible options Replaces: https://github.com/containers/podman/pull/16813 Which is stuck in CI and Ed is on break. Signed-off-by: Ed Santiago <santiago@redhat.com> Signed-off-by: Daniel J Walsh <dwalsh@redhat.com>
51 lines
1.7 KiB
Bash
51 lines
1.7 KiB
Bash
#!/usr/bin/env bats -*- bats -*-
|
|
#
|
|
# options that cannot be set together
|
|
#
|
|
|
|
load helpers
|
|
|
|
|
|
@test "options that cannot be set together" {
|
|
skip_if_remote "not much point testing remote, and container-cleanup fails anyway"
|
|
|
|
tests="
|
|
create,run | --cpu-period=1 | --cpus=2 | $IMAGE
|
|
create,run | --cpu-quota=1 | --cpus=2 | $IMAGE
|
|
create,run | --no-hosts | --add-host=foo:1.1.1.1 | $IMAGE
|
|
create,run | --userns=bar | --pod=foo | $IMAGE
|
|
container cleanup | --all | --exec=foo
|
|
container cleanup | --exec=foo | --rmi | foo
|
|
"
|
|
|
|
# FIXME: parse_table is what does all the work, giving us test cases.
|
|
while read subcommands opt1 opt2 args; do
|
|
opt1_name=${opt1%=*}
|
|
opt2_name=${opt2%=*}
|
|
|
|
readarray -d, -t subcommand_list <<<$subcommands
|
|
for subcommand in "${subcommand_list[@]}"; do
|
|
run_podman 125 $subcommand $opt1 $opt2 $args
|
|
is "$output" "Error: $opt1_name and $opt2_name cannot be set together" \
|
|
"podman $subcommand $opt1 $opt2"
|
|
|
|
# Reverse order
|
|
run_podman 125 $subcommand $opt2 $opt1 $args
|
|
is "$output" "Error: $opt1_name and $opt2_name cannot be set together" \
|
|
"podman $subcommand $opt2 $opt1"
|
|
done
|
|
done < <(parse_table "$tests")
|
|
|
|
# Different error message; cannot be tested with the other ones above
|
|
for opt in arch os; do
|
|
for cmd in create pull; do
|
|
run_podman 125 $cmd --platform=foo --$opt=bar sdfsdf
|
|
is "$output" "Error: --platform option can not be specified with --arch or --os" \
|
|
"podman $cmd --platform + --$opt"
|
|
done
|
|
done
|
|
}
|
|
|
|
|
|
# vim: filetype=sh
|