From 521a120aa06708a3d7488d5ffa3c9810b1574b66 Mon Sep 17 00:00:00 2001 From: kyle Date: Fri, 10 Jan 2025 15:18:48 -0500 Subject: [PATCH] configuring tests to load env vars --- .github/workflows/ci.yaml | 8 ++------ Makefile | 8 ++++---- tests/conftest.py | 16 ++++++++++++++++ .../processes/ingest/assert_ingested_records.py | 4 ++-- .../ingest/test_chicago_isac_process.py | 3 --- .../processes/ingest/test_doab_process.py | 3 --- .../processes/ingest/test_gutenberg_process.py | 3 --- .../processes/ingest/test_loc_process.py | 3 --- .../processes/ingest/test_met_process.py | 3 --- .../processes/ingest/test_muse_process.py | 2 -- .../processes/ingest/test_nypl_process.py | 3 --- .../ingest/test_publisher_backlist_process.py | 3 --- .../services/sources/test_nypl_bib_service.py | 2 -- .../sources/test_publisher_backlist_service.py | 2 -- tests/integration/test_google_integration.py | 3 --- tests/integration/test_oclc_auth_manager.py | 3 --- tests/integration/test_oclc_catalog_manager.py | 2 -- tests/integration/test_ssm_service.py | 3 --- 18 files changed, 24 insertions(+), 50 deletions(-) create mode 100644 tests/conftest.py diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index af588f22e5..fd3f398811 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -22,11 +22,8 @@ jobs: integration-tests: runs-on: ubuntu-latest env: - AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} - AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} - NYPL_API_CLIENT_ID: ${{ secrets.NYPL_API_CLIENT_ID }} - NYPL_API_CLIENT_SECRET: ${{ secrets.NYPL_API_CLIENT_SECRET }} - NYPL_API_TOKEN_URL: ${{ secrets.NYPL_API_TOKEN_URL }} + AWS_ACCESS: ${{ secrets.AWS_ACCESS_KEY_ID }} + AWS_SECRET: ${{ secrets.AWS_SECRET_ACCESS_KEY }} ENVIRONMENT: qa steps: - uses: actions/checkout@v3 @@ -37,7 +34,6 @@ jobs: - name: Install dependencies run: | make unit-deps - # TODO: is this the right flow? - name: Run functional tests run: | make functional diff --git a/Makefile b/Makefile index fd0b938e80..2590a2dbd9 100644 --- a/Makefile +++ b/Makefile @@ -7,13 +7,13 @@ help: @echo "make help" unit: - python -m pytest --cov-report term-missing --cov=. tests/unit + python -m pytest --cov-report term-missing --cov=. tests/unit --env=$(ENV) -allure-test: - python -m pytest --alluredir=./allure-results ./tests/unit +functional: + python -m pytest tests/functional --env=$(ENV) integration: - python -m pytest tests/integration + python -m pytest tests/integration --env=$(ENV) up: $(compose_command) up -d diff --git a/tests/conftest.py b/tests/conftest.py new file mode 100644 index 0000000000..4f0087eb0a --- /dev/null +++ b/tests/conftest.py @@ -0,0 +1,16 @@ +import os +import pytest + +from load_env import load_env_file + + +def pytest_addoption(parser): + parser.addoption('--env', action='store', default='local', help='Environment to use for tests') + + +@pytest.fixture(scope='session', autouse=True) +def setup_env(pytestconfig): + environment = os.environ.get('ENVIRONMENT') or pytestconfig.getoption('--env') + + if environment in ['local', 'qa']: + load_env_file(environment, file_string=f'config/{environment}.yaml') diff --git a/tests/functional/processes/ingest/assert_ingested_records.py b/tests/functional/processes/ingest/assert_ingested_records.py index 76b69822e8..be9aa5b361 100644 --- a/tests/functional/processes/ingest/assert_ingested_records.py +++ b/tests/functional/processes/ingest/assert_ingested_records.py @@ -9,11 +9,11 @@ def assert_ingested_records(source_name: str): db_manager.generateEngine() db_manager.createSession() - doab_records = ( + records = ( db_manager.session.query(Record) .filter(Record.source == source_name) .filter(Record.date_modified > datetime.now(timezone.utc).replace(tzinfo=None) - timedelta(minutes=5)) .all() ) - assert len(doab_records) > 1 + assert len(records) > 1 diff --git a/tests/functional/processes/ingest/test_chicago_isac_process.py b/tests/functional/processes/ingest/test_chicago_isac_process.py index 20a9c5dc52..264a0715e5 100644 --- a/tests/functional/processes/ingest/test_chicago_isac_process.py +++ b/tests/functional/processes/ingest/test_chicago_isac_process.py @@ -1,9 +1,6 @@ from processes import ChicagoISACProcess -from load_env import load_env_file from .assert_ingested_records import assert_ingested_records -load_env_file('local', file_string='config/local.yaml') - def test_chigaco_isac_process(): isac_process = ChicagoISACProcess('complete', None, None, None, 5, None) diff --git a/tests/functional/processes/ingest/test_doab_process.py b/tests/functional/processes/ingest/test_doab_process.py index 6e98049906..b923c1bab4 100644 --- a/tests/functional/processes/ingest/test_doab_process.py +++ b/tests/functional/processes/ingest/test_doab_process.py @@ -1,9 +1,6 @@ from processes import DOABProcess -from load_env import load_env_file from .assert_ingested_records import assert_ingested_records -load_env_file('local', file_string='config/local.yaml') - def test_doab_process(): doab_process = DOABProcess('complete', None, None, None, 5, None) diff --git a/tests/functional/processes/ingest/test_gutenberg_process.py b/tests/functional/processes/ingest/test_gutenberg_process.py index ebf9466651..c5660bcb89 100644 --- a/tests/functional/processes/ingest/test_gutenberg_process.py +++ b/tests/functional/processes/ingest/test_gutenberg_process.py @@ -1,9 +1,6 @@ from processes import GutenbergProcess -from load_env import load_env_file from .assert_ingested_records import assert_ingested_records -load_env_file('local', file_string='config/local.yaml') - def test_gutenberg_process(): gutenberg_process = GutenbergProcess('complete', None, None, None, 5, None) diff --git a/tests/functional/processes/ingest/test_loc_process.py b/tests/functional/processes/ingest/test_loc_process.py index e496ef8704..e836da66c4 100644 --- a/tests/functional/processes/ingest/test_loc_process.py +++ b/tests/functional/processes/ingest/test_loc_process.py @@ -1,9 +1,6 @@ from processes import LOCProcess -from load_env import load_env_file from .assert_ingested_records import assert_ingested_records -load_env_file('local', file_string='config/local.yaml') - def test_loc_process(): loc_process = LOCProcess('complete', None, None, None, 5, None) diff --git a/tests/functional/processes/ingest/test_met_process.py b/tests/functional/processes/ingest/test_met_process.py index 7ac0e1676d..cb95e73994 100644 --- a/tests/functional/processes/ingest/test_met_process.py +++ b/tests/functional/processes/ingest/test_met_process.py @@ -1,9 +1,6 @@ from processes import LOCProcess -from load_env import load_env_file from .assert_ingested_records import assert_ingested_records -load_env_file('local', file_string='config/local.yaml') - def test_met_process(): met_process = LOCProcess('complete', None, None, None, 5, None) diff --git a/tests/functional/processes/ingest/test_muse_process.py b/tests/functional/processes/ingest/test_muse_process.py index 6e093db1b7..3530056ed2 100644 --- a/tests/functional/processes/ingest/test_muse_process.py +++ b/tests/functional/processes/ingest/test_muse_process.py @@ -1,8 +1,6 @@ from processes import MUSEProcess -from load_env import load_env_file from .assert_ingested_records import assert_ingested_records -load_env_file('local', file_string='config/local.yaml') def test_muse_process(): diff --git a/tests/functional/processes/ingest/test_nypl_process.py b/tests/functional/processes/ingest/test_nypl_process.py index 9baf954e9b..5a3b7f52bb 100644 --- a/tests/functional/processes/ingest/test_nypl_process.py +++ b/tests/functional/processes/ingest/test_nypl_process.py @@ -1,9 +1,6 @@ from processes import NYPLProcess -from load_env import load_env_file from .assert_ingested_records import assert_ingested_records -load_env_file('local', file_string='config/local.yaml') - def test_nypl_process(): nypl_process = NYPLProcess('complete', None, None, None, 5, None) diff --git a/tests/functional/processes/ingest/test_publisher_backlist_process.py b/tests/functional/processes/ingest/test_publisher_backlist_process.py index 41297f8a73..ad7b9f205e 100644 --- a/tests/functional/processes/ingest/test_publisher_backlist_process.py +++ b/tests/functional/processes/ingest/test_publisher_backlist_process.py @@ -1,9 +1,6 @@ from processes import PublisherBacklistProcess -from load_env import load_env_file from .assert_ingested_records import assert_ingested_records -load_env_file('local', file_string='config/local.yaml') - def test_publisher_backlist_process(): publisher_backlist_project = PublisherBacklistProcess('complete', None, None, None, 5, None) diff --git a/tests/integration/services/sources/test_nypl_bib_service.py b/tests/integration/services/sources/test_nypl_bib_service.py index 730523a268..4d71cf5574 100644 --- a/tests/integration/services/sources/test_nypl_bib_service.py +++ b/tests/integration/services/sources/test_nypl_bib_service.py @@ -1,13 +1,11 @@ from datetime import datetime, timezone, timedelta import pytest -from load_env import load_env_file from services import NYPLBibService class TestNYPLBibService: @pytest.fixture def test_instance(self): - load_env_file('local', file_string='config/local.yaml') return NYPLBibService() def test_get_records(self, test_instance: NYPLBibService): diff --git a/tests/integration/services/sources/test_publisher_backlist_service.py b/tests/integration/services/sources/test_publisher_backlist_service.py index b493832417..7f5af69b1a 100644 --- a/tests/integration/services/sources/test_publisher_backlist_service.py +++ b/tests/integration/services/sources/test_publisher_backlist_service.py @@ -1,13 +1,11 @@ from datetime import datetime, timezone, timedelta import pytest -from load_env import load_env_file from services import PublisherBacklistService class TestPublisherBacklistService: @pytest.fixture def test_instance(self): - load_env_file('local', file_string='config/local.yaml') return PublisherBacklistService() def test_get_records(self, test_instance: PublisherBacklistService): diff --git a/tests/integration/test_google_integration.py b/tests/integration/test_google_integration.py index 600500cd80..1fa2d89c71 100644 --- a/tests/integration/test_google_integration.py +++ b/tests/integration/test_google_integration.py @@ -1,14 +1,11 @@ import os import pytest -from load_env import load_env_file from services import GoogleDriveService -load_env_file('local-compose', file_string='config/local-compose.yaml') class TestGoogleDriveService: @pytest.fixture def test_instance(self): - load_env_file('local', file_string='config/local.yaml') return GoogleDriveService() def test_get_drive_file(self, test_instance: GoogleDriveService): diff --git a/tests/integration/test_oclc_auth_manager.py b/tests/integration/test_oclc_auth_manager.py index ccfcd8a7b4..a7ef149ab6 100644 --- a/tests/integration/test_oclc_auth_manager.py +++ b/tests/integration/test_oclc_auth_manager.py @@ -1,7 +1,4 @@ from managers.oclc_auth import OCLCAuthManager -from load_env import load_env_file - -load_env_file('local-compose', file_string='config/local-compose.yaml') def test_get_search_token(): diff --git a/tests/integration/test_oclc_catalog_manager.py b/tests/integration/test_oclc_catalog_manager.py index c02ec5037a..853ff9c99a 100644 --- a/tests/integration/test_oclc_catalog_manager.py +++ b/tests/integration/test_oclc_catalog_manager.py @@ -1,11 +1,9 @@ import pytest -from load_env import load_env_file from managers import OCLCCatalogManager class TestOCLCCatalogManager: @pytest.fixture def test_instance(self): - load_env_file('local-compose', file_string='config/local-compose.yaml') return OCLCCatalogManager() def test_query_bibs(self, test_instance: OCLCCatalogManager): diff --git a/tests/integration/test_ssm_service.py b/tests/integration/test_ssm_service.py index 98fda0a726..5bd8eb1eff 100644 --- a/tests/integration/test_ssm_service.py +++ b/tests/integration/test_ssm_service.py @@ -1,13 +1,10 @@ -import os import pytest -from load_env import load_env_file from services.ssm_service import SSMService class TestSSMService: @pytest.fixture def test_instance(self): - load_env_file('local', file_string='config/local.yaml') return SSMService() def test_get_parameter(self, test_instance):