Apply filters correctly
This commit is contained in:
@@ -9,8 +9,8 @@ class CliAppTest < CliTestCase
|
||||
.returns("123") # old version
|
||||
|
||||
run_command("boot").tap do |output|
|
||||
assert_match %r[docker run --detach --restart unless-stopped], output
|
||||
assert_match %r[docker container ls --all --filter name=app-web-123 --quiet | xargs docker stop], output
|
||||
assert_match /#{Regexp.escape("docker run --detach --restart unless-stopped")}/, output
|
||||
assert_match /#{Regexp.escape("docker container ls --all --filter name=app-web-123 --quiet | xargs docker stop")}/, output
|
||||
end
|
||||
end
|
||||
|
||||
@@ -26,10 +26,10 @@ class CliAppTest < CliTestCase
|
||||
.returns([ :docker, :run ])
|
||||
|
||||
run_command("boot").tap do |output|
|
||||
assert_match %r[Rebooting container with same version 999 already deployed], output # Can't start what's already running
|
||||
assert_match %r[docker container ls --all --filter name=app-web-999 --quiet | xargs docker stop], output # Stop old running
|
||||
assert_match %r[docker container ls --all --filter name=app-web-999 --quiet | xargs docker container rm], output # Remove old container
|
||||
assert_match %r[docker run on 1.1.1.1], output # Start new container
|
||||
assert_match /#{Regexp.escape("Rebooting container with same version 999 already deployed")}/, output # Can't start what's already running
|
||||
assert_match /#{Regexp.escape("docker container ls --all --filter name=app-web-999 --quiet | xargs docker stop")}/, output # Stop old running
|
||||
assert_match /#{Regexp.escape("docker container ls --all --filter name=app-web-999 --quiet | xargs docker container rm")}/, output # Remove old container
|
||||
assert_match /#{Regexp.escape("docker run on 1.1.1.1")}/, output # Start new container
|
||||
end
|
||||
ensure
|
||||
Thread.report_on_exception = true
|
||||
@@ -37,46 +37,46 @@ class CliAppTest < CliTestCase
|
||||
|
||||
test "start" do
|
||||
run_command("start").tap do |output|
|
||||
assert_match %r[docker start app-web-999], output
|
||||
assert_match /#{Regexp.escape("docker start app-web-999")}/, output
|
||||
end
|
||||
end
|
||||
|
||||
test "stop" do
|
||||
run_command("stop").tap do |output|
|
||||
assert_match %r[docker ps --quiet --filter label=service=app label=role=web | xargs docker stop], output
|
||||
assert_match /#{Regexp.escape("docker ps --quiet --filter label=service=app --filter label=role=web | xargs docker stop")}/, output
|
||||
end
|
||||
end
|
||||
|
||||
test "details" do
|
||||
run_command("details").tap do |output|
|
||||
assert_match %r[docker ps --filter label=service=app label=role=web], output
|
||||
assert_match /#{Regexp.escape("docker ps --filter label=service=app --filter label=role=web")}/, output
|
||||
end
|
||||
end
|
||||
|
||||
test "remove" do
|
||||
run_command("remove").tap do |output|
|
||||
assert_match %r[docker ps --quiet --filter label=service=app label=role=web | xargs docker stop], output
|
||||
assert_match %r[docker container prune --force --filter label=service=app], output
|
||||
assert_match %r[docker image prune --all --force --filter label=service=app], output
|
||||
assert_match /#{Regexp.escape("docker ps --quiet --filter label=service=app --filter label=role=web | xargs docker stop")}/, output
|
||||
assert_match /#{Regexp.escape("docker container prune --force --filter label=service=app")}/, output
|
||||
assert_match /#{Regexp.escape("docker image prune --all --force --filter label=service=app")}/, output
|
||||
end
|
||||
end
|
||||
|
||||
test "remove_container" do
|
||||
run_command("remove_container", "1234567").tap do |output|
|
||||
assert_match %r[docker container ls --all --filter name=app-web-1234567 --quiet | xargs docker container rm], output
|
||||
assert_match /#{Regexp.escape("docker container ls --all --filter name=app-web-1234567 --quiet | xargs docker container rm")}/, output
|
||||
end
|
||||
end
|
||||
|
||||
test "exec" do
|
||||
run_command("exec", "ruby -v").tap do |output|
|
||||
assert_match %r[docker run --rm dhh/app:999 ruby -v], output
|
||||
assert_match /#{Regexp.escape("docker run --rm dhh/app:999 ruby -v")}/, output
|
||||
end
|
||||
end
|
||||
|
||||
test "exec with reuse" do
|
||||
run_command("exec", "--reuse", "ruby -v").tap do |output|
|
||||
assert_match %r[docker ps --filter label=service=app --format "{{.Names}}" | sed 's/-/\n/g' | tail -n 1], output
|
||||
assert_match %r[docker exec app-web-999 ruby -v], output
|
||||
assert_match /#{Regexp.escape("docker ps --filter label=service=app --format \"{{.Names}}\" | sed 's/-/\\n/g' | tail -n 1")}/, output
|
||||
assert_match /#{Regexp.escape("docker exec app-web-999 ruby -v")}/, output
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
Reference in New Issue
Block a user