nixos/acme: Port test to python

This commit is contained in:
Jacek Galowicz 2019-10-27 13:53:55 +01:00 committed by Jacek Galowicz
parent d4a5ea5219
commit e5ee596263

View File

@ -1,6 +1,6 @@
let let
commonConfig = ./common/letsencrypt/common.nix; commonConfig = ./common/letsencrypt/common.nix;
in import ./make-test.nix { in import ./make-test-python.nix {
name = "acme"; name = "acme";
nodes = rec { nodes = rec {
@ -90,39 +90,44 @@ in import ./make-test.nix {
newServerSystem = nodes.webserver2.config.system.build.toplevel; newServerSystem = nodes.webserver2.config.system.build.toplevel;
switchToNewServer = "${newServerSystem}/bin/switch-to-configuration test"; switchToNewServer = "${newServerSystem}/bin/switch-to-configuration test";
in in
# Note, waitForUnit does not work for oneshot services that do not have RemainAfterExit=true, # Note, wait_for_unit does not work for oneshot services that do not have RemainAfterExit=true,
# this is because a oneshot goes from inactive => activating => inactive, and never # this is because a oneshot goes from inactive => activating => inactive, and never
# reaches the active state. To work around this, we create some mock target units which # reaches the active state. To work around this, we create some mock target units which
# get pulled in by the oneshot units. The target units linger after activation, and hence we # get pulled in by the oneshot units. The target units linger after activation, and hence we
# can use them to probe that a oneshot fired. It is a bit ugly, but it is the best we can do # can use them to probe that a oneshot fired. It is a bit ugly, but it is the best we can do
'' ''
$client->start; client.start()
$letsencrypt->start; letsencrypt.start()
$acmeStandalone->start; acmeStandalone.start()
$letsencrypt->waitForUnit("default.target"); letsencrypt.wait_for_unit("default.target")
$letsencrypt->waitForUnit("pebble.service"); letsencrypt.wait_for_unit("pebble.service")
subtest "can request certificate with HTTPS-01 challenge", sub { with subtest("can request certificate with HTTPS-01 challenge"):
$acmeStandalone->waitForUnit("default.target"); acmeStandalone.wait_for_unit("default.target")
$acmeStandalone->succeed("systemctl start acme-standalone.com.service"); acmeStandalone.succeed("systemctl start acme-standalone.com.service")
$acmeStandalone->waitForUnit("acme-finished-standalone.com.target"); acmeStandalone.wait_for_unit("acme-finished-standalone.com.target")
};
$client->waitForUnit("default.target"); client.wait_for_unit("default.target")
$client->succeed('curl https://acme-v02.api.letsencrypt.org:15000/roots/0 > /tmp/ca.crt'); client.succeed("curl https://acme-v02.api.letsencrypt.org:15000/roots/0 > /tmp/ca.crt")
$client->succeed('curl https://acme-v02.api.letsencrypt.org:15000/intermediate-keys/0 >> /tmp/ca.crt'); client.succeed(
"curl https://acme-v02.api.letsencrypt.org:15000/intermediate-keys/0 >> /tmp/ca.crt"
)
subtest "Can request certificate for nginx service", sub { with subtest("Can request certificate for nginx service"):
$webserver->waitForUnit("acme-finished-a.example.com.target"); webserver.wait_for_unit("acme-finished-a.example.com.target")
$client->succeed('curl --cacert /tmp/ca.crt https://a.example.com/ | grep -qF "hello world"'); client.succeed(
}; "curl --cacert /tmp/ca.crt https://a.example.com/ | grep -qF 'hello world'"
)
subtest "Can add another certificate for nginx service", sub { with subtest("Can add another certificate for nginx service"):
$webserver->succeed("/run/current-system/fine-tune/child-1/bin/switch-to-configuration test"); webserver.succeed(
$webserver->waitForUnit("acme-finished-b.example.com.target"); "/run/current-system/fine-tune/child-1/bin/switch-to-configuration test"
$client->succeed('curl --cacert /tmp/ca.crt https://b.example.com/ | grep -qF "hello world"'); )
}; webserver.wait_for_unit("acme-finished-b.example.com.target")
client.succeed(
"curl --cacert /tmp/ca.crt https://b.example.com/ | grep -qF 'hello world'"
)
''; '';
} }