tests: simplify import_site tests (#29545)
This commit is contained in:
parent
c60ed8b5ee
commit
75e0b37880
|
@ -1,4 +1,5 @@
|
|||
import __builtin__
|
||||
import random
|
||||
import json
|
||||
|
||||
from django.core import management
|
||||
|
@ -6,6 +7,19 @@ import pytest
|
|||
|
||||
from django_rbac.utils import get_role_model
|
||||
|
||||
Role = get_role_model()
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def json_fixture(tmpdir):
|
||||
def f(content):
|
||||
name = str(random.getrandbits(64))
|
||||
outfile = tmpdir.join(name)
|
||||
with outfile.open('w') as f:
|
||||
f.write(json.dumps(content))
|
||||
return outfile.strpath
|
||||
return f
|
||||
|
||||
|
||||
def dummy_export_site(*args):
|
||||
return {'roles': [{'name': 'role1'}]}
|
||||
|
@ -30,22 +44,24 @@ def test_export_role_cmd_to_file(db, monkeypatch, tmpdir):
|
|||
assert json.loads(f.read()) == dummy_export_site()
|
||||
|
||||
|
||||
def test_import_site_cmd(db, tmpdir, monkeypatch):
|
||||
export_file = tmpdir.join('roles-export.json')
|
||||
with export_file.open('w'):
|
||||
export_file.write(json.dumps({'roles': []}))
|
||||
management.call_command('import_site', export_file.strpath)
|
||||
def test_import_site_cmd(db, monkeypatch, json_fixture):
|
||||
management.call_command('import_site', json_fixture({'roles': []}))
|
||||
|
||||
|
||||
def test_import_site_cmd_infos_on_stdout(db, tmpdir, monkeypatch, capsys):
|
||||
export_file = tmpdir.join('roles-export.json')
|
||||
with export_file.open('w'):
|
||||
export_file.write(json.dumps(
|
||||
{'roles': [{
|
||||
'uuid': 'dqfewrvesvews2532', 'slug': 'role-slug', 'name': 'role-name',
|
||||
'ou': None, 'service': None}]}))
|
||||
def test_import_site_cmd_infos_on_stdout(db, monkeypatch, capsys, json_fixture):
|
||||
content = {
|
||||
'roles': [
|
||||
{
|
||||
'uuid': 'dqfewrvesvews2532',
|
||||
'slug': 'role-slug',
|
||||
'name': 'role-name',
|
||||
'ou': None,
|
||||
'service': None
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
management.call_command('import_site', export_file.strpath)
|
||||
management.call_command('import_site', json_fixture(content))
|
||||
|
||||
out, err = capsys.readouterr()
|
||||
assert "Real run" in out
|
||||
|
@ -53,13 +69,7 @@ def test_import_site_cmd_infos_on_stdout(db, tmpdir, monkeypatch, capsys):
|
|||
assert "0 roles updated" in out
|
||||
|
||||
|
||||
def test_import_site_transaction_rollback_on_error(db, tmpdir, monkeypatch, capsys):
|
||||
export_file = tmpdir.join('roles-export.json')
|
||||
with export_file.open('w'):
|
||||
export_file.write(json.dumps({'roles': []}))
|
||||
|
||||
Role = get_role_model()
|
||||
|
||||
def test_import_site_transaction_rollback_on_error(db, monkeypatch, capsys, json_fixture):
|
||||
def exception_import_site(*args):
|
||||
Role.objects.create(slug='role-slug')
|
||||
raise Exception()
|
||||
|
@ -69,43 +79,51 @@ def test_import_site_transaction_rollback_on_error(db, tmpdir, monkeypatch, caps
|
|||
authentic2.management.commands.import_site, 'import_site', exception_import_site)
|
||||
|
||||
with pytest.raises(Exception):
|
||||
management.call_command('import_site', export_file.strpath)
|
||||
management.call_command('import_site', json_fixture({'roles': []}))
|
||||
|
||||
with pytest.raises(Role.DoesNotExist):
|
||||
Role.objects.get(slug='role-slug')
|
||||
|
||||
|
||||
def test_import_site_transaction_rollback_on_dry_run(db, tmpdir, monkeypatch, capsys):
|
||||
export_file = tmpdir.join('roles-export.json')
|
||||
with export_file.open('w'):
|
||||
export_file.write(json.dumps(
|
||||
{'roles': [{
|
||||
'uuid': 'dqfewrvesvews2532', 'slug': 'role-slug', 'name': 'role-name',
|
||||
'ou': None, 'service': None}]}))
|
||||
def test_import_site_transaction_rollback_on_dry_run(db, monkeypatch, capsys, json_fixture):
|
||||
content = {
|
||||
'roles': [
|
||||
{
|
||||
'uuid': 'dqfewrvesvews2532',
|
||||
'slug': 'role-slug',
|
||||
'name': 'role-name',
|
||||
'ou': None,
|
||||
'service': None
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
Role = get_role_model()
|
||||
|
||||
management.call_command('import_site', '--dry-run', export_file.strpath)
|
||||
management.call_command('import_site', '--dry-run', json_fixture(content))
|
||||
|
||||
with pytest.raises(Role.DoesNotExist):
|
||||
Role.objects.get(slug='role-slug')
|
||||
|
||||
|
||||
def test_import_site_cmd_unhandled_context_option(db, tmpdir, monkeypatch, capsys):
|
||||
def test_import_site_cmd_unhandled_context_option(db, monkeypatch, capsys, json_fixture):
|
||||
from authentic2.data_transfer import DataImportError
|
||||
|
||||
export_file = tmpdir.join('roles-export.json')
|
||||
with export_file.open('w'):
|
||||
export_file.write(json.dumps(
|
||||
{'roles': [{
|
||||
'uuid': 'dqfewrvesvews2532', 'slug': 'role-slug', 'name': 'role-name',
|
||||
'ou': None, 'service': None}]}))
|
||||
content = {
|
||||
'roles': [
|
||||
{
|
||||
'uuid': 'dqfewrvesvews2532',
|
||||
'slug': 'role-slug',
|
||||
'name': 'role-name',
|
||||
'ou': None,
|
||||
'service': None
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
get_role_model().objects.create(uuid='dqfewrvesvews2532', slug='role-slug', name='role-name')
|
||||
Role.objects.create(uuid='dqfewrvesvews2532', slug='role-slug', name='role-name')
|
||||
|
||||
with pytest.raises(DataImportError):
|
||||
management.call_command(
|
||||
'import_site', '-o', 'role-delete-orphans', export_file.strpath)
|
||||
'import_site', '-o', 'role-delete-orphans', json_fixture(content))
|
||||
|
||||
|
||||
def test_import_site_cmd_unknown_context_option(db, tmpdir, monkeypatch, capsys):
|
||||
|
@ -115,18 +133,23 @@ def test_import_site_cmd_unknown_context_option(db, tmpdir, monkeypatch, capsys)
|
|||
management.call_command('import_site', '-o', 'unknown-option', export_file.strpath)
|
||||
|
||||
|
||||
def test_import_site_confirm_prompt_yes(db, tmpdir, monkeypatch):
|
||||
export_file = tmpdir.join('roles-export.json')
|
||||
with export_file.open('w'):
|
||||
export_file.write(json.dumps(
|
||||
{'roles': [{
|
||||
'uuid': 'dqfewrvesvews2532', 'slug': 'role-slug', 'name': 'role-name',
|
||||
'ou': None, 'service': None}]}))
|
||||
def test_import_site_confirm_prompt_yes(db, monkeypatch, json_fixture):
|
||||
content = {
|
||||
'roles': [
|
||||
{
|
||||
'uuid': 'dqfewrvesvews2532',
|
||||
'slug': 'role-slug',
|
||||
'name': 'role-name',
|
||||
'ou': None,
|
||||
'service': None
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
def yes_raw_input(*args, **kwargs):
|
||||
return 'yes'
|
||||
|
||||
monkeypatch.setattr(__builtin__, 'raw_input', yes_raw_input)
|
||||
|
||||
management.call_command('import_site', export_file.strpath, stdin='yes')
|
||||
assert get_role_model().objects.get(uuid='dqfewrvesvews2532')
|
||||
management.call_command('import_site', json_fixture(content), stdin='yes')
|
||||
assert Role.objects.get(uuid='dqfewrvesvews2532')
|
||||
|
|
Loading…
Reference in New Issue