2023-05-24 11:10:40 -04:00
|
|
|
# noqa
|
2022-10-12 10:22:22 -04:00
|
|
|
import os
|
|
|
|
import shutil
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
from flask.app import Flask
|
2023-03-06 11:59:33 -05:00
|
|
|
from spiffworkflow_backend.models.bpmn_process import BpmnProcessModel
|
2023-01-19 12:36:45 -05:00
|
|
|
from spiffworkflow_backend.models.db import db
|
2022-10-20 16:00:12 -04:00
|
|
|
from spiffworkflow_backend.models.user import UserModel
|
2023-05-22 14:58:51 -04:00
|
|
|
from spiffworkflow_backend.services.authorization_service import AuthorizationService
|
2022-10-12 10:22:22 -04:00
|
|
|
from spiffworkflow_backend.services.process_model_service import ProcessModelService
|
|
|
|
|
2023-05-26 20:01:08 -04:00
|
|
|
from tests.spiffworkflow_backend.helpers.base_test import BaseTest
|
2022-10-12 10:22:22 -04:00
|
|
|
|
|
|
|
# We need to call this before importing spiffworkflow_backend
|
|
|
|
# otherwise typeguard cannot work. hence the noqa: E402
|
|
|
|
if os.environ.get("RUN_TYPEGUARD") == "true":
|
2023-05-01 15:26:29 -04:00
|
|
|
from typeguard import install_import_hook
|
2022-10-12 10:22:22 -04:00
|
|
|
|
|
|
|
install_import_hook(packages="spiffworkflow_backend")
|
|
|
|
|
|
|
|
|
|
|
|
from spiffworkflow_backend import create_app # noqa: E402
|
|
|
|
|
|
|
|
|
2024-01-16 14:47:25 -05:00
|
|
|
def _set_unit_testing_env_variables() -> None:
|
2023-02-07 15:02:47 -05:00
|
|
|
os.environ["SPIFFWORKFLOW_BACKEND_ENV"] = "unit_testing"
|
2023-05-30 19:53:26 -04:00
|
|
|
os.environ["FLASK_SESSION_SECRET_KEY"] = (
|
|
|
|
"e7711a3ba96c46c68e084a86952de16f" # noqa: S105, do not care about security when running unit tests
|
|
|
|
)
|
2024-01-16 14:47:25 -05:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
def app() -> Flask: # noqa
|
|
|
|
_set_unit_testing_env_variables()
|
2022-10-12 10:22:22 -04:00
|
|
|
app = create_app()
|
|
|
|
|
2023-12-20 07:18:20 -08:00
|
|
|
# to screw with this, poet add nplusone --group dev
|
|
|
|
# from nplusone.ext.flask_sqlalchemy import NPlusOne
|
|
|
|
# app.config["NPLUSONE_RAISE"] = True
|
|
|
|
# NPlusOne(app)
|
|
|
|
|
2022-10-12 10:22:22 -04:00
|
|
|
return app
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture()
|
|
|
|
def with_db_and_bpmn_file_cleanup() -> None:
|
2023-02-20 12:34:42 -05:00
|
|
|
"""Do it cleanly!"""
|
2023-02-17 10:44:03 -05:00
|
|
|
meta = db.metadata
|
2023-03-28 15:56:00 -04:00
|
|
|
db.session.execute(db.update(BpmnProcessModel).values(top_level_process_id=None))
|
|
|
|
db.session.execute(db.update(BpmnProcessModel).values(direct_parent_process_id=None))
|
2023-03-03 16:51:24 -05:00
|
|
|
|
2023-02-17 10:44:03 -05:00
|
|
|
for table in reversed(meta.sorted_tables):
|
|
|
|
db.session.execute(table.delete())
|
2022-10-20 16:00:12 -04:00
|
|
|
db.session.commit()
|
2022-10-12 10:22:22 -04:00
|
|
|
|
|
|
|
try:
|
|
|
|
yield
|
|
|
|
finally:
|
2023-05-17 10:16:09 -04:00
|
|
|
if os.path.exists(ProcessModelService.root_path()):
|
|
|
|
shutil.rmtree(ProcessModelService.root_path())
|
2022-10-12 10:22:22 -04:00
|
|
|
|
|
|
|
|
2022-10-20 16:00:12 -04:00
|
|
|
@pytest.fixture()
|
2023-05-24 11:10:40 -04:00
|
|
|
def with_super_admin_user() -> UserModel: # noqa
|
|
|
|
# this loads all permissions from yaml everytime this function is called which is slow
|
|
|
|
# so default to just setting a simple super admin and only run with the "real" permissions in ci
|
|
|
|
if os.environ.get("SPIFFWORKFLOW_BACKEND_RUNNING_IN_CI") == "true":
|
|
|
|
user = BaseTest.find_or_create_user(username="testadmin1")
|
|
|
|
AuthorizationService.import_permissions_from_yaml_file(user)
|
|
|
|
else:
|
|
|
|
user = BaseTest.create_user_with_permission("super_admin")
|
2023-05-22 14:58:51 -04:00
|
|
|
return user
|