mirror of
https://github.com/saltstack/salt.git
synced 2025-04-17 10:10:20 +00:00
453 lines
14 KiB
Python
453 lines
14 KiB
Python
import pytest
|
|
from pytestskipmarkers.utils import platform
|
|
|
|
import salt.modules.postgres as postgres
|
|
import salt.states.postgres_group as postgres_group
|
|
from tests.support.mock import create_autospec, patch
|
|
|
|
|
|
@pytest.fixture(name="db_args")
|
|
def fixture_db_args():
|
|
return {
|
|
"runas": None,
|
|
"host": None,
|
|
"port": None,
|
|
"maintenance_db": None,
|
|
"user": None,
|
|
"password": None,
|
|
}
|
|
|
|
|
|
@pytest.fixture(name="md5_pw")
|
|
def fixture_md5_pw():
|
|
if platform.is_fips_enabled():
|
|
pytest.skip("Test cannot run on a FIPS enabled platform")
|
|
# 'md5' + md5('password' + 'groupname')
|
|
return "md58b14c378fab8ef0dc227f4e6d6787a87"
|
|
|
|
|
|
@pytest.fixture(name="existing_group")
|
|
def fixture_existing_group():
|
|
return {
|
|
"superuser": False,
|
|
"inherits privileges": True,
|
|
"can create roles": False,
|
|
"can create databases": False,
|
|
"can update system catalogs": None,
|
|
"can login": False,
|
|
"replication": False,
|
|
"connections": None,
|
|
"expiry time": None,
|
|
"defaults variables": "",
|
|
"password": "",
|
|
"groups": [],
|
|
}
|
|
|
|
|
|
@pytest.fixture(name="test_mode")
|
|
def fixture_test_mode():
|
|
with patch.dict(postgres_group.__opts__, {"test": True}):
|
|
yield
|
|
|
|
|
|
@pytest.fixture
|
|
def mocks():
|
|
return {
|
|
"postgres.role_get": create_autospec(postgres.role_get, return_value=None),
|
|
"postgres.user_exists": create_autospec(
|
|
postgres.user_exists, return_value=False
|
|
),
|
|
"postgres.group_create": create_autospec(
|
|
postgres.group_create, return_value=True
|
|
),
|
|
"postgres.group_update": create_autospec(
|
|
postgres.group_update, return_value=True
|
|
),
|
|
"postgres.group_remove": create_autospec(
|
|
postgres.group_remove, return_value=True
|
|
),
|
|
}
|
|
|
|
|
|
@pytest.fixture
|
|
def configure_loader_modules(mocks):
|
|
return {
|
|
postgres_group: {"__opts__": {"test": False}, "__salt__": mocks},
|
|
postgres: {"__opts__": {"test": False}},
|
|
}
|
|
|
|
|
|
# ==========
|
|
# postgres_group.present
|
|
# ==========
|
|
|
|
|
|
@pytest.mark.skip_on_fips_enabled_platform
|
|
def test_present_create_basic(mocks, db_args):
|
|
assert postgres_group.present("groupname") == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": "Present"},
|
|
"comment": "The group groupname has been created",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once_with(
|
|
"groupname", return_password=True, **db_args
|
|
)
|
|
mocks["postgres.group_create"].assert_called_once_with(
|
|
groupname="groupname",
|
|
createdb=None,
|
|
createroles=None,
|
|
encrypted="md5",
|
|
superuser=None,
|
|
login=None,
|
|
inherit=None,
|
|
replication=None,
|
|
rolepassword=None,
|
|
groups=None,
|
|
**db_args
|
|
)
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
@pytest.mark.usefixtures("test_mode")
|
|
def test_present_create_basic_test(mocks, db_args):
|
|
assert postgres_group.present("groupname") == {
|
|
"name": "groupname",
|
|
"result": None,
|
|
"changes": {},
|
|
"comment": "Group groupname is set to be created",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once_with(
|
|
"groupname", return_password=True, **db_args
|
|
)
|
|
mocks["postgres.group_create"].assert_not_called()
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_exists_basic(mocks, existing_group, db_args):
|
|
mocks["postgres.role_get"].return_value = existing_group
|
|
|
|
assert postgres_group.present("groupname") == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {},
|
|
"comment": "Group groupname is already present",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once_with(
|
|
"groupname", return_password=True, **db_args
|
|
)
|
|
mocks["postgres.group_create"].assert_not_called()
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_create_basic_error(mocks, db_args):
|
|
mocks["postgres.group_create"].return_value = False
|
|
|
|
assert postgres_group.present("groupname") == {
|
|
"name": "groupname",
|
|
"result": False,
|
|
"changes": {},
|
|
"comment": "Failed to create group groupname",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once_with(
|
|
"groupname", return_password=True, **db_args
|
|
)
|
|
mocks["postgres.group_create"].assert_called_once()
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_change_option(mocks, existing_group, db_args):
|
|
mocks["postgres.role_get"].return_value = existing_group
|
|
|
|
assert postgres_group.present("groupname", replication=True) == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": {"replication": True}},
|
|
"comment": "The group groupname has been updated",
|
|
}
|
|
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_not_called()
|
|
mocks["postgres.group_update"].assert_called_once_with(
|
|
groupname="groupname",
|
|
createdb=None,
|
|
createroles=None,
|
|
encrypted="md5",
|
|
superuser=None,
|
|
login=None,
|
|
inherit=None,
|
|
replication=True,
|
|
rolepassword=None,
|
|
groups=None,
|
|
**db_args
|
|
)
|
|
|
|
|
|
def test_present_create_md5_password(mocks, md5_pw, db_args):
|
|
assert postgres_group.present("groupname", password="password", encrypted=True) == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": "Present"},
|
|
"comment": "The group groupname has been created",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_called_once_with(
|
|
groupname="groupname",
|
|
createdb=None,
|
|
createroles=None,
|
|
encrypted=True,
|
|
superuser=None,
|
|
login=None,
|
|
inherit=None,
|
|
replication=None,
|
|
rolepassword=md5_pw,
|
|
groups=None,
|
|
**db_args
|
|
)
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_create_plain_password(mocks, db_args):
|
|
assert postgres_group.present(
|
|
"groupname", password="password", encrypted=False
|
|
) == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": "Present"},
|
|
"comment": "The group groupname has been created",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_called_once_with(
|
|
groupname="groupname",
|
|
createdb=None,
|
|
createroles=None,
|
|
encrypted=False,
|
|
superuser=None,
|
|
login=None,
|
|
inherit=None,
|
|
replication=None,
|
|
rolepassword="password",
|
|
groups=None,
|
|
**db_args
|
|
)
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_create_md5_password_default_plain(mocks, monkeypatch, md5_pw, db_args):
|
|
monkeypatch.setattr(postgres, "_DEFAULT_PASSWORDS_ENCRYPTION", False)
|
|
test_present_create_md5_password(mocks, md5_pw, db_args)
|
|
|
|
|
|
def test_present_create_md5_password_default_encrypted(
|
|
mocks, monkeypatch, md5_pw, db_args
|
|
):
|
|
monkeypatch.setattr(postgres, "_DEFAULT_PASSWORDS_ENCRYPTION", True)
|
|
|
|
assert postgres_group.present("groupname", password="password") == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": "Present"},
|
|
"comment": "The group groupname has been created",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_called_once_with(
|
|
groupname="groupname",
|
|
createdb=None,
|
|
createroles=None,
|
|
encrypted=True,
|
|
superuser=None,
|
|
login=None,
|
|
inherit=None,
|
|
replication=None,
|
|
rolepassword=md5_pw,
|
|
groups=None,
|
|
**db_args
|
|
)
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_create_md5_prehashed(mocks, md5_pw, db_args):
|
|
assert postgres_group.present("groupname", password=md5_pw, encrypted=True) == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": "Present"},
|
|
"comment": "The group groupname has been created",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_called_once_with(
|
|
groupname="groupname",
|
|
createdb=None,
|
|
createroles=None,
|
|
encrypted=True,
|
|
superuser=None,
|
|
login=None,
|
|
inherit=None,
|
|
replication=None,
|
|
rolepassword=md5_pw,
|
|
groups=None,
|
|
**db_args
|
|
)
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_md5_matches(mocks, existing_group, md5_pw):
|
|
existing_group["password"] = md5_pw
|
|
mocks["postgres.role_get"].return_value = existing_group
|
|
|
|
assert postgres_group.present("groupname", password="password", encrypted=True) == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {},
|
|
"comment": "Group groupname is already present",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_not_called()
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_md5_matches_prehashed(mocks, existing_group, md5_pw):
|
|
existing_group["password"] = md5_pw
|
|
mocks["postgres.role_get"].return_value = existing_group
|
|
|
|
assert postgres_group.present("groupname", password=md5_pw, encrypted=True) == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {},
|
|
"comment": "Group groupname is already present",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_not_called()
|
|
mocks["postgres.group_update"].assert_not_called()
|
|
|
|
|
|
def test_present_update_md5_password(mocks, existing_group, md5_pw, db_args):
|
|
existing_group["password"] = "md500000000000000000000000000000000"
|
|
mocks["postgres.role_get"].return_value = existing_group
|
|
|
|
assert postgres_group.present("groupname", password="password", encrypted=True) == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": {"password": True}},
|
|
"comment": "The group groupname has been updated",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_not_called()
|
|
mocks["postgres.group_update"].assert_called_once_with(
|
|
groupname="groupname",
|
|
createdb=None,
|
|
createroles=None,
|
|
encrypted=True,
|
|
superuser=None,
|
|
login=None,
|
|
inherit=None,
|
|
replication=None,
|
|
rolepassword=md5_pw,
|
|
groups=None,
|
|
**db_args
|
|
)
|
|
|
|
|
|
@pytest.mark.skip_on_fips_enabled_platform
|
|
def test_present_update_error(mocks, existing_group):
|
|
existing_group["password"] = "md500000000000000000000000000000000"
|
|
mocks["postgres.role_get"].return_value = existing_group
|
|
mocks["postgres.group_update"].return_value = False
|
|
|
|
assert postgres_group.present("groupname", password="password", encrypted=True) == {
|
|
"name": "groupname",
|
|
"result": False,
|
|
"changes": {},
|
|
"comment": "Failed to update group groupname",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once()
|
|
mocks["postgres.group_create"].assert_not_called()
|
|
mocks["postgres.group_update"].assert_called_once()
|
|
|
|
|
|
def test_present_update_password_no_check(mocks, existing_group, md5_pw, db_args):
|
|
mocks["postgres.role_get"].return_value = existing_group
|
|
|
|
assert postgres_group.present(
|
|
"groupname", password="password", encrypted=True, refresh_password=True
|
|
) == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": {"password": True}},
|
|
"comment": "The group groupname has been updated",
|
|
}
|
|
mocks["postgres.role_get"].assert_called_once_with(
|
|
"groupname", return_password=False, **db_args
|
|
)
|
|
mocks["postgres.group_create"].assert_not_called()
|
|
mocks["postgres.group_update"].assert_called_once_with(
|
|
groupname="groupname",
|
|
createdb=None,
|
|
createroles=None,
|
|
encrypted=True,
|
|
superuser=None,
|
|
login=None,
|
|
inherit=None,
|
|
replication=None,
|
|
rolepassword=md5_pw,
|
|
groups=None,
|
|
**db_args
|
|
)
|
|
|
|
|
|
# ==========
|
|
# postgres_group.absent
|
|
# ==========
|
|
|
|
|
|
def test_absent_delete(mocks, db_args):
|
|
mocks["postgres.user_exists"].return_value = True
|
|
|
|
assert postgres_group.absent("groupname") == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {"groupname": "Absent"},
|
|
"comment": "Group groupname has been removed",
|
|
}
|
|
mocks["postgres.user_exists"].assert_called_once_with("groupname", **db_args)
|
|
mocks["postgres.group_remove"].assert_called_once_with("groupname", **db_args)
|
|
|
|
|
|
@pytest.mark.usefixtures("test_mode")
|
|
def test_absent_test(mocks, db_args):
|
|
mocks["postgres.user_exists"].return_value = True
|
|
|
|
assert postgres_group.absent("groupname") == {
|
|
"name": "groupname",
|
|
"result": None,
|
|
"changes": {},
|
|
"comment": "Group groupname is set to be removed",
|
|
}
|
|
mocks["postgres.user_exists"].assert_called_once_with("groupname", **db_args)
|
|
mocks["postgres.group_remove"].assert_not_called()
|
|
|
|
|
|
def test_absent_already(mocks, db_args):
|
|
mocks["postgres.user_exists"].return_value = False
|
|
|
|
assert postgres_group.absent("groupname") == {
|
|
"name": "groupname",
|
|
"result": True,
|
|
"changes": {},
|
|
"comment": "Group groupname is not present, so it cannot be removed",
|
|
}
|
|
mocks["postgres.user_exists"].assert_called_once_with("groupname", **db_args)
|
|
mocks["postgres.group_remove"].assert_not_called()
|
|
|
|
|
|
def test_absent_error(mocks):
|
|
mocks["postgres.user_exists"].return_value = True
|
|
mocks["postgres.group_remove"].return_value = False
|
|
|
|
assert postgres_group.absent("groupname") == {
|
|
"name": "groupname",
|
|
"result": False,
|
|
"changes": {},
|
|
"comment": "Group groupname failed to be removed",
|
|
}
|
|
mocks["postgres.user_exists"].assert_called_once()
|
|
mocks["postgres.group_remove"].assert_called_once()
|