diff options
author | Guillaume Girol <symphorien+git@xlumurb.eu> | 2021-10-10 12:00:00 +0000 |
---|---|---|
committer | Guillaume Girol <symphorien+git@xlumurb.eu> | 2021-10-28 18:37:11 +0200 |
commit | e28414b63dd4161e3d8f32a6779fe2df52091302 (patch) | |
tree | 8cb634ad9a7a2d875014b7d05dcc0004ab99488f /nixos/tests/ihatemoney/default.nix | |
parent | 076ffa9cf0732de37e92c4dfbe8c0eb1a5169cbe (diff) | |
download | nixpkgs-e28414b63dd4161e3d8f32a6779fe2df52091302.tar nixpkgs-e28414b63dd4161e3d8f32a6779fe2df52091302.tar.gz nixpkgs-e28414b63dd4161e3d8f32a6779fe2df52091302.tar.bz2 nixpkgs-e28414b63dd4161e3d8f32a6779fe2df52091302.tar.lz nixpkgs-e28414b63dd4161e3d8f32a6779fe2df52091302.tar.xz nixpkgs-e28414b63dd4161e3d8f32a6779fe2df52091302.tar.zst nixpkgs-e28414b63dd4161e3d8f32a6779fe2df52091302.zip |
python3.pkgs.ihatemoney: 4.2 -> 5.1.1
Diffstat (limited to 'nixos/tests/ihatemoney/default.nix')
-rw-r--r-- | nixos/tests/ihatemoney/default.nix | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/nixos/tests/ihatemoney/default.nix b/nixos/tests/ihatemoney/default.nix new file mode 100644 index 00000000000..78278d2e869 --- /dev/null +++ b/nixos/tests/ihatemoney/default.nix @@ -0,0 +1,78 @@ +{ system ? builtins.currentSystem, + config ? {}, + pkgs ? import ../../.. { inherit system config; } +}: + +let + inherit (import ../../lib/testing-python.nix { inherit system pkgs; }) makeTest; + f = backend: makeTest { + name = "ihatemoney-${backend}"; + machine = { nodes, lib, ... }: { + services.ihatemoney = { + enable = true; + enablePublicProjectCreation = true; + secureCookie = false; + inherit backend; + uwsgiConfig = { + http = ":8000"; + }; + }; + boot.cleanTmpDir = true; + # for exchange rates + security.pki.certificateFiles = [ ./server.crt ]; + networking.extraHosts = "127.0.0.1 api.exchangerate.host"; + services.nginx = { + enable = true; + virtualHosts."api.exchangerate.host" = { + addSSL = true; + # openssl req -x509 -newkey rsa:4096 -keyout server.key -out server.crt -days 1000000 -nodes -subj '/CN=api.exchangerate.host' + sslCertificate = ./server.crt; + sslCertificateKey = ./server.key; + locations."/".return = "200 '${builtins.readFile ./rates.json}'"; + }; + }; + # ihatemoney needs a local smtp server otherwise project creation just crashes + services.opensmtpd = { + enable = true; + serverConfiguration = '' + listen on lo + action foo relay + match from any for any action foo + ''; + }; + }; + testScript = '' + machine.wait_for_open_port(8000) + machine.wait_for_unit("uwsgi.service") + machine.wait_until_succeeds("curl --fail https://api.exchangerate.host") + machine.wait_until_succeeds("curl --fail http://localhost:8000") + + result = machine.succeed( + "curl --fail -X POST http://localhost:8000/api/projects -d 'name=yay&id=yay&password=yay&contact_email=yay@example.com&default_currency=XXX'" + ) + assert '"yay"' in result, repr(result) + owner, timestamp = machine.succeed( + "stat --printf %U:%G___%Y /var/lib/ihatemoney/secret_key" + ).split("___") + assert "ihatemoney:ihatemoney" == owner + + with subtest("Restart machine and service"): + machine.shutdown() + machine.start() + machine.wait_for_open_port(8000) + machine.wait_for_unit("uwsgi.service") + + with subtest("check that the database is really persistent"): + machine.succeed("curl --fail --basic -u yay:yay http://localhost:8000/api/projects/yay") + + with subtest("check that the secret key is really persistent"): + timestamp2 = machine.succeed("stat --printf %Y /var/lib/ihatemoney/secret_key") + assert timestamp == timestamp2 + + assert "ihatemoney" in machine.succeed("curl --fail http://localhost:8000") + ''; + }; +in { + ihatemoney-sqlite = f "sqlite"; + ihatemoney-postgresql = f "postgresql"; +} |