2022-01-10 20:35:00 +00:00
|
|
|
# pylint: disable=redefined-outer-name
|
|
|
|
# pylint: disable=unused-argument
|
2021-11-29 19:16:08 +00:00
|
|
|
import json
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
|
|
|
|
def read_json(file_path):
|
2022-01-10 20:35:00 +00:00
|
|
|
with open(file_path, "r", encoding="utf-8") as file:
|
|
|
|
return json.load(file)
|
2021-11-29 19:16:08 +00:00
|
|
|
|
|
|
|
|
2022-01-10 20:35:00 +00:00
|
|
|
## FIXTURES ###################################################
|
2021-11-29 19:16:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def ssh_off(mocker, datadir):
|
|
|
|
mocker.patch("selfprivacy_api.utils.USERDATA_FILE", new=datadir / "turned_off.json")
|
2022-01-10 20:35:00 +00:00
|
|
|
assert not read_json(datadir / "turned_off.json")["ssh"]["enable"]
|
|
|
|
assert read_json(datadir / "turned_off.json")["ssh"]["passwordAuthentication"]
|
2021-11-29 19:16:08 +00:00
|
|
|
return datadir
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def ssh_on(mocker, datadir):
|
|
|
|
mocker.patch("selfprivacy_api.utils.USERDATA_FILE", new=datadir / "turned_on.json")
|
2022-01-10 20:35:00 +00:00
|
|
|
assert read_json(datadir / "turned_off.json")["ssh"]["passwordAuthentication"]
|
|
|
|
assert read_json(datadir / "turned_on.json")["ssh"]["enable"]
|
2021-11-29 19:16:08 +00:00
|
|
|
return datadir
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def all_off(mocker, datadir):
|
|
|
|
mocker.patch("selfprivacy_api.utils.USERDATA_FILE", new=datadir / "all_off.json")
|
2022-01-10 20:35:00 +00:00
|
|
|
assert not read_json(datadir / "all_off.json")["ssh"]["passwordAuthentication"]
|
|
|
|
assert not read_json(datadir / "all_off.json")["ssh"]["enable"]
|
2021-11-29 19:16:08 +00:00
|
|
|
return datadir
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def undefined_settings(mocker, datadir):
|
|
|
|
mocker.patch("selfprivacy_api.utils.USERDATA_FILE", new=datadir / "undefined.json")
|
|
|
|
assert "ssh" not in read_json(datadir / "undefined.json")
|
|
|
|
return datadir
|
|
|
|
|
|
|
|
|
2022-01-10 20:35:00 +00:00
|
|
|
@pytest.fixture
|
|
|
|
def undefined_values(mocker, datadir):
|
|
|
|
mocker.patch(
|
|
|
|
"selfprivacy_api.utils.USERDATA_FILE", new=datadir / "undefined_values.json"
|
|
|
|
)
|
|
|
|
assert "ssh" in read_json(datadir / "undefined_values.json")
|
|
|
|
assert "enable" not in read_json(datadir / "undefined_values.json")["ssh"]
|
|
|
|
assert (
|
|
|
|
"passwordAuthentication"
|
|
|
|
not in read_json(datadir / "undefined_values.json")["ssh"]
|
|
|
|
)
|
|
|
|
return datadir
|
|
|
|
|
|
|
|
|
2021-11-29 19:16:08 +00:00
|
|
|
@pytest.fixture
|
|
|
|
def root_and_admin_have_keys(mocker, datadir):
|
|
|
|
mocker.patch(
|
|
|
|
"selfprivacy_api.utils.USERDATA_FILE",
|
|
|
|
new=datadir / "root_and_admin_have_keys.json",
|
|
|
|
)
|
2022-01-10 20:35:00 +00:00
|
|
|
assert read_json(datadir / "root_and_admin_have_keys.json")["ssh"]["enable"]
|
|
|
|
assert read_json(datadir / "root_and_admin_have_keys.json")["ssh"][
|
|
|
|
"passwordAuthentication"
|
|
|
|
]
|
2021-11-29 19:16:08 +00:00
|
|
|
assert read_json(datadir / "root_and_admin_have_keys.json")["ssh"]["rootKeys"] == [
|
|
|
|
"ssh-ed25519 KEY test@pc"
|
|
|
|
]
|
|
|
|
assert read_json(datadir / "root_and_admin_have_keys.json")["sshKeys"] == [
|
|
|
|
"ssh-rsa KEY test@pc"
|
|
|
|
]
|
|
|
|
return datadir
|
|
|
|
|
|
|
|
|
2022-01-10 20:35:00 +00:00
|
|
|
@pytest.fixture
|
|
|
|
def some_users(mocker, datadir):
|
|
|
|
mocker.patch("selfprivacy_api.utils.USERDATA_FILE", new=datadir / "some_users.json")
|
|
|
|
assert "users" in read_json(datadir / "some_users.json")
|
|
|
|
assert read_json(datadir / "some_users.json")["users"] == [
|
|
|
|
{
|
|
|
|
"username": "user1",
|
|
|
|
"hashedPassword": "HASHED_PASSWORD_1",
|
|
|
|
"sshKeys": ["ssh-rsa KEY user1@pc"],
|
|
|
|
},
|
|
|
|
{"username": "user2", "hashedPassword": "HASHED_PASSWORD_2", "sshKeys": []},
|
|
|
|
{"username": "user3", "hashedPassword": "HASHED_PASSWORD_3"},
|
|
|
|
]
|
|
|
|
return datadir
|
|
|
|
|
|
|
|
|
|
|
|
## /ssh/keys/{user} ######################################################
|
|
|
|
|
|
|
|
|
|
|
|
def test_add_key_on_undefined_users(authorized_client, undefined_settings):
|
|
|
|
response = authorized_client.post(
|
|
|
|
"/services/ssh/keys/user1", json={"public_key": "ssh-rsa KEY user4@pc"}
|
|
|
|
)
|
|
|
|
assert response.status_code == 404
|
|
|
|
|
|
|
|
|
|
|
|
def test_delete_key_when_undefined_users(authorized_client, undefined_settings):
|
|
|
|
response = authorized_client.delete(
|
|
|
|
"/services/ssh/keys/user1", json={"public_key": "ssh-rsa KEY user1@pc"}
|
|
|
|
)
|
|
|
|
assert response.status_code == 404
|