mirror of
https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api.git
synced 2024-12-01 19:06:45 +00:00
More system tests
Co-authored-by: Detlaff <dettlaff@riseup.net>
This commit is contained in:
parent
e3354c73ef
commit
eb21b65bbc
|
@ -2,6 +2,7 @@
|
||||||
# pylint: disable=unused-argument
|
# pylint: disable=unused-argument
|
||||||
# pylint: disable=missing-function-docstring
|
# pylint: disable=missing-function-docstring
|
||||||
import json
|
import json
|
||||||
|
import os
|
||||||
import pytest
|
import pytest
|
||||||
import datetime
|
import datetime
|
||||||
|
|
||||||
|
@ -134,7 +135,9 @@ info {
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
def test_graphql_wrong_auth(wrong_auth_client):
|
def test_graphql_get_python_version_wrong_auth(
|
||||||
|
wrong_auth_client, mock_subprocess_check_output
|
||||||
|
):
|
||||||
"""Test wrong auth"""
|
"""Test wrong auth"""
|
||||||
response = wrong_auth_client.get(
|
response = wrong_auth_client.get(
|
||||||
"/graphql",
|
"/graphql",
|
||||||
|
@ -146,6 +149,62 @@ def test_graphql_wrong_auth(wrong_auth_client):
|
||||||
assert response.json.get("data") is None
|
assert response.json.get("data") is None
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_get_python_version(authorized_client, mock_subprocess_check_output):
|
||||||
|
"""Test get python version"""
|
||||||
|
response = authorized_client.get(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": generate_system_query([API_PYTHON_VERSION_INFO]),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is not None
|
||||||
|
assert response.json["data"]["system"]["info"]["pythonVersion"] == "Testing Linux"
|
||||||
|
assert mock_subprocess_check_output.call_count == 1
|
||||||
|
assert mock_subprocess_check_output.call_args[0][0] == ["python", "-V"]
|
||||||
|
|
||||||
|
|
||||||
|
API_SYSTEM_VERSION_INFO = """
|
||||||
|
info {
|
||||||
|
systemVersion
|
||||||
|
}
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_get_system_version_unauthorized(
|
||||||
|
wrong_auth_client, mock_subprocess_check_output
|
||||||
|
):
|
||||||
|
"""Test wrong auth"""
|
||||||
|
response = wrong_auth_client.get(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": generate_system_query([API_SYSTEM_VERSION_INFO]),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is None
|
||||||
|
|
||||||
|
assert mock_subprocess_check_output.call_count == 0
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_get_system_version(authorized_client, mock_subprocess_check_output):
|
||||||
|
"""Test get system version"""
|
||||||
|
response = authorized_client.get(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": generate_system_query([API_SYSTEM_VERSION_INFO]),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is not None
|
||||||
|
|
||||||
|
assert response.json["data"]["sytem"]["info"]["systemVersion"] == "Testing Linux"
|
||||||
|
assert mock_subprocess_check_output.call_count == 1
|
||||||
|
assert mock_subprocess_check_output.call_args[0][0] == ["uname", "-a"]
|
||||||
|
|
||||||
|
|
||||||
API_GET_DOMAIN_INFO = """
|
API_GET_DOMAIN_INFO = """
|
||||||
domainInfo {
|
domainInfo {
|
||||||
domain
|
domain
|
||||||
|
@ -730,9 +789,9 @@ def test_graphql_change_auto_upgrade_with_empty_input(authorized_client, turned_
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
API_REBUILD_SYSTEM_MUTATION = """
|
API_PULL_SYSTEM_CONFIGURATION_MUTATION = """
|
||||||
mutation rebuildSystem() {
|
mutation testPullSystemConfiguration() {
|
||||||
runSystemRebuild {
|
pullRepositoryChanges {
|
||||||
success
|
success
|
||||||
message
|
message
|
||||||
code
|
code
|
||||||
|
@ -741,125 +800,62 @@ mutation rebuildSystem() {
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
def test_graphql_system_rebuild_unauthorized(client, mock_subprocess_popen):
|
def test_graphql_pull_system_configuration_unauthorized(client, mock_subprocess_popen):
|
||||||
"""Test system rebuild without authorization"""
|
|
||||||
response = client.post(
|
response = client.post(
|
||||||
"/graphql",
|
"/graphql",
|
||||||
json={
|
json={
|
||||||
"query": API_REBUILD_SYSTEM_MUTATION,
|
"query": API_PULL_SYSTEM_CONFIGURATION_MUTATION,
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert response.status_code == 200
|
assert response.status_code == 200
|
||||||
assert response.json.get("data") is None
|
assert response.json.get("data") is None
|
||||||
assert mock_subprocess_popen.call_count == 0
|
assert mock_subprocess_popen.call_count == 0
|
||||||
|
|
||||||
|
|
||||||
def test_graphql_system_rebuild(authorized_client, mock_subprocess_popen):
|
def test_graphql_pull_system_configuration(
|
||||||
"""Test system rebuild"""
|
authorized_client, mock_subprocess_popen, mock_os_chdir
|
||||||
|
):
|
||||||
|
current_dir = os.getcwd()
|
||||||
response = authorized_client.post(
|
response = authorized_client.post(
|
||||||
"/graphql",
|
"/graphql",
|
||||||
json={
|
json={
|
||||||
"query": API_REBUILD_SYSTEM_MUTATION,
|
"query": API_PULL_SYSTEM_CONFIGURATION_MUTATION,
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
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 response.json["data"]["runSystemRebuild"]["success"] is True
|
assert response.json["data"]["pullRepositoryChanges"]["success"] is True
|
||||||
assert response.json["data"]["runSystemRebuild"]["message"] is not None
|
assert response.json["data"]["pullRepositoryChanges"]["message"] is not None
|
||||||
assert response.json["data"]["runSystemRebuild"]["code"] == 200
|
assert response.json["data"]["pullRepositoryChanges"]["code"] == 200
|
||||||
|
|
||||||
assert mock_subprocess_popen.call_count == 1
|
assert mock_subprocess_popen.call_count == 1
|
||||||
assert mock_subprocess_popen.call_args[0][0] == [
|
assert mock_subprocess_popen.call_args[0][0] == ["git", "pull"]
|
||||||
"systemctl",
|
assert mock_os_chdir.call_count == 2
|
||||||
"start",
|
assert mock_os_chdir.call_args_list[0][0][0] == "/etc/nixos"
|
||||||
"sp-nixos-rebuild.service",
|
assert mock_os_chdir.call_args_list[1][0][0] == current_dir
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
API_UPGRADE_SYSTEM_MUTATION = """
|
def test_graphql_pull_system_broken_repo(
|
||||||
mutation upgradeSystem() {
|
authorized_client, mock_broken_service, mock_os_chdir
|
||||||
runSystemUpgrade {
|
):
|
||||||
success
|
current_dir = os.getcwd()
|
||||||
message
|
|
||||||
code
|
|
||||||
}
|
|
||||||
}
|
|
||||||
"""
|
|
||||||
|
|
||||||
|
|
||||||
def test_graphql_system_upgrade_unauthorized(client, mock_subprocess_popen):
|
|
||||||
"""Test system upgrade without authorization"""
|
|
||||||
response = client.post(
|
|
||||||
"/graphql",
|
|
||||||
json={
|
|
||||||
"query": API_UPGRADE_SYSTEM_MUTATION,
|
|
||||||
},
|
|
||||||
)
|
|
||||||
assert response.status_code == 200
|
|
||||||
assert response.json.get("data") is None
|
|
||||||
assert mock_subprocess_popen.call_count == 0
|
|
||||||
|
|
||||||
|
|
||||||
def test_graphql_system_upgrade(authorized_client, mock_subprocess_popen):
|
|
||||||
"""Test system upgrade"""
|
|
||||||
response = authorized_client.post(
|
response = authorized_client.post(
|
||||||
"/graphql",
|
"/graphql",
|
||||||
json={
|
json={
|
||||||
"query": API_UPGRADE_SYSTEM_MUTATION,
|
"query": API_PULL_SYSTEM_CONFIGURATION_MUTATION,
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
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 response.json["data"]["runSystemUpgrade"]["success"] is True
|
assert response.json["data"]["pullRepositoryChanges"]["success"] is False
|
||||||
assert response.json["data"]["runSystemUpgrade"]["message"] is not None
|
assert response.json["data"]["pullRepositoryChanges"]["message"] is not None
|
||||||
assert response.json["data"]["runSystemUpgrade"]["code"] == 200
|
assert response.json["data"]["pullRepositoryChanges"]["code"] == 500
|
||||||
assert mock_subprocess_popen.call_count == 1
|
|
||||||
assert mock_subprocess_popen.call_args[0][0] == [
|
|
||||||
"systemctl",
|
|
||||||
"start",
|
|
||||||
"sp-nixos-upgrade.service",
|
|
||||||
]
|
|
||||||
|
|
||||||
|
assert mock_broken_service.call_count == 1
|
||||||
API_ROLLBACK_SYSTEM_MUTATION = """
|
assert mock_os_chdir.call_count == 2
|
||||||
mutation rollbackSystem() {
|
assert mock_os_chdir.call_args_list[0][0][0] == "/etc/nixos"
|
||||||
runSystemRollback {
|
assert mock_os_chdir.call_args_list[1][0][0] == current_dir
|
||||||
success
|
|
||||||
message
|
|
||||||
code
|
|
||||||
}
|
|
||||||
}
|
|
||||||
"""
|
|
||||||
|
|
||||||
|
|
||||||
def test_graphql_system_rollback_unauthorized(client, mock_subprocess_popen):
|
|
||||||
"""Test system rollback without authorization"""
|
|
||||||
response = client.post(
|
|
||||||
"/graphql",
|
|
||||||
json={
|
|
||||||
"query": API_ROLLBACK_SYSTEM_MUTATION,
|
|
||||||
},
|
|
||||||
)
|
|
||||||
assert response.status_code == 200
|
|
||||||
assert response.json.get("data") is None
|
|
||||||
assert mock_subprocess_popen.call_count == 0
|
|
||||||
|
|
||||||
|
|
||||||
def test_graphql_system_rollback(authorized_client, mock_subprocess_popen):
|
|
||||||
"""Test system rollback"""
|
|
||||||
response = authorized_client.post(
|
|
||||||
"/graphql",
|
|
||||||
json={
|
|
||||||
"query": API_ROLLBACK_SYSTEM_MUTATION,
|
|
||||||
},
|
|
||||||
)
|
|
||||||
assert response.status_code == 200
|
|
||||||
assert response.json.get("data") is not None
|
|
||||||
assert response.json["data"]["runSystemRollback"]["success"] is True
|
|
||||||
assert response.json["data"]["runSystemRollback"]["message"] is not None
|
|
||||||
assert response.json["data"]["runSystemRollback"]["code"] == 200
|
|
||||||
assert mock_subprocess_popen.call_count == 1
|
|
||||||
assert mock_subprocess_popen.call_args[0][0] == [
|
|
||||||
"systemctl",
|
|
||||||
"start",
|
|
||||||
"sp-nixos-rollback.service",
|
|
||||||
]
|
|
||||||
|
|
231
tests/test_graphql/test_system_nixos_tasks.py
Normal file
231
tests/test_graphql/test_system_nixos_tasks.py
Normal file
|
@ -0,0 +1,231 @@
|
||||||
|
# pylint: disable=redefined-outer-name
|
||||||
|
# pylint: disable=unused-argument
|
||||||
|
# pylint: disable=missing-function-docstring
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def domain_file(mocker, datadir):
|
||||||
|
mocker.patch("selfprivacy_api.utils.DOMAIN_FILE", datadir / "domain")
|
||||||
|
return datadir
|
||||||
|
|
||||||
|
|
||||||
|
class ProcessMock:
|
||||||
|
"""Mock subprocess.Popen"""
|
||||||
|
|
||||||
|
def __init__(self, args, **kwargs):
|
||||||
|
self.args = args
|
||||||
|
self.kwargs = kwargs
|
||||||
|
|
||||||
|
def communicate(): # pylint: disable=no-method-argument
|
||||||
|
return (b"", None)
|
||||||
|
|
||||||
|
returncode = 0
|
||||||
|
|
||||||
|
|
||||||
|
class BrokenServiceMock(ProcessMock):
|
||||||
|
"""Mock subprocess.Popen for broken service"""
|
||||||
|
|
||||||
|
def communicate(): # pylint: disable=no-method-argument
|
||||||
|
return (b"Testing error", None)
|
||||||
|
|
||||||
|
returncode = 3
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def mock_subprocess_popen(mocker):
|
||||||
|
mock = mocker.patch("subprocess.Popen", autospec=True, return_value=ProcessMock)
|
||||||
|
return mock
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def mock_os_chdir(mocker):
|
||||||
|
mock = mocker.patch("os.chdir", autospec=True)
|
||||||
|
return mock
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def mock_subprocess_check_output(mocker):
|
||||||
|
mock = mocker.patch(
|
||||||
|
"subprocess.check_output", autospec=True, return_value=b"Testing Linux"
|
||||||
|
)
|
||||||
|
return mock
|
||||||
|
|
||||||
|
|
||||||
|
API_REBUILD_SYSTEM_MUTATION = """
|
||||||
|
mutation rebuildSystem() {
|
||||||
|
runSystemRebuild {
|
||||||
|
success
|
||||||
|
message
|
||||||
|
code
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_system_rebuild_unauthorized(client, mock_subprocess_popen):
|
||||||
|
"""Test system rebuild without authorization"""
|
||||||
|
response = client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_REBUILD_SYSTEM_MUTATION,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is None
|
||||||
|
assert mock_subprocess_popen.call_count == 0
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_system_rebuild(authorized_client, mock_subprocess_popen):
|
||||||
|
"""Test system rebuild"""
|
||||||
|
response = authorized_client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_REBUILD_SYSTEM_MUTATION,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is not None
|
||||||
|
assert response.json["data"]["runSystemRebuild"]["success"] is True
|
||||||
|
assert response.json["data"]["runSystemRebuild"]["message"] is not None
|
||||||
|
assert response.json["data"]["runSystemRebuild"]["code"] == 200
|
||||||
|
assert mock_subprocess_popen.call_count == 1
|
||||||
|
assert mock_subprocess_popen.call_args[0][0] == [
|
||||||
|
"systemctl",
|
||||||
|
"start",
|
||||||
|
"sp-nixos-rebuild.service",
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
API_UPGRADE_SYSTEM_MUTATION = """
|
||||||
|
mutation upgradeSystem() {
|
||||||
|
runSystemUpgrade {
|
||||||
|
success
|
||||||
|
message
|
||||||
|
code
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_system_upgrade_unauthorized(client, mock_subprocess_popen):
|
||||||
|
"""Test system upgrade without authorization"""
|
||||||
|
response = client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_UPGRADE_SYSTEM_MUTATION,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is None
|
||||||
|
assert mock_subprocess_popen.call_count == 0
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_system_upgrade(authorized_client, mock_subprocess_popen):
|
||||||
|
"""Test system upgrade"""
|
||||||
|
response = authorized_client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_UPGRADE_SYSTEM_MUTATION,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is not None
|
||||||
|
assert response.json["data"]["runSystemUpgrade"]["success"] is True
|
||||||
|
assert response.json["data"]["runSystemUpgrade"]["message"] is not None
|
||||||
|
assert response.json["data"]["runSystemUpgrade"]["code"] == 200
|
||||||
|
assert mock_subprocess_popen.call_count == 1
|
||||||
|
assert mock_subprocess_popen.call_args[0][0] == [
|
||||||
|
"systemctl",
|
||||||
|
"start",
|
||||||
|
"sp-nixos-upgrade.service",
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
API_ROLLBACK_SYSTEM_MUTATION = """
|
||||||
|
mutation rollbackSystem() {
|
||||||
|
runSystemRollback {
|
||||||
|
success
|
||||||
|
message
|
||||||
|
code
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_system_rollback_unauthorized(client, mock_subprocess_popen):
|
||||||
|
"""Test system rollback without authorization"""
|
||||||
|
response = client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_ROLLBACK_SYSTEM_MUTATION,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is None
|
||||||
|
assert mock_subprocess_popen.call_count == 0
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_system_rollback(authorized_client, mock_subprocess_popen):
|
||||||
|
"""Test system rollback"""
|
||||||
|
response = authorized_client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_ROLLBACK_SYSTEM_MUTATION,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is not None
|
||||||
|
assert response.json["data"]["runSystemRollback"]["success"] is True
|
||||||
|
assert response.json["data"]["runSystemRollback"]["message"] is not None
|
||||||
|
assert response.json["data"]["runSystemRollback"]["code"] == 200
|
||||||
|
assert mock_subprocess_popen.call_count == 1
|
||||||
|
assert mock_subprocess_popen.call_args[0][0] == [
|
||||||
|
"systemctl",
|
||||||
|
"start",
|
||||||
|
"sp-nixos-rollback.service",
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
API_REBOOT_SYSTEM_MUTATION = """
|
||||||
|
mutation system {
|
||||||
|
rebootSystem {
|
||||||
|
success
|
||||||
|
message
|
||||||
|
code
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_reboot_system_unauthorized(client, mock_subprocess_popen):
|
||||||
|
response = client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_REBOOT_SYSTEM_MUTATION,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is None
|
||||||
|
|
||||||
|
assert mock_subprocess_popen.call_count == 0
|
||||||
|
|
||||||
|
|
||||||
|
def test_graphql_reboot_system(authorized_client, mock_subprocess_popen):
|
||||||
|
response = authorized_client.post(
|
||||||
|
"/graphql",
|
||||||
|
json={
|
||||||
|
"query": API_REBOOT_SYSTEM_MUTATION,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
assert response.status_code == 200
|
||||||
|
assert response.json.get("data") is not None
|
||||||
|
|
||||||
|
assert response.json["data"]["rebootSystem"]["success"] is True
|
||||||
|
assert response.json["data"]["rebootSystem"]["message"] is not None
|
||||||
|
assert response.json["data"]["rebootSystem"]["code"] == 200
|
||||||
|
|
||||||
|
assert mock_subprocess_popen.call_count == 1
|
||||||
|
assert mock_subprocess_popen.call_args[0][0] == ["reboot"]
|
Loading…
Reference in a new issue