salt/tests/pytests/unit/modules/test_win_lgpo_reg.py
2023-04-27 09:28:25 +01:00

327 lines
9 KiB
Python

import pathlib
import pytest
import salt.modules.win_file as win_file
import salt.modules.win_lgpo_reg as lgpo_reg
import salt.utils.files
import salt.utils.win_dacl
import salt.utils.win_lgpo_reg
import salt.utils.win_reg
from salt.exceptions import SaltInvocationError
pytestmark = [
pytest.mark.windows_whitelisted,
pytest.mark.skip_unless_on_windows,
pytest.mark.destructive_test,
]
@pytest.fixture
def configure_loader_modules():
return {
win_file: {
"__utils__": {
"dacl.set_perms": salt.utils.win_dacl.set_perms,
"dacl.set_permissions": salt.utils.win_dacl.set_permissions,
},
},
}
@pytest.fixture
def empty_reg_pol():
class_info = salt.utils.win_lgpo_reg.CLASS_INFO
reg_pol_file = pathlib.Path(class_info["Machine"]["policy_path"])
if not reg_pol_file.parent.exists():
reg_pol_file.parent.mkdir(parents=True)
with salt.utils.files.fopen(str(reg_pol_file), "wb") as f:
f.write(salt.utils.win_lgpo_reg.REG_POL_HEADER.encode("utf-16-le"))
salt.utils.win_reg.delete_key_recursive(hive="HKLM", key="SOFTWARE\\MyKey1")
salt.utils.win_reg.delete_key_recursive(hive="HKLM", key="SOFTWARE\\MyKey2")
yield
salt.utils.win_reg.delete_key_recursive(hive="HKLM", key="SOFTWARE\\MyKey1")
salt.utils.win_reg.delete_key_recursive(hive="HKLM", key="SOFTWARE\\MyKey2")
with salt.utils.files.fopen(str(reg_pol_file), "wb") as f:
f.write(salt.utils.win_lgpo_reg.REG_POL_HEADER.encode("utf-16-le"))
@pytest.fixture
def reg_pol():
data_to_write = {
"SOFTWARE\\MyKey1": {
"MyValue1": {
"data": "squidward",
"type": "REG_SZ",
},
"**del.MyValue2": {
"data": " ",
"type": "REG_SZ",
},
},
"SOFTWARE\\MyKey2": {
"MyValue3": {
"data": ["spongebob", "squarepants"],
"type": "REG_MULTI_SZ",
},
},
}
lgpo_reg.write_reg_pol(data_to_write)
salt.utils.win_reg.set_value(
hive="HKLM",
key="SOFTWARE\\MyKey1",
vname="MyValue1",
vdata="squidward",
vtype="REG_SZ",
)
salt.utils.win_reg.set_value(
hive="HKLM",
key="SOFTWARE\\MyKey2",
vname="MyValue3",
vdata=["spongebob", "squarepants"],
vtype="REG_MULTI_SZ",
)
yield
salt.utils.win_reg.delete_key_recursive(hive="HKLM", key="SOFTWARE\\MyKey1")
salt.utils.win_reg.delete_key_recursive(hive="HKLM", key="SOFTWARE\\MyKey2")
class_info = salt.utils.win_lgpo_reg.CLASS_INFO
reg_pol_file = class_info["Machine"]["policy_path"]
with salt.utils.files.fopen(reg_pol_file, "wb") as f:
f.write(salt.utils.win_lgpo_reg.REG_POL_HEADER.encode("utf-16-le"))
def test_read_reg_pol(empty_reg_pol):
expected = {}
result = lgpo_reg.read_reg_pol()
assert result == expected
def test_read_reg_pol_invalid_policy_class():
pytest.raises(SaltInvocationError, lgpo_reg.read_reg_pol, policy_class="Invalid")
def test_write_reg_pol(empty_reg_pol):
data_to_write = {
r"SOFTWARE\MyKey": {
"MyValue": {
"data": "string",
"type": "REG_SZ",
},
},
}
lgpo_reg.write_reg_pol(data_to_write)
result = lgpo_reg.read_reg_pol()
assert result == data_to_write
def test_write_reg_pol_invalid_policy_class():
pytest.raises(
SaltInvocationError, lgpo_reg.write_reg_pol, data={}, policy_class="Invalid"
)
def test_get_value(reg_pol):
expected = {"data": "squidward", "type": "REG_SZ"}
result = lgpo_reg.get_value(key="SOFTWARE\\MyKey1", v_name="MyValue1")
assert result == expected
def test_get_value_invalid_policy_class():
pytest.raises(
SaltInvocationError,
lgpo_reg.get_value,
key="",
v_name="",
policy_class="Invalid",
)
def test_get_key(reg_pol):
expected = {
"MyValue3": {
"data": ["spongebob", "squarepants"],
"type": "REG_MULTI_SZ",
},
}
result = lgpo_reg.get_key(key="SOFTWARE\\MyKey2")
assert result == expected
def test_get_key_invalid_policy_class():
pytest.raises(SaltInvocationError, lgpo_reg.get_key, key="", policy_class="Invalid")
def test_set_value(empty_reg_pol):
key = "SOFTWARE\\MyKey"
v_name = "MyValue"
# Test command return
result = lgpo_reg.set_value(key=key, v_name=v_name, v_data="1")
assert result is True
# Test value actually set in Registry.pol
expected = {"data": 1, "type": "REG_DWORD"}
result = lgpo_reg.get_value(key=key, v_name=v_name)
assert result == expected
# Test that the registry value has been set
expected = {
"hive": "HKLM",
"key": key,
"vname": v_name,
"vdata": 1,
"vtype": "REG_DWORD",
"success": True,
}
result = salt.utils.win_reg.read_value(hive="HKLM", key=key, vname=v_name)
assert result == expected
def test_set_value_existing_change(reg_pol):
expected = {"data": 1, "type": "REG_DWORD"}
key = "SOFTWARE\\MyKey"
v_name = "MyValue1"
lgpo_reg.set_value(key=key, v_name=v_name, v_data="1")
result = lgpo_reg.get_value(key=key, v_name=v_name)
assert result == expected
expected = {
"hive": "HKLM",
"key": key,
"vname": v_name,
"vdata": 1,
"vtype": "REG_DWORD",
"success": True,
}
result = salt.utils.win_reg.read_value(hive="HKLM", key=key, vname=v_name)
assert result == expected
def test_set_value_existing_no_change(reg_pol):
expected = {"data": "squidward", "type": "REG_SZ"}
key = "SOFTWARE\\MyKey"
v_name = "MyValue1"
lgpo_reg.set_value(key=key, v_name=v_name, v_data="squidward", v_type="REG_SZ")
result = lgpo_reg.get_value(key=key, v_name=v_name)
assert result == expected
def test_set_value_invalid_policy_class():
pytest.raises(
SaltInvocationError,
lgpo_reg.set_value,
key="",
v_name="",
v_data="",
policy_class="Invalid",
)
def test_set_value_invalid_reg_type():
pytest.raises(
SaltInvocationError,
lgpo_reg.set_value,
key="",
v_name="",
v_data="",
v_type="REG_INVALID",
)
def test_set_value_invalid_reg_sz():
pytest.raises(
SaltInvocationError,
lgpo_reg.set_value,
key="",
v_name="",
v_data=[],
v_type="REG_SZ",
)
def test_set_value_invalid_reg_multi_sz():
pytest.raises(
SaltInvocationError,
lgpo_reg.set_value,
key="",
v_name="",
v_data=1,
v_type="REG_MULTI_SZ",
)
def test_set_value_invalid_reg_dword():
pytest.raises(
SaltInvocationError, lgpo_reg.set_value, key="", v_name="", v_data="string"
)
def test_disable_value(reg_pol):
key = "SOFTWARE\\MyKey1"
# Test that the command completed successfully
result = lgpo_reg.disable_value(key=key, v_name="MyValue1")
assert result is True
# Test that the value was actually set in Registry.pol
expected = {
"**del.MyValue1": {"data": " ", "type": "REG_SZ"},
"**del.MyValue2": {"data": " ", "type": "REG_SZ"},
}
result = lgpo_reg.get_key(key=key)
assert result == expected
# Test that the registry value has been removed
result = salt.utils.win_reg.value_exists(hive="HKLM", key=key, vname="MyValue1")
assert result is False
def test_disable_value_no_change(reg_pol):
expected = {
"MyValue1": {"data": "squidward", "type": "REG_SZ"},
"**del.MyValue2": {"data": " ", "type": "REG_SZ"},
}
key = "SOFTWARE\\MyKey1"
lgpo_reg.disable_value(key=key, v_name="MyValue2")
result = lgpo_reg.get_key(key=key)
assert result == expected
def test_disable_value_invalid_policy_class():
pytest.raises(
SaltInvocationError,
lgpo_reg.disable_value,
key="",
v_name="",
policy_class="Invalid",
)
def test_delete_value_existing(reg_pol):
key = "SOFTWARE\\MyKey1"
# Test that the command completes successfully
result = lgpo_reg.delete_value(key=key, v_name="MyValue1")
assert result is True
# Test that the value is actually removed from Registry.pol
expected = {
"**del.MyValue2": {
"data": " ",
"type": "REG_SZ",
},
}
result = lgpo_reg.get_key(key=key)
assert result == expected
# Test that the registry entry has been removed
result = salt.utils.win_reg.value_exists(hive="HKLM", key=key, vname="MyValue2")
assert result is False
def test_delete_value_no_change(empty_reg_pol):
expected = {}
key = "SOFTWARE\\MyKey1"
lgpo_reg.delete_value(key=key, v_name="MyValue2")
result = lgpo_reg.get_key(key=key)
assert result == expected
def test_delete_value_invalid_policy_class():
pytest.raises(
SaltInvocationError,
lgpo_reg.delete_value,
key="",
v_name="",
policy_class="Invalid",
)