Reorganize tests

This commit is contained in:
inexcode 2022-08-20 22:48:44 +04:00
parent c92294350f
commit 07f4da2f23
58 changed files with 143 additions and 95 deletions

View file

@ -186,7 +186,9 @@ def resize_block_mock(mocker):
return mock return mock
def test_call_resize_from_block_device(lsblk_singular_mock, resize_block_mock, authorized_client): def test_call_resize_from_block_device(
lsblk_singular_mock, resize_block_mock, authorized_client
):
block_device = BlockDevice(json.loads(VOLUME_LSBLK_OUTPUT)["blockdevices"][0]) block_device = BlockDevice(json.loads(VOLUME_LSBLK_OUTPUT)["blockdevices"][0])
block_device.resize() block_device.resize()
assert resize_block_mock.call_count == 1 assert resize_block_mock.call_count == 1
@ -223,7 +225,9 @@ def test_get_stats_from_block_device(lsblk_singular_mock, authorized_client):
] ]
def test_mount_block_device(lsblk_singular_mock, only_root_in_userdata, authorized_client): def test_mount_block_device(
lsblk_singular_mock, only_root_in_userdata, authorized_client
):
block_device = BlockDevice(json.loads(SINGLE_LSBLK_OUTPUT)["blockdevices"][0]) block_device = BlockDevice(json.loads(SINGLE_LSBLK_OUTPUT)["blockdevices"][0])
result = block_device.mount() result = block_device.mount()
assert result is False assert result is False
@ -270,7 +274,9 @@ def test_mount_block_device_when_undefined(
) )
def test_unmount_block_device(lsblk_singular_mock, only_root_in_userdata, authorized_client): def test_unmount_block_device(
lsblk_singular_mock, only_root_in_userdata, authorized_client
):
block_device = BlockDevice(json.loads(SINGLE_LSBLK_OUTPUT)["blockdevices"][0]) block_device = BlockDevice(json.loads(SINGLE_LSBLK_OUTPUT)["blockdevices"][0])
result = block_device.unmount() result = block_device.unmount()
assert result is True assert result is True

View file

@ -124,6 +124,7 @@ def mock_dkim_key(mocker):
autospec=True, autospec=True,
return_value="I am a DKIM key", return_value="I am a DKIM key",
) )
return mock
API_PYTHON_VERSION_INFO = """ API_PYTHON_VERSION_INFO = """
@ -137,7 +138,7 @@ def test_graphql_get_python_version_wrong_auth(
wrong_auth_client, mock_subprocess_check_output wrong_auth_client, mock_subprocess_check_output
): ):
"""Test wrong auth""" """Test wrong auth"""
response = wrong_auth_client.get( response = wrong_auth_client.post(
"/graphql", "/graphql",
json={ json={
"query": generate_system_query([API_PYTHON_VERSION_INFO]), "query": generate_system_query([API_PYTHON_VERSION_INFO]),
@ -149,7 +150,7 @@ def test_graphql_get_python_version_wrong_auth(
def test_graphql_get_python_version(authorized_client, mock_subprocess_check_output): def test_graphql_get_python_version(authorized_client, mock_subprocess_check_output):
"""Test get python version""" """Test get python version"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": generate_system_query([API_PYTHON_VERSION_INFO]), "query": generate_system_query([API_PYTHON_VERSION_INFO]),
@ -173,7 +174,7 @@ def test_graphql_get_system_version_unauthorized(
wrong_auth_client, mock_subprocess_check_output wrong_auth_client, mock_subprocess_check_output
): ):
"""Test wrong auth""" """Test wrong auth"""
response = wrong_auth_client.get( response = wrong_auth_client.post(
"/graphql", "/graphql",
json={ json={
"query": generate_system_query([API_SYSTEM_VERSION_INFO]), "query": generate_system_query([API_SYSTEM_VERSION_INFO]),
@ -188,7 +189,7 @@ def test_graphql_get_system_version_unauthorized(
def test_graphql_get_system_version(authorized_client, mock_subprocess_check_output): def test_graphql_get_system_version(authorized_client, mock_subprocess_check_output):
"""Test get system version""" """Test get system version"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": generate_system_query([API_SYSTEM_VERSION_INFO]), "query": generate_system_query([API_SYSTEM_VERSION_INFO]),
@ -209,7 +210,7 @@ domainInfo {
hostname hostname
provider provider
requiredDnsRecords { requiredDnsRecords {
type recordType
name name
content content
ttl ttl
@ -219,14 +220,14 @@ domainInfo {
""" """
def dns_record(type="A", name="test.tld", content=None, ttl=3600, priority=None): def dns_record(record_type="A", name="test-domain.tld", content=None, ttl=3600, priority=None):
if content is None: if content is None:
if type == "A": if record_type == "A":
content = "157.90.247.192" content = "157.90.247.192"
elif type == "AAAA": elif record_type == "AAAA":
content = "fe80::9400:ff:fef1:34ae" content = "fe80::9400:ff:fef1:34ae"
return { return {
"type": type, "recordType": record_type,
"name": name, "name": name,
"content": content, "content": content,
"ttl": ttl, "ttl": ttl,
@ -237,7 +238,7 @@ def dns_record(type="A", name="test.tld", content=None, ttl=3600, priority=None)
def is_dns_record_in_array(records, dns_record) -> bool: def is_dns_record_in_array(records, dns_record) -> bool:
for record in records: for record in records:
if ( if (
record["type"] == dns_record["type"] record["recordType"] == dns_record["recordType"]
and record["name"] == dns_record["name"] and record["name"] == dns_record["name"]
and record["content"] == dns_record["content"] and record["content"] == dns_record["content"]
and record["ttl"] == dns_record["ttl"] and record["ttl"] == dns_record["ttl"]
@ -248,10 +249,10 @@ def is_dns_record_in_array(records, dns_record) -> bool:
def test_graphql_get_domain( def test_graphql_get_domain(
authorized_client, domain_file, mock_get_ip4, mock_get_ip6, turned_on authorized_client, domain_file, mock_get_ip4, mock_get_ip6, turned_on, mock_dkim_key
): ):
"""Test get domain""" """Test get domain"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": generate_system_query([API_GET_DOMAIN_INFO]), "query": generate_system_query([API_GET_DOMAIN_INFO]),
@ -263,53 +264,53 @@ def test_graphql_get_domain(
assert ( assert (
response.json()["data"]["system"]["domainInfo"]["hostname"] == "test-instance" response.json()["data"]["system"]["domainInfo"]["hostname"] == "test-instance"
) )
assert response.json()["data"]["system"]["domainInfo"]["provider"] == "HETZNER" assert response.json()["data"]["system"]["domainInfo"]["provider"] == "CLOUDFLARE"
dns_records = response.json()["data"]["system"]["domainInfo"]["requiredDnsRecords"] dns_records = response.json()["data"]["system"]["domainInfo"]["requiredDnsRecords"]
assert is_dns_record_in_array(dns_records, dns_record()) assert is_dns_record_in_array(dns_records, dns_record())
assert is_dns_record_in_array(dns_records, dns_record(type="AAAA")) assert is_dns_record_in_array(dns_records, dns_record(record_type="AAAA"))
assert is_dns_record_in_array(dns_records, dns_record(name="api.test.tld")) assert is_dns_record_in_array(dns_records, dns_record(name="api"))
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_record(name="api.test.tld", type="AAAA") dns_records, dns_record(name="api", record_type="AAAA")
) )
assert is_dns_record_in_array(dns_records, dns_record(name="cloud.test.tld")) assert is_dns_record_in_array(dns_records, dns_record(name="cloud"))
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_record(name="cloud.test.tld", type="AAAA") dns_records, dns_record(name="cloud", record_type="AAAA")
) )
assert is_dns_record_in_array(dns_records, dns_record(name="git.test.tld")) assert is_dns_record_in_array(dns_records, dns_record(name="git"))
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_record(name="git.test.tld", type="AAAA") dns_records, dns_record(name="git", record_type="AAAA")
) )
assert is_dns_record_in_array(dns_records, dns_record(name="meet.test.tld")) assert is_dns_record_in_array(dns_records, dns_record(name="meet"))
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_record(name="meet.test.tld", type="AAAA") dns_records, dns_record(name="meet", record_type="AAAA")
) )
assert is_dns_record_in_array(dns_records, dns_record(name="password.test.tld")) assert is_dns_record_in_array(dns_records, dns_record(name="password"))
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_record(name="password.test.tld", type="AAAA") dns_records, dns_record(name="password", record_type="AAAA")
) )
assert is_dns_record_in_array(dns_records, dns_record(name="social.test.tld")) assert is_dns_record_in_array(dns_records, dns_record(name="social"))
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_record(name="social.test.tld", type="AAAA") dns_records, dns_record(name="social", record_type="AAAA")
) )
assert is_dns_record_in_array(dns_records, dns_record(name="vpn.test.tld")) assert is_dns_record_in_array(dns_records, dns_record(name="vpn"))
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_record(name="vpn.test.tld", type="AAAA") dns_records, dns_record(name="vpn", record_type="AAAA")
) )
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_records,
dns_record(name="test.tld", type="MX", content="test.tld", priority=10), dns_record(name="test-domain.tld", record_type="MX", content="test-domain.tld", priority=10),
) )
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_records,
dns_record( dns_record(
name="_dmarc.test.tld", type="TXT", content="v=DMARC1; p=none", ttl=18000 name="_dmarc", record_type="TXT", content="v=DMARC1; p=none", ttl=18000
), ),
) )
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_records,
dns_record( dns_record(
name="test.tld", name="test-domain.tld",
type="TXT", record_type="TXT",
content="v=spf1 a mx ip4:157.90.247.192 -all", content="v=spf1 a mx ip4:157.90.247.192 -all",
ttl=18000, ttl=18000,
), ),
@ -317,8 +318,8 @@ def test_graphql_get_domain(
assert is_dns_record_in_array( assert is_dns_record_in_array(
dns_records, dns_records,
dns_record( dns_record(
name="selector._domainkey.test.tld", name="selector._domainkey",
type="TXT", record_type="TXT",
content="I am a DKIM key", content="I am a DKIM key",
ttl=18000, ttl=18000,
), ),
@ -334,7 +335,7 @@ settings {
def test_graphql_get_timezone_unauthorized(client, turned_on): def test_graphql_get_timezone_unauthorized(client, turned_on):
"""Test get timezone without auth""" """Test get timezone without auth"""
response = client.get( response = client.post(
"/graphql", "/graphql",
json={ json={
"query": generate_system_query([API_GET_TIMEZONE]), "query": generate_system_query([API_GET_TIMEZONE]),
@ -346,7 +347,7 @@ def test_graphql_get_timezone_unauthorized(client, turned_on):
def test_graphql_get_timezone(authorized_client, turned_on): def test_graphql_get_timezone(authorized_client, turned_on):
"""Test get timezone""" """Test get timezone"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": generate_system_query([API_GET_TIMEZONE]), "query": generate_system_query([API_GET_TIMEZONE]),
@ -359,7 +360,7 @@ def test_graphql_get_timezone(authorized_client, turned_on):
def test_graphql_get_timezone_on_undefined(authorized_client, undefined_config): def test_graphql_get_timezone_on_undefined(authorized_client, undefined_config):
"""Test get timezone when none is defined in config""" """Test get timezone when none is defined in config"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": generate_system_query([API_GET_TIMEZONE]), "query": generate_system_query([API_GET_TIMEZONE]),
@ -484,7 +485,7 @@ def test_graphql_change_timezone_with_invalid_timezone(authorized_client, turned
API_GET_AUTO_UPGRADE_SETTINGS_QUERY = """ API_GET_AUTO_UPGRADE_SETTINGS_QUERY = """
settings { settings {
autoUpgrade { autoUpgrade {
enableAutoUpgrade enable
allowReboot allowReboot
} }
} }
@ -493,10 +494,10 @@ settings {
def test_graphql_get_auto_upgrade_unauthorized(client, turned_on): def test_graphql_get_auto_upgrade_unauthorized(client, turned_on):
"""Test get auto upgrade settings without auth""" """Test get auto upgrade settings without auth"""
response = client.get( response = client.post(
"/graphql", "/graphql",
json={ json={
"query": API_GET_AUTO_UPGRADE_SETTINGS_QUERY, "query": generate_system_query([API_GET_AUTO_UPGRADE_SETTINGS_QUERY]),
}, },
) )
assert response.status_code == 200 assert response.status_code == 200
@ -505,66 +506,66 @@ def test_graphql_get_auto_upgrade_unauthorized(client, turned_on):
def test_graphql_get_auto_upgrade(authorized_client, turned_on): def test_graphql_get_auto_upgrade(authorized_client, turned_on):
"""Test get auto upgrade settings""" """Test get auto upgrade settings"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": API_GET_AUTO_UPGRADE_SETTINGS_QUERY, "query": generate_system_query([API_GET_AUTO_UPGRADE_SETTINGS_QUERY]),
}, },
) )
assert response.status_code == 200 assert response.status_code == 200
assert response.json().get("data") is not None assert response.json().get("data") is not None
assert ( assert (
response.json()["data"]["settings"]["autoUpgrade"]["enableAutoUpgrade"] is True response.json()["data"]["system"]["settings"]["autoUpgrade"]["enable"] is True
) )
assert response.json()["data"]["settings"]["autoUpgrade"]["allowReboot"] is True assert response.json()["data"]["system"]["settings"]["autoUpgrade"]["allowReboot"] is True
def test_graphql_get_auto_upgrade_on_undefined(authorized_client, undefined_config): def test_graphql_get_auto_upgrade_on_undefined(authorized_client, undefined_config):
"""Test get auto upgrade settings when none is defined in config""" """Test get auto upgrade settings when none is defined in config"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": API_GET_AUTO_UPGRADE_SETTINGS_QUERY, "query": generate_system_query([API_GET_AUTO_UPGRADE_SETTINGS_QUERY]),
}, },
) )
assert response.status_code == 200 assert response.status_code == 200
assert response.json().get("data") is not None assert response.json().get("data") is not None
assert ( assert (
response.json()["data"]["settings"]["autoUpgrade"]["enableAutoUpgrade"] is True response.json()["data"]["system"]["settings"]["autoUpgrade"]["enable"] is True
) )
assert response.json()["data"]["settings"]["autoUpgrade"]["allowReboot"] is False assert response.json()["data"]["system"]["settings"]["autoUpgrade"]["allowReboot"] is False
def test_graphql_get_auto_upgrade_without_vlaues(authorized_client, no_values): def test_graphql_get_auto_upgrade_without_vlaues(authorized_client, no_values):
"""Test get auto upgrade settings without values""" """Test get auto upgrade settings without values"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": API_GET_AUTO_UPGRADE_SETTINGS_QUERY, "query": generate_system_query([API_GET_AUTO_UPGRADE_SETTINGS_QUERY]),
}, },
) )
assert response.status_code == 200 assert response.status_code == 200
assert response.json().get("data") is not None assert response.json().get("data") is not None
assert ( assert (
response.json()["data"]["settings"]["autoUpgrade"]["enableAutoUpgrade"] is True response.json()["data"]["system"]["settings"]["autoUpgrade"]["enable"] is True
) )
assert response.json()["data"]["settings"]["autoUpgrade"]["allowReboot"] is False assert response.json()["data"]["system"]["settings"]["autoUpgrade"]["allowReboot"] is False
def test_graphql_get_auto_upgrade_turned_off(authorized_client, turned_off): def test_graphql_get_auto_upgrade_turned_off(authorized_client, turned_off):
"""Test get auto upgrade settings when turned off""" """Test get auto upgrade settings when turned off"""
response = authorized_client.get( response = authorized_client.post(
"/graphql", "/graphql",
json={ json={
"query": API_GET_AUTO_UPGRADE_SETTINGS_QUERY, "query": generate_system_query([API_GET_AUTO_UPGRADE_SETTINGS_QUERY]),
}, },
) )
assert response.status_code == 200 assert response.status_code == 200
assert response.json().get("data") is not None assert response.json().get("data") is not None
assert ( assert (
response.json()["data"]["settings"]["autoUpgrade"]["enableAutoUpgrade"] is False response.json()["data"]["system"]["settings"]["autoUpgrade"]["enable"] is False
) )
assert response.json()["data"]["settings"]["autoUpgrade"]["allowReboot"] is False assert response.json()["data"]["system"]["settings"]["autoUpgrade"]["allowReboot"] is False
API_CHANGE_AUTO_UPGRADE_SETTINGS = """ API_CHANGE_AUTO_UPGRADE_SETTINGS = """
@ -805,7 +806,7 @@ def test_graphql_change_auto_upgrade_with_empty_input(authorized_client, turned_
API_PULL_SYSTEM_CONFIGURATION_MUTATION = """ API_PULL_SYSTEM_CONFIGURATION_MUTATION = """
mutation testPullSystemConfiguration() { mutation testPullSystemConfiguration {
pullRepositoryChanges { pullRepositoryChanges {
success success
message message

View file

@ -33,7 +33,7 @@
}, },
"username": "tester", "username": "tester",
"gitea": { "gitea": {
"enable": false "enable": true
}, },
"ocserv": { "ocserv": {
"enable": true "enable": true

View file

@ -30,3 +30,21 @@ def test_jobs(authorized_client, jobs_file, shared_datadir):
) )
assert jobs.get_jobs() == [test_job] assert jobs.get_jobs() == [test_job]
@pytest.fixture
def mock_subprocess_run(mocker):
mock = mocker.patch("subprocess.run", autospec=True)
return mock
@pytest.fixture
def mock_shutil_move(mocker):
mock = mocker.patch("shutil.move", autospec=True)
return mock
@pytest.fixture
def mock_shutil_chown(mocker):
mock = mocker.patch("shutil.chown", autospec=True)
return mock

View file

@ -0,0 +1 @@
{}

View file

@ -0,0 +1,14 @@
{
"tokens": [
{
"token": "TEST_TOKEN",
"name": "test_token",
"date": "2022-01-14 08:31:10.789314"
},
{
"token": "TEST_TOKEN2",
"name": "test_token2",
"date": "2022-01-14 08:31:10.789314"
}
]
}

View file

@ -12,68 +12,78 @@ def call_args_asserts(mocked_object):
assert mocked_object.call_count == 7 assert mocked_object.call_count == 7
assert mocked_object.call_args_list[0][0][0] == [ assert mocked_object.call_args_list[0][0][0] == [
"systemctl", "systemctl",
"status", "show",
"dovecot2.service", "dovecot2.service",
] ]
assert mocked_object.call_args_list[1][0][0] == [ assert mocked_object.call_args_list[1][0][0] == [
"systemctl", "systemctl",
"status", "show",
"postfix.service", "postfix.service",
] ]
assert mocked_object.call_args_list[2][0][0] == [ assert mocked_object.call_args_list[2][0][0] == [
"systemctl", "systemctl",
"status", "show",
"vaultwarden.service", "vaultwarden.service",
] ]
assert mocked_object.call_args_list[3][0][0] == [ assert mocked_object.call_args_list[3][0][0] == [
"systemctl", "systemctl",
"status", "show",
"gitea.service", "gitea.service",
] ]
assert mocked_object.call_args_list[4][0][0] == [ assert mocked_object.call_args_list[4][0][0] == [
"systemctl", "systemctl",
"status", "show",
"phpfpm-nextcloud.service", "phpfpm-nextcloud.service",
] ]
assert mocked_object.call_args_list[5][0][0] == [ assert mocked_object.call_args_list[5][0][0] == [
"systemctl", "systemctl",
"status", "show",
"ocserv.service", "ocserv.service",
] ]
assert mocked_object.call_args_list[6][0][0] == [ assert mocked_object.call_args_list[6][0][0] == [
"systemctl", "systemctl",
"status", "show",
"pleroma.service", "pleroma.service",
] ]
class ProcessMock: SUCCESSFUL_STATUS = b"""
"""Mock subprocess.Popen""" Type=oneshot
ExitType=main
Restart=no
NotifyAccess=none
RestartUSec=100ms
LoadState=loaded
ActiveState=active
FreezerState=running
SubState=exited
"""
def __init__(self, args, **kwargs): FAILED_STATUS = b"""
self.args = args Type=oneshot
self.kwargs = kwargs ExitType=main
Restart=no
def communicate(): NotifyAccess=none
return (b"", None) RestartUSec=100ms
LoadState=loaded
returncode = 0 ActiveState=failed
FreezerState=running
SubState=exited
class BrokenServiceMock(ProcessMock): """
returncode = 3
@pytest.fixture @pytest.fixture
def mock_subproccess_popen(mocker): def mock_subproccess_popen(mocker):
mock = mocker.patch("subprocess.Popen", autospec=True, return_value=ProcessMock) mock = mocker.patch(
"subprocess.check_output", autospec=True, return_value=SUCCESSFUL_STATUS
)
return mock return mock
@pytest.fixture @pytest.fixture
def mock_broken_service(mocker): def mock_broken_service(mocker):
mock = mocker.patch( mock = mocker.patch(
"subprocess.Popen", autospec=True, return_value=BrokenServiceMock "subprocess.check_output", autospec=True, return_value=FAILED_STATUS
) )
return mock return mock
@ -116,13 +126,13 @@ def test_no_dkim_key(authorized_client, mock_broken_service):
response = authorized_client.get("/services/status") response = authorized_client.get("/services/status")
assert response.status_code == 200 assert response.status_code == 200
assert response.json() == { assert response.json() == {
"imap": 3, "imap": 1,
"smtp": 3, "smtp": 1,
"http": 0, "http": 0,
"bitwarden": 3, "bitwarden": 1,
"gitea": 3, "gitea": 1,
"nextcloud": 3, "nextcloud": 1,
"ocserv": 3, "ocserv": 1,
"pleroma": 3, "pleroma": 1,
} }
call_args_asserts(mock_broken_service) call_args_asserts(mock_broken_service)

View file

@ -2,12 +2,10 @@
# pylint: disable=unused-argument # pylint: disable=unused-argument
# pylint: disable=missing-function-docstring # pylint: disable=missing-function-docstring
import datetime import datetime
import json
import re
import pytest import pytest
from mnemonic import Mnemonic from mnemonic import Mnemonic
from .common import read_json, write_json from tests.common import read_json, write_json
TOKENS_FILE_CONTETS = { TOKENS_FILE_CONTETS = {