2022-06-03 13:28:38 -05:00
|
|
|
#
|
|
|
|
# Copyright (C) 2022 FreeIPA Contributors see COPYING for license
|
|
|
|
#
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2022-07-14 03:20:23 -05:00
|
|
|
from ipaplatform.paths import paths
|
|
|
|
|
|
|
|
from ipatests.pytest_ipa.integration import tasks
|
2022-06-03 13:28:38 -05:00
|
|
|
from ipatests.test_integration.test_installation import (
|
|
|
|
TestInstallWithCA_DNS1,
|
|
|
|
TestInstallWithCA_KRA1,
|
|
|
|
)
|
|
|
|
from ipatests.test_integration.test_caless import TestServerCALessToExternalCA
|
2022-07-14 03:20:23 -05:00
|
|
|
from ipatests.test_integration.test_vault import TestInstallKRA
|
2022-06-03 13:28:38 -05:00
|
|
|
from ipatests.test_integration.test_commands import TestIPACommand
|
|
|
|
|
|
|
|
|
|
|
|
def pki_supports_RSNv3(host):
|
|
|
|
"""
|
|
|
|
Return whether the host supports RNSv3 based on the pki version
|
|
|
|
"""
|
|
|
|
script = ("from ipaserver.install.ca import "
|
|
|
|
"random_serial_numbers_version; "
|
|
|
|
"print(random_serial_numbers_version(True))")
|
|
|
|
result = host.run_command(['python3', '-c', script])
|
|
|
|
if 'true' in result.stdout_text.strip().lower():
|
|
|
|
return True
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
2022-07-14 03:20:23 -05:00
|
|
|
def check_pki_config_params(host):
|
|
|
|
# Check CS.cfg
|
|
|
|
try:
|
|
|
|
cs_cfg = host.get_file_contents(paths.CA_CS_CFG_PATH)
|
|
|
|
kra_cfg = host.get_file_contents(paths.KRA_CS_CFG_PATH)
|
|
|
|
assert "dbs.cert.id.generator=random".encode() in cs_cfg
|
|
|
|
assert "dbs.request.id.generator=random".encode() in cs_cfg
|
|
|
|
assert "dbs.key.id.generator=random".encode() in kra_cfg
|
|
|
|
except IOError:
|
|
|
|
pytest.skip("PKI config not present.Skipping test")
|
|
|
|
|
|
|
|
|
2022-06-03 13:28:38 -05:00
|
|
|
class TestInstallWithCA_DNS1_RSN(TestInstallWithCA_DNS1):
|
|
|
|
random_serial = True
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def install(cls, mh):
|
|
|
|
if not pki_supports_RSNv3(mh.master):
|
|
|
|
raise pytest.skip("RNSv3 not supported")
|
|
|
|
super(TestInstallWithCA_DNS1_RSN, cls).install(mh)
|
|
|
|
|
|
|
|
|
|
|
|
class TestInstallWithCA_KRA1_RSN(TestInstallWithCA_KRA1):
|
|
|
|
random_serial = True
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def install(cls, mh):
|
|
|
|
if not pki_supports_RSNv3(mh.master):
|
|
|
|
raise pytest.skip("RNSv3 not supported")
|
|
|
|
super(TestInstallWithCA_KRA1_RSN, cls).install(mh)
|
|
|
|
|
|
|
|
|
|
|
|
class TestIPACommand_RSN(TestIPACommand):
|
|
|
|
random_serial = True
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def install(cls, mh):
|
|
|
|
if not pki_supports_RSNv3(mh.master):
|
|
|
|
raise pytest.skip("RNSv3 not supported")
|
|
|
|
super(TestIPACommand_RSN, cls).install(mh)
|
|
|
|
|
|
|
|
|
|
|
|
class TestServerCALessToExternalCA_RSN(TestServerCALessToExternalCA):
|
|
|
|
random_serial = True
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def install(cls, mh):
|
|
|
|
if not pki_supports_RSNv3(mh.master):
|
|
|
|
raise pytest.skip("RNSv3 not supported")
|
|
|
|
super(TestServerCALessToExternalCA_RSN, cls).install(mh)
|
2022-06-13 03:19:08 -05:00
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def uninstall(cls, mh):
|
|
|
|
if not pki_supports_RSNv3(mh.master):
|
|
|
|
raise pytest.skip("RSNv3 not supported")
|
|
|
|
super(TestServerCALessToExternalCA_RSN, cls).uninstall(mh)
|
2022-07-14 03:20:23 -05:00
|
|
|
|
|
|
|
|
|
|
|
class TestRSNPKIConfig(TestInstallWithCA_KRA1):
|
|
|
|
random_serial = True
|
|
|
|
num_replicas = 3
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def install(cls, mh):
|
|
|
|
if not pki_supports_RSNv3(mh.master):
|
|
|
|
raise pytest.skip("RSNv3 not supported")
|
|
|
|
super(TestRSNPKIConfig, cls).install(mh)
|
|
|
|
|
|
|
|
def test_check_pki_config(self):
|
|
|
|
check_pki_config_params(self.master)
|
|
|
|
check_pki_config_params(self.replicas[0])
|
|
|
|
check_pki_config_params(self.replicas[1])
|
|
|
|
|
|
|
|
def test_check_rsn_version(self):
|
|
|
|
tasks.kinit_admin(self.master)
|
|
|
|
res = self.master.run_command(['ipa', 'ca-find'])
|
|
|
|
assert 'RSN Version: 3' in res.stdout_text
|
|
|
|
tasks.kinit_admin(self.replicas[0])
|
|
|
|
res = self.replicas[0].run_command(['ipa', 'ca-find'])
|
|
|
|
assert 'RSN Version: 3' in res.stdout_text
|
|
|
|
|
|
|
|
|
|
|
|
class TestRSNVault(TestInstallKRA):
|
|
|
|
random_serial = True
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def install(cls, mh):
|
|
|
|
if not pki_supports_RSNv3(mh.master):
|
|
|
|
raise pytest.skip("RSNv3 not supported")
|
|
|
|
super(TestRSNVault, cls).install(mh)
|