The official backend of Bootstrap Academy.
If you would like to submit a bug report or feature request, or are looking for general information about the project or the publicly available instances, please refer to the Bootstrap-Academy repository.
- Install Nix with flakes enabled:
- If you are on NixOS, just ensure that flakes are enabled by setting
nix.settings.experimental-features = ["nix-command" "flakes"];inconfiguration.nix. - If you are using a different Linux distribution or OS, follow the instructions on https://nixos.org/download/ and add the line
experimental-features = nix-command flakesto/etc/nix/nix.confto enable flakes.
- If you are on NixOS, just ensure that flakes are enabled by setting
- Add your user to the
trusted-usersNix option (replaceYOUR_USERNAMEwith the actual name of the user account you use for development):- If you are on NixOS, set
nix.settings.trusted-users = ["root" "YOUR_USERNAME"];inconfiguration.nix. - If you are using a different Linux distribution or OS, add the line
trusted-users = root YOUR_USERNAMEto/etc/nix/nix.confand runsudo systemctl restart nix-daemon.
- If you are on NixOS, set
- Install direnv (optional, but strongly recommended):
- If you are on NixOS, set
programs.direnv.enable = true;inconfiguration.nix. - If you are using a different Linux distribution or OS, run the command
nix profile add nixpkgs#direnv. Don't forget to install the shell hook (e.g. for bash runecho 'eval "$(direnv hook bash)"' >> ~/.bashrc).
- If you are on NixOS, set
- Clone this repository and
cdinto it. - If you installed direnv, run
direnv allowto automatically load the development environment when entering this repository. Otherwise you need to runnix develop --no-pure-evalmanually each time to enter the development shell. - Run
devenv upto start a local Postgres database, Valkey cache, SMTP server and some other services needed by the backend. - In a different terminal, you can now run
cargo run -- serve. By default, the Swagger UI documentation is now available on http://127.0.0.1:8000/docs
You can set the following additional environment variables to customize the development environment.
If you use direnv, create a file with the name .env in the repository root with NAME=VALUE pairs on each line.
Otherwise you need to set these variables manually.
DEVENV_RUST: Set to0if you already have a Rust toolchain installed which you would like to use instead of the one provided by devenv.RUST_LOG: Set the tracing filter (log level). See thetracing-subscriberdocs for details.RUST_LOG_PRETTY: Set to0to use the single-line instead of the multi-line log format.
For development in VSCode/VSCodium, simply open this repository, install the recommended extensions and confirm restarting the extensions after direnv successfully initialized.
psql: Connect to the local Postgres databasevalkey-cli: Connect to the local Valkey cachecargo run -- --help: List all commands provided by the backend CLIjust: List all recipes provided by thejustfilegenerate: RegenerateCargo.nix. Run this command after changing anyCargo.tomlorCargo.lockfile.generate-clorinde: Regenerateacademy_persistence/postgres/clorinde. Run this command after changing the database schema or the queries inacademy_persistence/postgres/queries.
- The web interface of smtp4dev is available on http://localhost:5000/
- Various services for mocking external APIs are running on ports starting at 8001. See the logs of the
testing-*services indevenv upfor details.
This repository contains three different kinds of tests: Unit tests, integration tests and system tests.
Unit tests test only one unit (i.e. function in most cases) at a time and do not rely on any external systems.
To run the unit tests, use the command just test-unit.
Integration tests are used to test the integration with other systems such as external APIs or databases.
To run the integration tests, use the corresponding just recipes (e.g. to run the Postgres tests execute just test-postgres).
To run all unit and integration tests, use the command just test.
It is also possible to generate coverage reports by replacing test with coverage in any of the previous commands.
System tests are used to test a production build of the backend in an environment that is as realistic as possible (with some exceptions).
For that we use the NixOS test framework which spawns virtual machines containing a minimal NixOS system running the backend and then runs test scripts written in Python against these VMs.
To run the system tests, use the command nix build -L .#tests.composite (if you are on darwin, you may need to set up a linux builder).
You can also run individual system tests e.g. using nix build -L .#tests.user.