mirror of
https://github.com/peeringdb/peeringdb.git
synced 2024-05-11 05:55:09 +00:00
* add OPERATIONS_EMAIL setting * fixes #1019: redundant saves to deleted netixlans during ix-f import * private pocs are no longer valid (#944) * poetry relock (handleref update) * fixes #1032: __id api filter not working * Additional self-selection fields for Facilities #800 * advanced search fields for available voltage, property and diverse serving substations (#1016) * When network sets netixlan speed to 1200000 only 1T is shown instead of 1.2T ... sometimes #500 * add search-data * comment out mount points for api-cache, search-data, django-peeringdb * poetry relock (django-peeringdb 2.9.0) * linting Co-authored-by: Stefan Pratter <stefan@20c.com>
173 lines
5.2 KiB
Python
173 lines
5.2 KiB
Python
import os
|
|
|
|
import pytest
|
|
from allauth.account.signals import email_confirmed, user_signed_up
|
|
from django.conf import settings
|
|
from django.contrib.auth import get_user_model
|
|
from django.test import TestCase
|
|
|
|
from mainsite.settings import _set_bool, _set_option
|
|
from peeringdb_server import models, serializers
|
|
from peeringdb_server import settings as pdb_settings
|
|
|
|
from .util import SettingsCase
|
|
|
|
|
|
class TestAutoVerifyUser(SettingsCase):
|
|
settings = {"AUTO_VERIFY_USERS": True}
|
|
|
|
def test_setting(self):
|
|
user = get_user_model().objects.create_user(
|
|
"user_a", "user_a@localhost", "user_a"
|
|
)
|
|
user_signed_up.send(sender=None, request=None, user=user)
|
|
assert user.is_verified_user == True
|
|
assert user.status == "ok"
|
|
|
|
|
|
class TestAutoApproveAffiliation(SettingsCase):
|
|
settings = {"AUTO_APPROVE_AFFILIATION": True}
|
|
|
|
def test_setting(self):
|
|
|
|
org = models.Organization.objects.create(name="Test Org", status="ok")
|
|
net = models.Network.objects.create(
|
|
name="Test Net", org=org, asn=63311, status="ok"
|
|
)
|
|
user = get_user_model().objects.create_user(
|
|
"user_a", "user_a@localhost", "user_a"
|
|
)
|
|
user_b = get_user_model().objects.create_user(
|
|
"user_b", "user_b@localhost", "user_b"
|
|
)
|
|
user.set_verified()
|
|
user_b.set_verified()
|
|
|
|
uoar = models.UserOrgAffiliationRequest.objects.create(
|
|
user=user, org=org, asn=net.asn
|
|
)
|
|
assert user.is_org_admin(org) == True
|
|
|
|
uoar = models.UserOrgAffiliationRequest.objects.create(user=user, asn=63312)
|
|
net = models.Network.objects.get(asn=63312)
|
|
assert user.is_org_admin(net.org) == True
|
|
|
|
uoar = models.UserOrgAffiliationRequest.objects.create(
|
|
user=user, org_name="Test Org 2"
|
|
)
|
|
org = models.Organization.objects.get(name="Test Org 2")
|
|
assert user.is_org_admin(org) == True
|
|
|
|
uoar = models.UserOrgAffiliationRequest.objects.create(user=user_b, asn=63312)
|
|
assert user_b.is_org_admin(net.org) == False
|
|
assert user_b.is_org_member(net.org) == False
|
|
|
|
|
|
def test_set_option():
|
|
context = {}
|
|
_set_option("TEST_SETTING", "hello", context)
|
|
assert context["TEST_SETTING"] == "hello"
|
|
|
|
|
|
def test_set_option_w_env_var():
|
|
"""
|
|
Environment variables take precedence over provided options
|
|
"""
|
|
context = {}
|
|
os.environ["TEST_SETTING"] = "world"
|
|
_set_option("TEST_SETTING", "hello", context)
|
|
assert context["TEST_SETTING"] == "world"
|
|
|
|
|
|
def test_set_option_coerce_env_var():
|
|
"""
|
|
We coerce the environment variable to the same type
|
|
as the provided default.
|
|
"""
|
|
context = {}
|
|
# env variables can never be set as integers
|
|
os.environ["TEST_SETTING"] = "123"
|
|
|
|
# setting an option with a default integer will coerce the env
|
|
# variable as well (fix for issue #888)
|
|
_set_option("TEST_SETTING", 321, context)
|
|
assert context["TEST_SETTING"] == 123
|
|
|
|
# setting an option with a default string will coerce the env
|
|
# variable as well
|
|
_set_option("TEST_SETTING", "321", context)
|
|
assert context["TEST_SETTING"] == "123"
|
|
|
|
_set_option("TEST_SETTING", 123.1, context)
|
|
assert context["TEST_SETTING"] == 123.0
|
|
|
|
|
|
def test_set_option_booleans():
|
|
|
|
context = {}
|
|
# env variables can only be set as strings
|
|
os.environ["TEST_SETTING"] = "False"
|
|
|
|
# setting the option with a boolean
|
|
# will use set_bool to handle the
|
|
# type coercion of the env variable
|
|
_set_option("TEST_SETTING", False, context)
|
|
assert context["TEST_SETTING"] == False
|
|
|
|
# the environment variable has precedence
|
|
_set_option("TEST_SETTING", True, context)
|
|
assert context["TEST_SETTING"] == False
|
|
|
|
del os.environ["TEST_SETTING"]
|
|
del context["TEST_SETTING"]
|
|
_set_option("TEST_SETTING", True, context)
|
|
# We can set boolean values without env vars as well
|
|
assert context["TEST_SETTING"] == True
|
|
|
|
|
|
def test_set_bool():
|
|
"""
|
|
We coerce the environment variable to a boolean
|
|
"""
|
|
context = {}
|
|
|
|
# 0 is interpreted as False
|
|
os.environ["TEST_SETTING"] = "0"
|
|
# env variables can never be set as integers
|
|
_set_bool("TEST_SETTING", False, context)
|
|
assert context["TEST_SETTING"] == False
|
|
|
|
# the environment variable has precedence
|
|
_set_bool("TEST_SETTING", True, context)
|
|
assert context["TEST_SETTING"] == False
|
|
|
|
# We raise an error if the env variable
|
|
# cannot be reasonably coerced to a bool
|
|
|
|
os.environ["TEST_SETTING"] = "100"
|
|
with pytest.raises(ValueError):
|
|
_set_option("TEST_SETTING", True, context)
|
|
|
|
|
|
def test_set_options_none():
|
|
"""
|
|
We coerce the environment variable to a boolean
|
|
"""
|
|
context = {}
|
|
|
|
# 0 is interpreted as False
|
|
os.environ["TEST_SETTING"] = "0"
|
|
|
|
# setting an option with None without setting the
|
|
# envvar_type raises an error
|
|
with pytest.raises(ValueError):
|
|
_set_option("TEST_SETTING", None, context)
|
|
|
|
# setting an option with None but setting the
|
|
# envvar_type is fine
|
|
_set_option("TEST_SETTING", None, context, envvar_type=int)
|
|
assert context["TEST_SETTING"] == 0
|
|
|
|
_set_option("TEST_SETTING", None, context, envvar_type=str)
|
|
assert context["TEST_SETTING"] == "0"
|