Instead of using `kamal envify` to generate the .env file, we now assume that it will be in place for us. Options in place of `kamal envify`: 1. Pre-generate the .env file 2. Create the env file in the `.pre-init` hook 3. Log into a secret store/check you are logged in in the pre-init hook Then use .dotenv command and variable substitution to interpolate the secrets.
54 lines
1.5 KiB
Ruby
54 lines
1.5 KiB
Ruby
require_relative "integration_test"
|
|
|
|
class AppTest < IntegrationTest
|
|
test "stop, start, boot, logs, images, containers, exec, remove" do
|
|
kamal :deploy
|
|
|
|
assert_app_is_up
|
|
|
|
kamal :app, :stop
|
|
|
|
assert_app_is_down
|
|
|
|
kamal :app, :start
|
|
|
|
# kamal app start does not wait
|
|
wait_for_app_to_be_up
|
|
|
|
kamal :app, :boot
|
|
|
|
wait_for_app_to_be_up
|
|
|
|
logs = kamal :app, :logs, capture: true
|
|
assert_match /App Host: vm1/, logs
|
|
assert_match /App Host: vm2/, logs
|
|
assert_match /GET \/ HTTP\/1.1/, logs
|
|
|
|
images = kamal :app, :images, capture: true
|
|
assert_match /App Host: vm1/, images
|
|
assert_match /App Host: vm2/, images
|
|
assert_match /registry:4443\/app\s+#{latest_app_version}/, images
|
|
assert_match /registry:4443\/app\s+latest/, images
|
|
|
|
containers = kamal :app, :containers, capture: true
|
|
assert_match /App Host: vm1/, containers
|
|
assert_match /App Host: vm2/, containers
|
|
assert_match /registry:4443\/app:#{latest_app_version}/, containers
|
|
assert_match /registry:4443\/app:latest/, containers
|
|
|
|
exec_output = kamal :app, :exec, :ps, capture: true
|
|
assert_match /App Host: vm1/, exec_output
|
|
assert_match /App Host: vm2/, exec_output
|
|
assert_match /1 root 0:\d\d ps/, exec_output
|
|
|
|
exec_output = kamal :app, :exec, "--reuse", :ps, capture: true
|
|
assert_match /App Host: vm1/, exec_output
|
|
assert_match /App Host: vm2/, exec_output
|
|
assert_match /1 root 0:\d\d nginx/, exec_output
|
|
|
|
kamal :app, :remove
|
|
|
|
assert_app_is_down
|
|
end
|
|
end
|