2019-12-06 10:32:57 +07:00
|
|
|
import os
|
2019-03-01 23:49:31 +01:00
|
|
|
from base64 import b64encode
|
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
import pytest
|
|
|
|
from flask_migrate import upgrade as flask_migrate_upgrade
|
|
|
|
|
2019-12-06 10:32:57 +07:00
|
|
|
from powerdnsadmin import create_app
|
2022-12-22 22:47:02 +01:00
|
|
|
from powerdnsadmin.models.api_key import ApiKey
|
2019-12-06 10:32:57 +07:00
|
|
|
from powerdnsadmin.models.base import db
|
|
|
|
from powerdnsadmin.models.setting import Setting
|
2022-12-22 22:47:02 +01:00
|
|
|
from powerdnsadmin.models.user import User
|
|
|
|
|
2019-12-06 10:32:57 +07:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
def app():
|
|
|
|
app = create_app('../configs/test.py')
|
|
|
|
yield app
|
2019-03-01 23:49:31 +01:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
2022-12-22 22:47:02 +01:00
|
|
|
def client(app):
|
2019-03-01 23:49:31 +01:00
|
|
|
app.config['TESTING'] = True
|
|
|
|
client = app.test_client()
|
|
|
|
yield client
|
|
|
|
|
|
|
|
def load_data(setting_name, *args, **kwargs):
|
|
|
|
if setting_name == 'maintenance':
|
|
|
|
return 0
|
|
|
|
if setting_name == 'pdns_api_url':
|
|
|
|
return 'http://empty'
|
|
|
|
if setting_name == 'pdns_api_key':
|
|
|
|
return 'XXXX'
|
|
|
|
if setting_name == 'pdns_version':
|
|
|
|
return '4.1.0'
|
|
|
|
if setting_name == 'google_oauth_enabled':
|
|
|
|
return False
|
|
|
|
if setting_name == 'session_timeout':
|
|
|
|
return 10
|
|
|
|
if setting_name == 'allow_user_create_domain':
|
|
|
|
return True
|
2022-05-19 00:53:05 +02:00
|
|
|
if setting_name == 'allow_user_remove_domain':
|
|
|
|
return True
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2019-12-06 10:32:57 +07:00
|
|
|
|
2020-01-27 12:38:38 +00:00
|
|
|
@pytest.fixture
|
2022-12-22 22:47:02 +01:00
|
|
|
def test_admin_user(app):
|
2020-01-27 12:38:38 +00:00
|
|
|
return app.config.get('TEST_ADMIN_USER')
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
2022-12-22 22:47:02 +01:00
|
|
|
def test_user(app):
|
2020-01-27 12:38:38 +00:00
|
|
|
return app.config.get('TEST_USER')
|
|
|
|
|
|
|
|
|
2019-03-01 23:49:31 +01:00
|
|
|
@pytest.fixture
|
2022-12-22 22:47:02 +01:00
|
|
|
def basic_auth_admin_headers(app):
|
2019-03-01 23:49:31 +01:00
|
|
|
test_admin_user = app.config.get('TEST_ADMIN_USER')
|
|
|
|
test_admin_pass = app.config.get('TEST_ADMIN_PASSWORD')
|
|
|
|
user_pass = "{0}:{1}".format(test_admin_user, test_admin_pass)
|
|
|
|
user_pass_base64 = b64encode(user_pass.encode('utf-8'))
|
|
|
|
headers = {
|
|
|
|
"Authorization": "Basic {0}".format(user_pass_base64.decode('utf-8'))
|
|
|
|
}
|
|
|
|
return headers
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
2022-12-22 22:47:02 +01:00
|
|
|
def basic_auth_user_headers(app):
|
2019-03-01 23:49:31 +01:00
|
|
|
test_user = app.config.get('TEST_USER')
|
|
|
|
test_user_pass = app.config.get('TEST_USER_PASSWORD')
|
|
|
|
user_pass = "{0}:{1}".format(test_user, test_user_pass)
|
|
|
|
user_pass_base64 = b64encode(user_pass.encode('utf-8'))
|
|
|
|
headers = {
|
|
|
|
"Authorization": "Basic {0}".format(user_pass_base64.decode('utf-8'))
|
|
|
|
}
|
|
|
|
return headers
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope="module")
|
2022-12-22 22:47:02 +01:00
|
|
|
def initial_data(app):
|
|
|
|
|
2019-03-01 23:49:31 +01:00
|
|
|
pdns_proto = os.environ['PDNS_PROTO']
|
|
|
|
pdns_host = os.environ['PDNS_HOST']
|
|
|
|
pdns_port = os.environ['PDNS_PORT']
|
|
|
|
pdns_api_url = '{0}://{1}:{2}'.format(pdns_proto, pdns_host, pdns_port)
|
|
|
|
|
|
|
|
api_url_setting = Setting('pdns_api_url', pdns_api_url)
|
|
|
|
api_key_setting = Setting('pdns_api_key', os.environ['PDNS_API_KEY'])
|
|
|
|
allow_create_domain_setting = Setting('allow_user_create_domain', True)
|
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
with app.app_context():
|
|
|
|
try:
|
|
|
|
flask_migrate_upgrade(directory="migrations")
|
|
|
|
db.session.add(api_url_setting)
|
|
|
|
db.session.add(api_key_setting)
|
|
|
|
db.session.add(allow_create_domain_setting)
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
test_user = app.config.get('TEST_USER')
|
|
|
|
test_user_pass = app.config.get('TEST_USER_PASSWORD')
|
|
|
|
test_admin_user = app.config.get('TEST_ADMIN_USER')
|
|
|
|
test_admin_pass = app.config.get('TEST_ADMIN_PASSWORD')
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
admin_user = User(username=test_admin_user,
|
|
|
|
plain_text_password=test_admin_pass,
|
|
|
|
email="admin@admin.com")
|
|
|
|
ret = admin_user.create_local_user()
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
if not ret['status']:
|
|
|
|
raise Exception("Error occurred creating user {0}".format(ret['msg']))
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
ordinary_user = User(username=test_user,
|
|
|
|
plain_text_password=test_user_pass,
|
|
|
|
email="test@test.com")
|
|
|
|
ret = ordinary_user.create_local_user()
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
if not ret['status']:
|
|
|
|
raise Exception("Error occurred creating user {0}".format(ret['msg']))
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
except Exception as e:
|
|
|
|
print("Unexpected ERROR: {0}".format(e))
|
|
|
|
raise e
|
2019-03-01 23:49:31 +01:00
|
|
|
|
|
|
|
yield
|
|
|
|
os.unlink(app.config['TEST_DB_LOCATION'])
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope="module")
|
2022-12-22 22:47:02 +01:00
|
|
|
def initial_apikey_data(app):
|
2019-03-01 23:49:31 +01:00
|
|
|
pdns_proto = os.environ['PDNS_PROTO']
|
|
|
|
pdns_host = os.environ['PDNS_HOST']
|
|
|
|
pdns_port = os.environ['PDNS_PORT']
|
|
|
|
pdns_api_url = '{0}://{1}:{2}'.format(pdns_proto, pdns_host, pdns_port)
|
|
|
|
|
|
|
|
api_url_setting = Setting('pdns_api_url', pdns_api_url)
|
|
|
|
api_key_setting = Setting('pdns_api_key', os.environ['PDNS_API_KEY'])
|
|
|
|
allow_create_domain_setting = Setting('allow_user_create_domain', True)
|
2022-05-19 00:53:05 +02:00
|
|
|
allow_remove_domain_setting = Setting('allow_user_remove_domain', True)
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
with app.app_context():
|
|
|
|
try:
|
|
|
|
flask_migrate_upgrade(directory="migrations")
|
|
|
|
db.session.add(api_url_setting)
|
|
|
|
db.session.add(api_key_setting)
|
|
|
|
db.session.add(allow_create_domain_setting)
|
|
|
|
db.session.add(allow_remove_domain_setting)
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
test_user_apikey = app.config.get('TEST_USER_APIKEY')
|
|
|
|
test_admin_apikey = app.config.get('TEST_ADMIN_APIKEY')
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
dummy_apikey = ApiKey(desc="dummy", role_name="Administrator")
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
admin_key = dummy_apikey.get_hashed_password(
|
|
|
|
plain_text_password=test_admin_apikey).decode('utf-8')
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
admin_apikey = ApiKey(key=admin_key,
|
|
|
|
desc="test admin apikey",
|
|
|
|
role_name="Administrator")
|
|
|
|
admin_apikey.create()
|
2019-12-06 10:32:57 +07:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
user_key = dummy_apikey.get_hashed_password(
|
|
|
|
plain_text_password=test_user_apikey).decode('utf-8')
|
2019-03-01 23:49:31 +01:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
user_apikey = ApiKey(key=user_key,
|
|
|
|
desc="test user apikey",
|
|
|
|
role_name="User")
|
|
|
|
user_apikey.create()
|
2019-12-06 10:32:57 +07:00
|
|
|
|
2022-12-22 22:47:02 +01:00
|
|
|
except Exception as e:
|
|
|
|
print("Unexpected ERROR: {0}".format(e))
|
|
|
|
raise e
|
2019-03-01 23:49:31 +01:00
|
|
|
|
|
|
|
yield
|
|
|
|
os.unlink(app.config['TEST_DB_LOCATION'])
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def zone_data():
|
|
|
|
data = {
|
|
|
|
"name": "example.org.",
|
|
|
|
"kind": "NATIVE",
|
|
|
|
"nameservers": ["ns1.example.org."]
|
|
|
|
}
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def created_zone_data():
|
|
|
|
data = {
|
2022-12-22 22:47:02 +01:00
|
|
|
'url': '/api/v1/servers/localhost/zones/example.org.',
|
|
|
|
'soa_edit_api': 'DEFAULT',
|
|
|
|
'last_check': 0,
|
2019-12-06 10:32:57 +07:00
|
|
|
'masters': [],
|
2022-12-22 22:47:02 +01:00
|
|
|
'dnssec': False,
|
|
|
|
'notified_serial': 0,
|
|
|
|
'nsec3narrow': False,
|
|
|
|
'serial': 2019013101,
|
|
|
|
'nsec3param': '',
|
|
|
|
'soa_edit': '',
|
|
|
|
'api_rectify': False,
|
|
|
|
'kind': 'Native',
|
2019-12-06 10:32:57 +07:00
|
|
|
'rrsets': [{
|
|
|
|
'comments': [],
|
2022-12-22 22:47:02 +01:00
|
|
|
'type': 'SOA',
|
|
|
|
'name': 'example.org.',
|
|
|
|
'ttl': 3600,
|
2019-12-06 10:32:57 +07:00
|
|
|
'records': [{
|
2022-12-22 22:47:02 +01:00
|
|
|
'content': 'a.misconfigured.powerdns.server. hostmaster.example.org. 2019013101 10800 3600 604800 3600',
|
2019-12-06 10:32:57 +07:00
|
|
|
'disabled': False
|
|
|
|
}]
|
|
|
|
}, {
|
|
|
|
'comments': [],
|
2022-12-22 22:47:02 +01:00
|
|
|
'type': 'NS',
|
|
|
|
'name': 'example.org.',
|
|
|
|
'ttl': 3600,
|
2019-12-06 10:32:57 +07:00
|
|
|
'records': [{
|
|
|
|
'content': 'ns1.example.org.',
|
|
|
|
'disabled': False
|
|
|
|
}]
|
|
|
|
}],
|
2022-12-22 22:47:02 +01:00
|
|
|
'name': 'example.org.',
|
|
|
|
'account': '',
|
|
|
|
'id': 'example.org.'
|
|
|
|
}
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
|
|
|
def user_data(app):
|
|
|
|
test_user = app.config.get('TEST_USER')
|
|
|
|
test_user_pass = app.config.get('TEST_USER_PASSWORD')
|
|
|
|
data = {
|
|
|
|
"username": test_user,
|
|
|
|
"plain_text_password": test_user_pass,
|
|
|
|
"email": "test@test.com"
|
2019-03-01 23:49:31 +01:00
|
|
|
}
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
|
|
|
def user_apikey_data():
|
|
|
|
data = {
|
|
|
|
"description": "userkey",
|
2019-12-06 10:32:57 +07:00
|
|
|
"domains": ["example.org"],
|
2019-03-01 23:49:31 +01:00
|
|
|
"role": "User"
|
|
|
|
}
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
|
|
|
def admin_apikey_data():
|
2019-12-06 10:32:57 +07:00
|
|
|
data = {"description": "masterkey", "domains": [], "role": "Administrator"}
|
2019-03-01 23:49:31 +01:00
|
|
|
return data
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='module')
|
2022-12-22 22:47:02 +01:00
|
|
|
def user_apikey_integration(app):
|
2019-03-01 23:49:31 +01:00
|
|
|
test_user_apikey = app.config.get('TEST_USER_APIKEY')
|
|
|
|
headers = create_apikey_headers(test_user_apikey)
|
|
|
|
return headers
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='module')
|
2022-12-22 22:47:02 +01:00
|
|
|
def admin_apikey_integration(app):
|
2019-03-01 23:49:31 +01:00
|
|
|
test_user_apikey = app.config.get('TEST_ADMIN_APIKEY')
|
|
|
|
headers = create_apikey_headers(test_user_apikey)
|
|
|
|
return headers
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='module')
|
2022-12-22 22:47:02 +01:00
|
|
|
def user_apikey(app):
|
|
|
|
with app.app_context():
|
|
|
|
data = user_apikey_data()
|
|
|
|
api_key = ApiKey(desc=data['description'],
|
|
|
|
role_name=data['role'],
|
|
|
|
domains=[])
|
|
|
|
headers = create_apikey_headers(api_key.plain_key)
|
|
|
|
return headers
|
2019-03-01 23:49:31 +01:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope='module')
|
2022-12-22 22:47:02 +01:00
|
|
|
def admin_apikey(app):
|
|
|
|
with app.app_context():
|
|
|
|
data = admin_apikey_data()
|
|
|
|
api_key = ApiKey(desc=data['description'],
|
|
|
|
role_name=data['role'],
|
|
|
|
domains=[])
|
|
|
|
headers = create_apikey_headers(api_key.plain_key)
|
|
|
|
return headers
|
2019-03-01 23:49:31 +01:00
|
|
|
|
|
|
|
|
|
|
|
def create_apikey_headers(passw):
|
|
|
|
user_pass_base64 = b64encode(passw.encode('utf-8'))
|
2019-12-06 10:32:57 +07:00
|
|
|
headers = {"X-API-KEY": "{0}".format(user_pass_base64.decode('utf-8'))}
|
2019-03-01 23:49:31 +01:00
|
|
|
return headers
|
2020-01-27 12:38:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def account_data():
|
|
|
|
data = {
|
|
|
|
"name": "test1",
|
|
|
|
"description": "test1 account",
|
|
|
|
"contact": "test1 contact",
|
|
|
|
"mail": "test1@example.com",
|
|
|
|
}
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def user1_data():
|
|
|
|
data = {
|
|
|
|
"username": "testuser1",
|
|
|
|
"plain_text_password": "ChangeMePlease",
|
|
|
|
"firstname": "firstname1",
|
|
|
|
"lastname": "lastname1",
|
|
|
|
"email": "testuser1@example.com",
|
|
|
|
"otp_secret": "",
|
|
|
|
"confirmed": False,
|
|
|
|
"role_name": "User",
|
|
|
|
}
|
|
|
|
return data
|