1import ./make-test-python.nix ({ lib, ... }: {
2 name = "paperless";
3 meta.maintainers = with lib.maintainers; [ erikarvstedt Flakebi ];
4
5 nodes.machine = { pkgs, ... }: {
6 environment.systemPackages = with pkgs; [ imagemagick jq ];
7 services.paperless = {
8 enable = true;
9 passwordFile = builtins.toFile "password" "admin";
10 };
11 };
12
13 testScript = ''
14 import json
15
16 machine.wait_for_unit("paperless-consumer.service")
17
18 with subtest("Add a document via the file system"):
19 machine.succeed(
20 "convert -size 400x40 xc:white -font 'DejaVu-Sans' -pointsize 20 -fill black "
21 "-annotate +5+20 'hello world 16-10-2005' /var/lib/paperless/consume/doc.png"
22 )
23
24 with subtest("Web interface gets ready"):
25 machine.wait_for_unit("paperless-web.service")
26 # Wait until server accepts connections
27 machine.wait_until_succeeds("curl -fs localhost:28981")
28
29 # Required for consuming documents via the web interface
30 with subtest("Task-queue gets ready"):
31 machine.wait_for_unit("paperless-task-queue.service")
32
33 with subtest("Add a document via the web interface"):
34 machine.succeed(
35 "convert -size 400x40 xc:white -font 'DejaVu-Sans' -pointsize 20 -fill black "
36 "-annotate +5+20 'hello web 16-10-2005' /tmp/webdoc.png"
37 )
38 machine.wait_until_succeeds("curl -u admin:admin -F document=@/tmp/webdoc.png -fs localhost:28981/api/documents/post_document/")
39
40 with subtest("Documents are consumed"):
41 machine.wait_until_succeeds(
42 "(($(curl -u admin:admin -fs localhost:28981/api/documents/ | jq .count) == 2))"
43 )
44 docs = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/"))['results']
45 assert "2005-10-16" in docs[0]['created']
46 assert "2005-10-16" in docs[1]['created']
47
48 # Detects gunicorn issues, see PR #190888
49 with subtest("Document metadata can be accessed"):
50 metadata = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/1/metadata/"))
51 assert "original_checksum" in metadata
52
53 metadata = json.loads(machine.succeed("curl -u admin:admin -fs localhost:28981/api/documents/2/metadata/"))
54 assert "original_checksum" in metadata
55 '';
56})