-
Notifications
You must be signed in to change notification settings - Fork 7
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Using a DbSession and an EngineSingleton to inject the engine #199
Using a DbSession and an EngineSingleton to inject the engine #199
Conversation
…d of giving it to every router. This is cleaner (I think) and makes it easy to patch the engine for unittests. Note that FastAPI Depends would work as well for the routers, but not for other parts of the code.
…eated when ES_USER and ES_PASSWORD env vars are empty; used the style of PR #199
src/tests/routers/ai_asset_routers/test_router_aiassets_retrieve_content.py
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not sure why in some tests sqlalchemy.engine.Engine is still used.
Thanks for the review! I indeed forgot to remove many usages of the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me.
* First approach to use the elasticsearch service * elasticsearch query example * elasticsearch query complete example * Elasticsearch setup configured * Remove .DS_Store and add it to dockerignore * Created an elastic search endpoint. It isnt working yet * Just to test the new database * To rebase develop * Working but not up-to-date with develop branch * Service working. Need to get up-to-date with develop * Some bugfixes for the connectors * Deleting docker images in clean script * Fixed issues with authentication * Publication search seems to work. TODO: test cases and other resourcse * platform and platform_identifier changed from aiod_entry to each instance * Created testcase for publication search * Made ElasticSearch router generic, implemented it for dataset * Logstash configured for dataset, experiment, ml_model, publication, and service * Logstash configured for dataset, experiment, ml_model, publication, and service * Logstash waits until fill-db-with-examples ends * take src from develop * Copied entire develop branch * Logstash configuration readapted to new names * Logstash configuration readapted to new names * added ai4experiments to platform names * Copied initial search routers to start creating them * Examples of ml_model, dataset and experiment used to insert ai4experiment data * Descriptions of the ai4experiment data improved * platform added to mappings * elasticsearch query example completed * First version of search service working * Search router tests implemented * Search fields selection added * Added search for event, news, ortganisation and project * Added routers for event, news, organisation and project * Logstash names changed * added logstash_config.py, just for having it there * Pagination changed to actual pages * Pagination changed to actual pages * Application areas added to elasticsearch resuts * First version with deletion * Prepared to be merged with develop * pull request modifications * pull request modifications * pull request modifications * Combined search with sql queries in process * Search functionality combined with optional SQL statment to retrieve everything * Elasticsearch and logstash configuration integrated in src * Search router tests actualised * Search router tests actualised * Search router tests actualised * pre-commit passed * All test passed and working. Not merged with develop * huggingface connector test to its original state * back to commented huggingface connector * Fixing unittests by making sure Elasticsearch instance can also be created when ES_USER and ES_PASSWORD env vars are empty; used the style of PR #199 * clean logstash configuration * clean logstash configuration * clean logstash configuration * clean logstash configuration * clean logstash configuration * clean logstash configuration * logstash config files generated with jinja2 * logstash config files generated with jinja2 * Logstash config files generated with jinja2. All test passed, but not merged with develop. * Second round of pull request comments * Second round of pull request comments * Second round of pull request comments * Second round of pull request comments * Second round of pull request comments * Created data/elasticsearch/.gitkeep to make sure it exists with the right permissions * Deleted autogenerated file logstash/config/logstash.yml * cleanup * Making sure docker compose up works even if generated files do not exist; added logging; simplified file names * Make sure data folders are always created with correct permissions (this was by accident removed in commit cc8c22f) * Added default logstash configuration * Fixed docker compose * Using FastAPI input validation * Made status nullable, so that we can return an empty status in the search_router --------- Co-authored-by: Adrián <[email protected]> Co-authored-by: Jos van der Velde <[email protected]>
Small refactor to make the code a bit cleaner.
Using a DbSession and an EngineSingleton to inject the engine, instead of giving it to every router. This is cleaner (I think) and makes it easy to patch the engine for unittests. Note that FastAPI Depends would work as well for the routers, but not for other parts of the code.