mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-02-25 18:55:28 -06:00
Remove DL0 specific tests from ipatests/test_integration/test_replica_promotion.py
These tests have been skipped already before. Therefore they can be removed. See: https://pagure.io/freeipa/issue/7689 Signed-off-by: Thomas Woerner <twoerner@redhat.com> Reviewed-By: Alexander Bokovoy <abokovoy@redhat.com>
This commit is contained in:
parent
374138d030
commit
fca1167af4
@ -8,14 +8,13 @@ import time
|
||||
import re
|
||||
from tempfile import NamedTemporaryFile
|
||||
import textwrap
|
||||
import pytest
|
||||
from ipatests.test_integration.base import IntegrationTest
|
||||
from ipatests.pytest_ipa.integration import tasks
|
||||
from ipatests.pytest_ipa.integration.tasks import (
|
||||
assert_error, replicas_cleanup)
|
||||
from ipatests.pytest_ipa.integration.env_config import get_global_config
|
||||
from ipalib.constants import (
|
||||
DOMAIN_LEVEL_0, DOMAIN_LEVEL_1, DOMAIN_SUFFIX_NAME, IPA_CA_NICKNAME)
|
||||
DOMAIN_LEVEL_1, IPA_CA_NICKNAME)
|
||||
from ipaplatform.paths import paths
|
||||
from ipapython import certdb
|
||||
|
||||
@ -40,138 +39,6 @@ class ReplicaPromotionBase(IntegrationTest):
|
||||
assert(found > 0), result2.stdout_text
|
||||
|
||||
|
||||
@pytest.mark.skip(reason="Domain level 0 is not supported anymore")
|
||||
class TestReplicaPromotionLevel0(ReplicaPromotionBase):
|
||||
|
||||
topology = 'star'
|
||||
num_replicas = 1
|
||||
domain_level = DOMAIN_LEVEL_0
|
||||
|
||||
@pytest.mark.skip(reason="Domain level 0 is not supported anymore")
|
||||
@replicas_cleanup
|
||||
def test_promotion_disabled(self):
|
||||
"""
|
||||
Testcase:
|
||||
http://www.freeipa.org/page/V4/Replica_Promotion/Test_plan#Test_case:
|
||||
_Make_sure_the_feature_is_unavailable_under_domain_level_0
|
||||
"""
|
||||
client = self.replicas[0]
|
||||
tasks.install_client(self.master, client)
|
||||
args = ['ipa-replica-install', '-U',
|
||||
'-p', self.master.config.dirman_password,
|
||||
'-w', self.master.config.admin_password,
|
||||
'--ip-address', client.ip]
|
||||
result = client.run_command(args, raiseonerr=False)
|
||||
assert_error(result,
|
||||
'You must provide a file generated by ipa-replica-prepare'
|
||||
' to create a replica when the domain is at level 0', 1)
|
||||
|
||||
@pytest.mark.xfail(reason="Ticket N 6274", strict=True)
|
||||
@replicas_cleanup
|
||||
def test_backup_restore(self):
|
||||
"""
|
||||
TestCase:
|
||||
http://www.freeipa.org/page/V4/Replica_Promotion/Test_plan#Test_case:
|
||||
_ipa-restore_after_domainlevel_raise_restores_original_domain_level
|
||||
"""
|
||||
command = ["ipa", "topologysegment-find", DOMAIN_SUFFIX_NAME]
|
||||
tasks.install_replica(self.master, self.replicas[0])
|
||||
backup_file = tasks.ipa_backup(self.master)
|
||||
self.master.run_command(["ipa", "domainlevel-set", str(DOMAIN_LEVEL_1)])
|
||||
# We need to give the server time to merge 2 one-way segments into one
|
||||
time.sleep(10)
|
||||
result = self.master.run_command(command)
|
||||
found1 = result.stdout_text.rfind("1 segment matched")
|
||||
assert(found1 > 0), result.stdout_text
|
||||
tasks.ipa_restore(self.master, backup_file)
|
||||
result2 = self.master.run_command(command, raiseonerr=False)
|
||||
found2 = result2.stdout_text.rfind("0 segments matched")
|
||||
assert(found2 > 0), result2.stdout_text
|
||||
|
||||
|
||||
@pytest.mark.skip(reason="Domain level 0 is not supported anymore")
|
||||
@pytest.mark.xfail(reason="Ticket N 6274", strict=True)
|
||||
class TestKRAInstall(IntegrationTest):
|
||||
"""
|
||||
TestCase: http://www.freeipa.org/page/V4/Replica_Promotion/Test_plan
|
||||
#Test_case:_ipa-kra-install_with_replica_file_works_only_on_domain_level_0
|
||||
"""
|
||||
topology = 'star'
|
||||
domain_level = DOMAIN_LEVEL_0
|
||||
num_replicas = 2
|
||||
|
||||
@classmethod
|
||||
def install(cls, mh):
|
||||
tasks.install_master(cls.master, domain_level=cls.domain_level)
|
||||
|
||||
def test_kra_install_without_replica_file(self):
|
||||
master = self.master
|
||||
replica1 = self.replicas[0]
|
||||
replica2 = self.replicas[1]
|
||||
tasks.install_kra(master, first_instance=True)
|
||||
tasks.install_replica(master, replica1)
|
||||
result1 = tasks.install_kra(replica1,
|
||||
domain_level=DOMAIN_LEVEL_1,
|
||||
raiseonerr=False)
|
||||
assert_error(result1, "A replica file is required", 1)
|
||||
tasks.install_kra(replica1,
|
||||
domain_level=DOMAIN_LEVEL_0,
|
||||
raiseonerr=True)
|
||||
# Now prepare the replica file, copy it to the client and raise
|
||||
# domain level on master to test the reverse situation
|
||||
tasks.replica_prepare(master, replica2)
|
||||
master.run_command(["ipa", "domainlevel-set", str(DOMAIN_LEVEL_1)])
|
||||
tasks.install_replica(master, replica2)
|
||||
result2 = tasks.install_kra(replica2,
|
||||
domain_level=DOMAIN_LEVEL_0,
|
||||
raiseonerr=False)
|
||||
assert_error(result2, "No replica file is required", 1)
|
||||
tasks.install_kra(replica2)
|
||||
|
||||
|
||||
@pytest.mark.skip(reason="Domain level 0 is not supported anymore")
|
||||
@pytest.mark.xfail(reason="Ticket N 6274", strict=True)
|
||||
class TestCAInstall(IntegrationTest):
|
||||
topology = 'star'
|
||||
domain_level = DOMAIN_LEVEL_0
|
||||
num_replicas = 2
|
||||
|
||||
@classmethod
|
||||
def install(cls, mh):
|
||||
tasks.install_master(cls.master, domain_level=cls.domain_level)
|
||||
|
||||
def test_ca_install_without_replica_file(self):
|
||||
"""
|
||||
TestCase:
|
||||
http://www.freeipa.org/page/V4/Replica_Promotion/Test_plan#Test_case:
|
||||
_ipa-ca-install_with_replica_file_works_only_on_domain_level_0
|
||||
"""
|
||||
master = self.master
|
||||
replica1 = self.replicas[0]
|
||||
replica2 = self.replicas[1]
|
||||
for replica in self.replicas:
|
||||
tasks.install_replica(master, replica, setup_ca=False,
|
||||
setup_dns=True)
|
||||
result1 = tasks.install_ca(replica1,
|
||||
domain_level=DOMAIN_LEVEL_1,
|
||||
raiseonerr=False)
|
||||
assert_error(result1, "If you wish to replicate CA to this host,"
|
||||
" please re-run 'ipa-ca-install'\nwith a"
|
||||
" replica file generated on an existing CA"
|
||||
" master as argument.", 1)
|
||||
|
||||
tasks.install_ca(replica1, domain_level=DOMAIN_LEVEL_0)
|
||||
# Now prepare the replica file, copy it to the client and raise
|
||||
# domain level on master to test the reverse situation
|
||||
master.run_command(["ipa", "domainlevel-set", str(DOMAIN_LEVEL_1)])
|
||||
result2 = tasks.install_ca(replica2,
|
||||
domain_level=DOMAIN_LEVEL_0,
|
||||
raiseonerr=False)
|
||||
assert_error(result2, 'Too many parameters provided.'
|
||||
' No replica file is required', 1)
|
||||
tasks.install_ca(replica2, domain_level=DOMAIN_LEVEL_1)
|
||||
|
||||
|
||||
class TestReplicaPromotionLevel1(ReplicaPromotionBase):
|
||||
"""
|
||||
TestCase: http://www.freeipa.org/page/V4/Replica_Promotion/Test_plan#
|
||||
@ -182,19 +49,6 @@ class TestReplicaPromotionLevel1(ReplicaPromotionBase):
|
||||
num_replicas = 1
|
||||
domain_level = DOMAIN_LEVEL_1
|
||||
|
||||
@pytest.mark.skip(reason="Domain level 0 is not supported anymore")
|
||||
@replicas_cleanup
|
||||
def test_replica_prepare_disabled(self):
|
||||
replica = self.replicas[0]
|
||||
args = ['ipa-replica-prepare',
|
||||
'-p', self.master.config.dirman_password,
|
||||
'--ip-address', replica.ip,
|
||||
replica.hostname]
|
||||
result = self.master.run_command(args, raiseonerr=False)
|
||||
assert_error(result, "Replica creation using 'ipa-replica-prepare'"
|
||||
" to generate replica file\n"
|
||||
"is supported only in 0-level IPA domain", 1)
|
||||
|
||||
@replicas_cleanup
|
||||
def test_one_command_installation(self):
|
||||
"""
|
||||
@ -213,89 +67,6 @@ class TestReplicaPromotionLevel1(ReplicaPromotionBase):
|
||||
assert "PKINIT is enabled" in result.stdout_text
|
||||
|
||||
|
||||
@pytest.mark.skip(reason="Domain level 0 is not supported anymore")
|
||||
@pytest.mark.xfail(reason="Ticket N 6274", strict=True)
|
||||
class TestReplicaManageCommands(IntegrationTest):
|
||||
topology = "star"
|
||||
num_replicas = 2
|
||||
domain_level = DOMAIN_LEVEL_0
|
||||
|
||||
def test_replica_manage_commands(self):
|
||||
"""
|
||||
TestCase: http://www.freeipa.org/page/V4/Replica_Promotion/Test_plan
|
||||
#Test_case:_ipa-replica-manage_connect_is_deprecated_in_domain_level_1
|
||||
"""
|
||||
master = self.master
|
||||
replica1 = self.replicas[0]
|
||||
replica2 = self.replicas[1]
|
||||
|
||||
result1 = master.run_command(["ipa-replica-manage",
|
||||
"connect",
|
||||
replica1.hostname,
|
||||
replica2.hostname],
|
||||
raiseonerr=False)
|
||||
assert result1.returncode == 0, result1.stderr_text
|
||||
result2 = master.run_command(["ipa-replica-manage",
|
||||
"disconnect",
|
||||
replica1.hostname,
|
||||
replica2.hostname],
|
||||
raiseonerr=False)
|
||||
assert result2.returncode == 0, result2.stderr_text
|
||||
master.run_command(["ipa", "domainlevel-set", str(DOMAIN_LEVEL_1)])
|
||||
result3 = master.run_command(["ipa-replica-manage",
|
||||
"connect",
|
||||
replica1.hostname,
|
||||
replica2.hostname],
|
||||
raiseonerr=False)
|
||||
assert_error(result3, 'Creation of IPA replication agreement is'
|
||||
' deprecated with managed IPA replication'
|
||||
' topology. Please use `ipa topologysegment-*`'
|
||||
' commands to manage the topology', 1)
|
||||
segment = tasks.create_segment(master, replica1, replica2)
|
||||
result4 = master.run_command(["ipa-replica-manage",
|
||||
"disconnect",
|
||||
replica1.hostname,
|
||||
replica2.hostname],
|
||||
raiseonerr=False)
|
||||
assert_error(result4, 'Removal of IPA replication agreement is'
|
||||
' deprecated with managed IPA replication'
|
||||
' topology. Please use `ipa topologysegment-*`'
|
||||
' commands to manage the topology', 1)
|
||||
|
||||
# http://www.freeipa.org/page/V4/Replica_Promotion/Test_plan
|
||||
#Test_case:_ipa-csreplica-manage_connect_is_deprecated
|
||||
#_in_domain_level_1
|
||||
|
||||
result5 = master.run_command(['ipa-csreplica-manage', 'del',
|
||||
replica1.hostname,
|
||||
'-p', master.config.dirman_password],
|
||||
raiseonerr=False)
|
||||
assert_error(result5, "Removal of IPA CS replication agreement"
|
||||
" and replication data is deprecated with"
|
||||
" managed IPA replication topology", 1)
|
||||
|
||||
tasks.destroy_segment(master, segment[0]['name'])
|
||||
result6 = master.run_command(["ipa-csreplica-manage",
|
||||
"connect",
|
||||
replica1.hostname,
|
||||
replica2.hostname,
|
||||
'-p', master.config.dirman_password],
|
||||
raiseonerr=False)
|
||||
assert_error(result6, "Creation of IPA CS replication agreement is"
|
||||
" deprecated with managed IPA replication"
|
||||
" topology", 1)
|
||||
tasks.create_segment(master, replica1, replica2)
|
||||
result7 = master.run_command(["ipa-csreplica-manage",
|
||||
"disconnect",
|
||||
replica1.hostname,
|
||||
replica2.hostname,
|
||||
'-p', master.config.dirman_password],
|
||||
raiseonerr=False)
|
||||
assert_error(result7, "Removal of IPA CS replication agreement is"
|
||||
" deprecated with managed IPA"
|
||||
" replication topology", 1)
|
||||
|
||||
|
||||
class TestUnprivilegedUserPermissions(IntegrationTest):
|
||||
"""
|
||||
TestCase:
|
||||
@ -381,34 +152,6 @@ class TestProhibitReplicaUninstallation(IntegrationTest):
|
||||
'-U', '--ignore-topology-disconnect'])
|
||||
|
||||
|
||||
@pytest.mark.skip(reason="Domain level 0 is not supported anymore")
|
||||
@pytest.mark.xfail(reason="Ticket N 6274", strict=True)
|
||||
class TestOldReplicaWorksAfterDomainUpgrade(IntegrationTest):
|
||||
topology = 'star'
|
||||
num_replicas = 1
|
||||
domain_level = DOMAIN_LEVEL_0
|
||||
username = 'testuser'
|
||||
|
||||
def test_replica_after_domain_upgrade(self):
|
||||
tasks.kinit_admin(self.master)
|
||||
tasks.kinit_admin(self.replicas[0])
|
||||
self.master.run_command(['ipa', 'user-add', self.username,
|
||||
'--first', 'test',
|
||||
'--last', 'user'])
|
||||
tasks.wait_for_replication(self.replicas[0].ldap_connect())
|
||||
self.master.run_command(['ipa', 'domainlevel-set',
|
||||
str(DOMAIN_LEVEL_1)])
|
||||
result = self.replicas[0].run_command(['ipa', 'user-show',
|
||||
self.username])
|
||||
assert("User login: %s" % self.username in result.stdout_text), (
|
||||
"A testuser was not found on replica after domain upgrade")
|
||||
self.replicas[0].run_command(['ipa', 'user-del', self.username])
|
||||
tasks.wait_for_replication(self.master.ldap_connect())
|
||||
result1 = self.master.run_command(['ipa', 'user-show', self.username],
|
||||
raiseonerr=False)
|
||||
assert_error(result1, "%s: user not found" % self.username, 2)
|
||||
|
||||
|
||||
class TestWrongClientDomain(IntegrationTest):
|
||||
topology = "star"
|
||||
num_replicas = 1
|
||||
|
Loading…
Reference in New Issue
Block a user