Skip to content

Commit

Permalink
Move check to profiles app
Browse files Browse the repository at this point in the history
  • Loading branch information
amickan committed May 3, 2024
1 parent 0b6e6ec commit 842255b
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 35 deletions.
18 changes: 0 additions & 18 deletions app/grandchallenge/components/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,21 +23,3 @@ def check_sagemaker_is_used(app_configs, **kwargs):
)

return errors


@register(deploy=True)
def check_dummy_provider_is_not_used(app_configs, **kwargs):
from django.conf import settings

errors = []

if "dummy" in settings.SOCIALACCOUNT_PROVIDERS.keys():
errors.append(
Error(
"The dummy social account provider is configured. This provider should only be used for testing purposes and not in production.",
hint="Remove the dummy provider from SOCIALACCOUNT_PROVIDERS in your settings.",
id="grandchallenge.components.E002",
)
)

return errors
22 changes: 22 additions & 0 deletions app/grandchallenge/profiles/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
from django.core.checks import Error, register


@register(deploy=True)
def check_dummy_provider_is_not_used(app_configs, **kwargs):
from django.conf import settings

errors = []

if (
"dummy" in settings.SOCIALACCOUNT_PROVIDERS.keys()
or "allauth.socialaccount.providers.dummy" in settings.INSTALLED_APPS
):
errors.append(
Error(
"The dummy social account provider is configured. This provider should only be used for testing purposes and not in production.",
hint="Remove the dummy provider from SOCIALACCOUNT_PROVIDERS and INSTALLED_APPS in your settings.",
id="grandchallenge.profiles.E001",
)
)

return errors
18 changes: 1 addition & 17 deletions app/tests/components_tests/test_checks.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,4 @@
from grandchallenge.components import (
check_dummy_provider_is_not_used,
check_sagemaker_is_used,
)
from grandchallenge.components import check_sagemaker_is_used
from grandchallenge.components.backends.amazon_sagemaker_training import (
AmazonSageMakerTrainingExecutor,
)
Expand All @@ -16,16 +13,3 @@ def test_check_sagemaker_is_used(settings):
assert len(errors) == 1
assert errors[0].id == "grandchallenge.components.E001"
assert errors[0].msg == f"{expected_backend} is not the default backend."


def test_check_dummy_provider_is_not_used(settings):
settings.SOCIALACCOUNT_PROVIDERS = {"dummy": {}}

errors = check_dummy_provider_is_not_used(None)

assert len(errors) == 1
assert errors[0].id == "grandchallenge.components.E002"
assert (
errors[0].msg
== "The dummy social account provider is configured. This provider should only be used for testing purposes and not in production."
)
25 changes: 25 additions & 0 deletions app/tests/profiles_tests/test_checks.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
from grandchallenge.profiles import check_dummy_provider_is_not_used


def test_check_dummy_provider_is_not_used(settings):

errors = check_dummy_provider_is_not_used(None)

assert len(errors) == 1
assert errors[0].id == "grandchallenge.profiles.E001"
assert (
errors[0].msg
== "The dummy social account provider is configured. This provider should only be used for testing purposes and not in production."
)

settings.SOCIALACCOUNT_PROVIDERS = {"dummy": {}}
settings.INSTALLED_APPS.remove("allauth.socialaccount.providers.dummy")

errors = check_dummy_provider_is_not_used(None)

assert len(errors) == 1
assert errors[0].id == "grandchallenge.profiles.E001"
assert (
errors[0].msg
== "The dummy social account provider is configured. This provider should only be used for testing purposes and not in production."
)

0 comments on commit 842255b

Please sign in to comment.