From 1a6a4e228733a59c60d5d86717d926df217fbd43 Mon Sep 17 00:00:00 2001 From: BorjaEst Date: Tue, 6 Sep 2022 09:47:14 +0200 Subject: [PATCH] Use .env for flask test config --- .gitignore | 1 + examples/example_flask.py | 6 +++--- flaat/flask/__init__.py | 6 +++--- flaat/flask/conftest.py | 5 ++--- 4 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.gitignore b/.gitignore index af71c8e..34b28bd 100644 --- a/.gitignore +++ b/.gitignore @@ -70,6 +70,7 @@ target/ # DotEnv configuration .env +.env.back # Database *.db diff --git a/examples/example_flask.py b/examples/example_flask.py index e81a613..a03dcd5 100644 --- a/examples/example_flask.py +++ b/examples/example_flask.py @@ -71,7 +71,7 @@ class ProductionConfig(Config): # In production you might want to reduce the number of OP TRUSTED_OP_LIST = ["https://aai.egi.eu/oidc/"] - FLAAT_ISSUER = "https://aai.egi.eu/oidc/" + FLAAT_ISS = "https://aai.egi.eu/oidc/" # Define your request timeout for production FLAAT_REQUEST_TIMEOUT = 1.2 @@ -107,9 +107,9 @@ class TestingConfig(Config): # ------------------------------------------------------------------ # Standard flask Application Factories snippet, source -------------- # https://flask.palletsprojects.com/en/2.1.x/patterns/appfactories -def create_app(config="ProductionConfig"): +def create_app(config=f"{__name__}.ProductionConfig"): app = Flask(__name__) - app.config.from_object(f"{__name__}.{config}") + app.config.from_object(config) # Init application plugins flaat.init_app(app) diff --git a/flaat/flask/__init__.py b/flaat/flask/__init__.py index c2b566f..b79d125 100644 --- a/flaat/flask/__init__.py +++ b/flaat/flask/__init__.py @@ -21,7 +21,7 @@ def __init__(self, access_levels=config.DEFAULT_ACCESS_LEVELS, app=None): def init_app(self, app): app.config.setdefault("TRUSTED_OP_LIST", []) - app.config.setdefault("FLAAT_ISSUER", "") + app.config.setdefault("FLAAT_ISS", "") app.config.setdefault("FLAAT_CLIENT_ID", "") app.config.setdefault("FLAAT_CLIENT_SECRET", "") app.config.setdefault("FLAAT_REQUEST_TIMEOUT", 1.2) # seconds @@ -52,14 +52,14 @@ def iss(self): """Returns the Flaat configured issuer URL. :return: Issuer URL of the pinned issuer """ - return current_app.config["FLAAT_ISSUER"] + return current_app.config["FLAAT_ISS"] def set_issuer(self, issuer: str): """Pins the given issuer. Only users of this issuer will be able to use services. :param issuer: Issuer URL of the pinned issuer. """ - current_app.config["FLAAT_ISSUER"] = issuer.rstrip("/") + current_app.config["FLAAT_ISS"] = issuer.rstrip("/") @property def client_id(self): diff --git a/flaat/flask/conftest.py b/flaat/flask/conftest.py index 74ed29d..a96e22a 100644 --- a/flaat/flask/conftest.py +++ b/flaat/flask/conftest.py @@ -5,11 +5,10 @@ import copy from flaat import issuers -from flaat.test_env import FLAAT_TRUSTED_OPS_LIST from pytest_cases import fixture -@fixture(scope="session", params=["ProductionConfig"]) +@fixture(scope="session", params=["flaat.test_env"]) def configuration(request): return request.param @@ -19,7 +18,7 @@ def app(configuration): from examples.example_flask import create_app app = create_app(configuration) - app.config["TRUSTED_OP_LIST"] = FLAAT_TRUSTED_OPS_LIST + app.config["ADMIN_EMAILS"] = ["admin@foo.org", "dev@foo.org"] app.config["TESTING"] = True # other setup can go here yield app