To start the project, up
the docker containers using compose:
docker compose up -d
The system will start out empty. To load test-data into the database, make sure you have the test-data CSV files in the folder ./suila/data
, then run the load_data.sh
-script command:
./bin/load_data.sh 200
NOTE: The 200
-argument is how many lines from the CSV files are loaded into the database.
If none is specified, all lines will be loaded, which can take awhile.
You can now access the web-ui at: http://localhost:8120/
The database can be accessed through CLI like so:
docker exec suila-db bash -c 'psql -U bf -c "SELECT * FROM common_user;"'
If we want access to the database through a program like PgAdmin, we need to portforward the suila-db
container ports.
This can be done by creating a docker-compose.override.yml
-file:
services:
suila-db:
ports:
- "5432:5432"
By default the host-domain for AKA-Selvbetjening is set to the prod-server, https://akap.sullissivik.gl
, but our ./dev-environment/suila.env
-settings will set this to https://test.akap.sullissivik.gl
.
if we want to interact with our local development version instead of the test-server, we need to connect
the suila-web
-container to AKA-Selvbetjening's container network. This can be done by adding the following
to a docker-compose.override.yml
-file:
networks:
aka-selvbetjening_default:
external: true
services:
suila-web:
networks:
- aka-selvbetjening_default
environment:
AKAP_HOST: http://akap-web:8010
NOTE: This assumes you use the default setup for the aka-selvbetjening's project,
configured in the docker-compose.yml
-file.
Now run the import_u1a_data
-command:
docker exec suila-web python manage.py import_u1a_data --verbose
IMPORTANT: U1A data is used when running the estimate_income
-command, which is done through the load_data.sh
-script.
This means that if the import_u1a_data
-command is executed after the load_data.sh
-script, we need to run the
estimate_income
-command again, or just run the load_data.sh
-script again.
To send data to Prisme, use the following management command: export_benefits_to_prisme
.
If you are working with test data from the CSV files, some minor configurations need to be made for the command to work in a development environment:
- Edit
suila/suila/management/commands/load_prisme_account_aliases.py
and setTAX_YEARS = range(2020, 2031)
- This ensures that
PrismeAccountAlias
rows are created for the years covered by the CSV test data.
- This ensures that
- Run the
load_prisme_account_aliases
-command-
docker exec suila-web python manage.py load_prisme_account_aliases
-
- Update all rows in the
suila_person
table with alocation_code
that exists in thesuila_prismeaccountalias
table (columntax_municipality_location_code
):-
docker exec suila-db psql -U suila -c 'UPDATE suila_person SET location_code = 961'
- Note: The available
location_code
values can be found insuila/suila/management/commands/load_prisme_account_aliases.py
.
-
Once these steps are complete, you can run the export_benefits_to_prisme
command:
docker exec suila-web python manage.py export_benefits_to_prisme --year=2023 --month=01
Note: The export_benefits_to_prisme
command requires that the calculate_benefit
command has been executed beforehand for the
year you want to export data to Prisme.
To run the tests run
docker exec suila-web bash -c 'coverage run manage.py test ; coverage combine ; coverage report --show-missing'
To run tests only in a specific file run
docker exec suila-web bash -c 'coverage run manage.py test data_analysis.tests.test_views'
To run type checks run:
docker exec suila-web mypy --config ../mypy.ini suila/