Loading nixos/tests/paperless.nix +58 −35 Original line number Diff line number Diff line Loading @@ -2,65 +2,88 @@ import ./make-test-python.nix ({ lib, ... }: { name = "paperless"; meta.maintainers = with lib.maintainers; [ erikarvstedt Flakebi ]; nodes.machine = { pkgs, ... }: { nodes = let self = { simple = { pkgs, ... }: { environment.systemPackages = with pkgs; [ imagemagick jq ]; services.paperless = { enable = true; passwordFile = builtins.toFile "password" "admin"; }; }; postgres = { config, pkgs, ... }: { imports = [ self.simple ]; services.postgresql = { enable = true; ensureDatabases = [ "paperless" ]; ensureUsers = [ { name = config.services.paperless.user; ensurePermissions = { "DATABASE \"paperless\"" = "ALL PRIVILEGES"; }; } ]; }; services.paperless.extraConfig = { PAPERLESS_DBHOST = "/run/postgresql"; }; }; }; in self; testScript = '' import json machine.wait_for_unit("paperless-consumer.service") def test_paperless(node): node.wait_for_unit("paperless-consumer.service") with subtest("Add a document via the file system"): machine.succeed( node.succeed( "convert -size 400x40 xc:white -font 'DejaVu-Sans' -pointsize 20 -fill black " "-annotate +5+20 'hello world 16-10-2005' /var/lib/paperless/consume/doc.png" ) with subtest("Web interface gets ready"): machine.wait_for_unit("paperless-web.service") node.wait_for_unit("paperless-web.service") # Wait until server accepts connections machine.wait_until_succeeds("curl -fs localhost:28981") node.wait_until_succeeds("curl -fs localhost:28981") # Required for consuming documents via the web interface with subtest("Task-queue gets ready"): machine.wait_for_unit("paperless-task-queue.service") node.wait_for_unit("paperless-task-queue.service") with subtest("Add a png document via the web interface"): machine.succeed( node.succeed( "convert -size 400x40 xc:white -font 'DejaVu-Sans' -pointsize 20 -fill black " "-annotate +5+20 'hello web 16-10-2005' /tmp/webdoc.png" ) machine.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.png -fs localhost:28981/api/documents/post_document/") node.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.png -fs localhost:28981/api/documents/post_document/") with subtest("Add a txt document via the web interface"): machine.succeed( node.succeed( "echo 'hello web 16-10-2005' > /tmp/webdoc.txt" ) machine.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.txt -fs localhost:28981/api/documents/post_document/") node.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.txt -fs localhost:28981/api/documents/post_document/") with subtest("Documents are consumed"): machine.wait_until_succeeds( node.wait_until_succeeds( "(($(curl -u admin:admin -fs localhost:28981/api/documents/ | jq .count) == 3))" ) docs = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/"))['results'] docs = json.loads(node.succeed("curl -u admin:admin -fs localhost:28981/api/documents/"))['results'] assert "2005-10-16" in docs[0]['created'] assert "2005-10-16" in docs[1]['created'] assert "2005-10-16" in docs[2]['created'] # Detects gunicorn issues, see PR #190888 with subtest("Document metadata can be accessed"): metadata = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/1/metadata/")) metadata = json.loads(node.succeed("curl -u admin:admin -fs localhost:28981/api/documents/1/metadata/")) assert "original_checksum" in metadata metadata = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/2/metadata/")) metadata = json.loads(node.succeed("curl -u admin:admin -fs localhost:28981/api/documents/2/metadata/")) assert "original_checksum" in metadata metadata = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/3/metadata/")) metadata = json.loads(node.succeed("curl -u admin:admin -fs localhost:28981/api/documents/3/metadata/")) assert "original_checksum" in metadata test_paperless(simple) simple.send_monitor_command("quit") simple.wait_for_shutdown() test_paperless(postgres) ''; }) Loading
nixos/tests/paperless.nix +58 −35 Original line number Diff line number Diff line Loading @@ -2,65 +2,88 @@ import ./make-test-python.nix ({ lib, ... }: { name = "paperless"; meta.maintainers = with lib.maintainers; [ erikarvstedt Flakebi ]; nodes.machine = { pkgs, ... }: { nodes = let self = { simple = { pkgs, ... }: { environment.systemPackages = with pkgs; [ imagemagick jq ]; services.paperless = { enable = true; passwordFile = builtins.toFile "password" "admin"; }; }; postgres = { config, pkgs, ... }: { imports = [ self.simple ]; services.postgresql = { enable = true; ensureDatabases = [ "paperless" ]; ensureUsers = [ { name = config.services.paperless.user; ensurePermissions = { "DATABASE \"paperless\"" = "ALL PRIVILEGES"; }; } ]; }; services.paperless.extraConfig = { PAPERLESS_DBHOST = "/run/postgresql"; }; }; }; in self; testScript = '' import json machine.wait_for_unit("paperless-consumer.service") def test_paperless(node): node.wait_for_unit("paperless-consumer.service") with subtest("Add a document via the file system"): machine.succeed( node.succeed( "convert -size 400x40 xc:white -font 'DejaVu-Sans' -pointsize 20 -fill black " "-annotate +5+20 'hello world 16-10-2005' /var/lib/paperless/consume/doc.png" ) with subtest("Web interface gets ready"): machine.wait_for_unit("paperless-web.service") node.wait_for_unit("paperless-web.service") # Wait until server accepts connections machine.wait_until_succeeds("curl -fs localhost:28981") node.wait_until_succeeds("curl -fs localhost:28981") # Required for consuming documents via the web interface with subtest("Task-queue gets ready"): machine.wait_for_unit("paperless-task-queue.service") node.wait_for_unit("paperless-task-queue.service") with subtest("Add a png document via the web interface"): machine.succeed( node.succeed( "convert -size 400x40 xc:white -font 'DejaVu-Sans' -pointsize 20 -fill black " "-annotate +5+20 'hello web 16-10-2005' /tmp/webdoc.png" ) machine.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.png -fs localhost:28981/api/documents/post_document/") node.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.png -fs localhost:28981/api/documents/post_document/") with subtest("Add a txt document via the web interface"): machine.succeed( node.succeed( "echo 'hello web 16-10-2005' > /tmp/webdoc.txt" ) machine.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.txt -fs localhost:28981/api/documents/post_document/") node.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.txt -fs localhost:28981/api/documents/post_document/") with subtest("Documents are consumed"): machine.wait_until_succeeds( node.wait_until_succeeds( "(($(curl -u admin:admin -fs localhost:28981/api/documents/ | jq .count) == 3))" ) docs = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/"))['results'] docs = json.loads(node.succeed("curl -u admin:admin -fs localhost:28981/api/documents/"))['results'] assert "2005-10-16" in docs[0]['created'] assert "2005-10-16" in docs[1]['created'] assert "2005-10-16" in docs[2]['created'] # Detects gunicorn issues, see PR #190888 with subtest("Document metadata can be accessed"): metadata = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/1/metadata/")) metadata = json.loads(node.succeed("curl -u admin:admin -fs localhost:28981/api/documents/1/metadata/")) assert "original_checksum" in metadata metadata = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/2/metadata/")) metadata = json.loads(node.succeed("curl -u admin:admin -fs localhost:28981/api/documents/2/metadata/")) assert "original_checksum" in metadata metadata = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/3/metadata/")) metadata = json.loads(node.succeed("curl -u admin:admin -fs localhost:28981/api/documents/3/metadata/")) assert "original_checksum" in metadata test_paperless(simple) simple.send_monitor_command("quit") simple.wait_for_shutdown() test_paperless(postgres) ''; })