From f3ad769e2ed1d82b81f31c940eb30b3591357d00 Mon Sep 17 00:00:00 2001 From: Patrik Rosecky Date: Wed, 20 Dec 2023 15:33:09 +0100 Subject: [PATCH] Tests: convert multihost/alltests/test_cache_testing to system/test_sss_cache --- .../multihost/alltests/test_cache_testing.py | 4 + src/tests/system/tests/test_memory_cache.py | 3 + src/tests/system/tests/test_sss_cache.py | 105 ++++++++++++++++++ 3 files changed, 112 insertions(+) diff --git a/src/tests/multihost/alltests/test_cache_testing.py b/src/tests/multihost/alltests/test_cache_testing.py index 774f43ae170..ac148a9a1aa 100644 --- a/src/tests/multihost/alltests/test_cache_testing.py +++ b/src/tests/multihost/alltests/test_cache_testing.py @@ -42,6 +42,7 @@ class TestCacheTesting(): Test for correct cache presence in case of variety of SSSD Configurations. Test for correct cache presence in case of modification & deletion of user entries. """ + @pytest.mark.converted('test_sss_cache.py', 'test_sss_cache__verify_timestamp_cache') @staticmethod def test_0001_Verify_Timestamp_Cache_Exists(multihost): """ @@ -64,6 +65,7 @@ def test_0001_Verify_Timestamp_Cache_Exists(multihost): cmd = multihost.client[0].run_command(list_cmd, raiseonerr=False) assert cmd.returncode == 0, f"Could not find timestamp cache file {file}" + @pytest.mark.converted('test_sss_cache.py', 'test_sss_cache__verify_timestamp_cache') @staticmethod def test_0002_Verify_Cache_on_User_Lookup(multihost): """ @@ -417,6 +419,7 @@ def test_0012_Set_refresh_expired_interval_to_40(multihost, backupsssdconf): assert cmd2.returncode == 0, f'{ldb_cmd2} did not execute successfully' assert "dataExpireTimestamp: 1\n" not in cmd2_output, "dataExpireTimestamp found in /tmp/file_ldb2" + @pytest.mark.converted('test_sss_cache.py', 'test_sss_cache__delete_and_modify_user_updates_cache') @staticmethod def test_0013_Modify_User_Attribute(multihost): """ @@ -465,6 +468,7 @@ def test_0013_Modify_User_Attribute(multihost): assert cmd4.returncode == 0, f'{ldb_cmd2} did not execute successfully' assert "dataExpireTimestamp: 1\n" not in cmd4_output, "dataExpireTimestamp found in /tmp/file_ldb2" + @pytest.mark.converted('test_sss_cache.py', 'test_sss_cache__delete_and_modify_user_updates_cache') @staticmethod def test_0014_Delete_an_existing_user(multihost): """ diff --git a/src/tests/system/tests/test_memory_cache.py b/src/tests/system/tests/test_memory_cache.py index ad35d1d1876..69241a0bb04 100644 --- a/src/tests/system/tests/test_memory_cache.py +++ b/src/tests/system/tests/test_memory_cache.py @@ -6,7 +6,10 @@ from __future__ import annotations +import time + import pytest +from pytest_mh.ssh import SSHAuthenticationError from sssd_test_framework.roles.client import Client from sssd_test_framework.roles.generic import GenericProvider from sssd_test_framework.roles.ldap import LDAP diff --git a/src/tests/system/tests/test_sss_cache.py b/src/tests/system/tests/test_sss_cache.py index f972f3dcba4..4e90f5b4c9f 100644 --- a/src/tests/system/tests/test_sss_cache.py +++ b/src/tests/system/tests/test_sss_cache.py @@ -111,3 +111,108 @@ def test_sss_cache__background_refresh(client: Client, provider: GenericProvider for y in v.items(): if y[0] == "lastUpdate": assert last_update[s] <= (int(y[1][0])) + + +@pytest.mark.topology(KnownTopologyGroup.AnyProvider) +def test_sss_cache__verify_timestamp_cache(client: Client, provider: GenericProvider): + """ + :title: Verify the existence of timestamp cache and use lsbsearch on those files + :setup: + 1. Add user + 2. Start SSSD + :steps: + 1. Execute getent passwd to fetch user details + 2. Check if timestamps cache file exists + 3. Get user information using ldbsearch on cache_test.ldb + 4. Get user timestamp information using ldbsearch on timestamps_test.ldb + :expectedresults: + 1. User details should be successfully fetched + 2. Cache file should be present + 3. User information were successfully fetched + 4. User information were successfully fetched + :customerscenario: False + """ + provider.user("user1").add() + client.sssd.start() + + client.tools.getent.passwd("user1") + cache = "/var/lib/sss/db/cache_test.ldb" + timestamps = "/var/lib/sss/db/timestamps_test.ldb" + assert client.fs.exists(timestamps), f"Timestamp file '{timestamps}' does not exist" + + ldb1 = client.ldb.search(cache, "name=user1@test,cn=users,cn=test,cn=sysdb") + ldb2 = client.ldb.search(timestamps, "name=user1@test,cn=users,cn=test,cn=sysdb") + assert ldb1 != {}, f"ldbsearch failed to find user1 in {cache}" + assert ldb2 != {}, f"ldbsearch failed to find user1 in {timestamps}" + + +@pytest.mark.topology(KnownTopologyGroup.AnyProvider) +def test_sss_cache__check_timestamps_fully_qualified_names(client: Client, provider: GenericProvider): + """ + :title: Set use fully qualified names to true and verify cache updates + :setup: + 1. Add user + 2. Set use_fully_qualified_names to True in the sssd.conf + 3. Start SSSD + 4. Execute getent passwd user1@test + :steps: + 1. Get user information using ldbsearch on cache_test.ldb + 2. Get user timestamp information using ldbsearch on timestamps_test.ldb + :expectedresults: + 1. User information were successfully fetched + 2. User information were successfully fetched + :customerscenario: False + """ + provider.user("user1").add() + client.sssd.domain["use_fully_qualified_names"] = "True" + client.sssd.start() + client.tools.getent.passwd("user1@test") + + cache = "/var/lib/sss/db/cache_test.ldb" + timestamps = "/var/lib/sss/db/timestamps_test.ldb" + user_basedn = "name=user1@test,cn=users,cn=test,cn=sysdb" + ldb1 = client.ldb.search(cache, user_basedn) + ldb2 = client.ldb.search(timestamps, user_basedn) + + assert ldb1 != {}, f"ldbsearch failed to find user1@test in {cache}" + assert ldb2 != {}, f"ldbsearch failed to find user1@test in {timestamps}" + + +@pytest.mark.topology(KnownTopologyGroup.AnyProvider) +def test_sss_cache__delete_and_modify_user_updates_cache(client: Client, provider: GenericProvider): + """ + :title: Modify user attribute and verify cache updates + :setup: + 1. Add users + 3. Start SSSD + 4. Execute getent passwd to fetch cache + 5. Expire whole cache + 6. Modify and delete user attribute + 7. Execute getent passwd again + :steps: + 1. Try to login + 2. Check that modified user was modified + :expectedresults: + 1. Modified user can login, Deleted usec cannot login + 2. Modified user has correct attributes + :customerscenario: False + """ + provider.user("user-modify").add(shell="/bin/bash") + provider.user("user-delete").add(shell="/bin/bash") + client.sssd.start() + client.tools.getent.passwd("user-modify") + client.tools.getent.passwd("user-delete") + client.sssctl.cache_expire(everything=True) + + provider.user("user-delete").delete() + provider.user("user-modify").modify(shell="/bin/sh") + + client.tools.getent.passwd("user-delete") + client.tools.getent.passwd("user-modify") + + assert client.auth.ssh.password("user-modify", "Secret123") + assert not client.auth.ssh.password("user-delete", "Secret123") + + modify = client.tools.getent.passwd("user-modify") + assert modify is not None + assert modify.shell == "/bin/sh"