-
Tom Prince authoredTom Prince authored
Developer documentation
Building
The build system uses Nix which must be installed before anything can be built. Start by setting up the development/operations environment:
$ nix-shell
Testing
The test system uses Nix which must be installed before any tests can be run.
Unit tests are run using this command:
$ nix-build nixos/unit-tests.nix
Unit tests are also run on CI.
The system tests are run using this command:
$ nix-build nixos/system-tests.nix
The system tests boot QEMU VMs which prevents them from running on CI at this time. The build requires > 10 GB of disk space, and the VMs might be timing out on slow or busy machines. If you run into timeouts, try raising the number of retries.
It is also possible go through the testing script interactively - useful for debugging:
$ nix-build -A private-storage.driver nixos/system-tests.nix
This will give you a result symlink in the current directory. Inside that is bin/nixos-test-driver which gives you a kind of REPL for interacting with the VMs. The kind of Python in this testScript is what you can enter into this REPL. Consult the official documentation on NixOS Tests for more information.