Skip to content
Snippets Groups Projects

PrivateStorageio

The backend for a private, secure, and end-to-end encrypted storage solution

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

Documentation

The documentation can be built using this command:

$ nix-build docs.nix

The documentation is also built on and published by CI.

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:

$ sudo --preserve-env 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:

$ sudo --preserve-env 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 Perl in this testScript is what you can enter into this REPL.

Deployment

See morph/README.rst.