summaryrefslogtreecommitdiff
path: root/tests/integration_tests/modules/test_ssh_generate.py
diff options
context:
space:
mode:
authorlucasmoura <lucas.moura@canonical.com>2020-10-19 16:09:51 -0300
committerGitHub <noreply@github.com>2020-10-19 15:09:51 -0400
commitb94962b558e929a365bcfad1ca9a9445eee575e8 (patch)
treec6e061054d84e2e5f580cf330a999745243b6061 /tests/integration_tests/modules/test_ssh_generate.py
parent8766784f4b1d1f9f6a9094e1268e4accb811ea7f (diff)
downloadvyos-cloud-init-b94962b558e929a365bcfad1ca9a9445eee575e8.tar.gz
vyos-cloud-init-b94962b558e929a365bcfad1ca9a9445eee575e8.zip
Add more integration tests (#615)
Translate the following tests from `cloud_tests` to the new integration test framework: * test_runcmd.py * seed_random_data.py * set_hostname.py * set_hostname_fqdn.py * snap.py * ssh_auth_key_fingerprints_disable.py * ssh_auth_key_fingerprints_enable.py * ssh_import_id.py * ssh_keys_generate.py * ssh_keys_provided.py * timezone.py * write_files.py
Diffstat (limited to 'tests/integration_tests/modules/test_ssh_generate.py')
-rw-r--r--tests/integration_tests/modules/test_ssh_generate.py50
1 files changed, 50 insertions, 0 deletions
diff --git a/tests/integration_tests/modules/test_ssh_generate.py b/tests/integration_tests/modules/test_ssh_generate.py
new file mode 100644
index 00000000..8c60fb87
--- /dev/null
+++ b/tests/integration_tests/modules/test_ssh_generate.py
@@ -0,0 +1,50 @@
+"""Integration test for the ssh module.
+
+This module has two tests to verify if we can create ssh keys
+through the ``ssh`` module. The first test asserts that some keys
+were not created while the second one verifies if the expected
+keys were created.
+
+(This is ported from
+``tests/cloud_tests/testcases/modules/ssh_keys_generate.yaml``.)"""
+
+import pytest
+
+
+USER_DATA = """\
+#cloud-config
+ssh_genkeytypes:
+ - ecdsa
+ - ed25519
+authkey_hash: sha512
+"""
+
+
+@pytest.mark.user_data(USER_DATA)
+class TestSshKeysGenerate:
+
+ @pytest.mark.parametrize(
+ "ssh_key_path", (
+ "/etc/ssh/ssh_host_dsa_key.pub",
+ "/etc/ssh/ssh_host_dsa_key",
+ "/etc/ssh/ssh_host_rsa_key.pub",
+ "/etc/ssh/ssh_host_rsa_key",
+ )
+ )
+ def test_ssh_keys_not_generated(self, ssh_key_path, class_client):
+ out = class_client.execute(
+ "test -e {}".format(ssh_key_path)
+ )
+ assert out.failed
+
+ @pytest.mark.parametrize(
+ "ssh_key_path", (
+ "/etc/ssh/ssh_host_ecdsa_key.pub",
+ "/etc/ssh/ssh_host_ecdsa_key",
+ "/etc/ssh/ssh_host_ed25519_key.pub",
+ "/etc/ssh/ssh_host_ed25519_key",
+ )
+ )
+ def test_ssh_keys_generated(self, ssh_key_path, class_client):
+ out = class_client.read_from_file(ssh_key_path)
+ assert "" != out.strip()