mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-06-09 19:13:26 +03:00
parent
79a8a723b9
commit
6a31e09833
2 changed files with 65 additions and 67 deletions
|
@ -551,7 +551,7 @@ in
|
|||
grav = runTest ./web-apps/grav.nix;
|
||||
graylog = handleTest ./graylog.nix { };
|
||||
greetd-no-shadow = handleTest ./greetd-no-shadow.nix { };
|
||||
grocy = handleTest ./grocy.nix { };
|
||||
grocy = runTest ./grocy.nix;
|
||||
grow-partition = runTest ./grow-partition.nix;
|
||||
grub = handleTest ./grub.nix { };
|
||||
guacamole-server = handleTest ./guacamole-server.nix { };
|
||||
|
|
|
@ -1,81 +1,79 @@
|
|||
import ./make-test-python.nix (
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
name = "grocy";
|
||||
meta = with pkgs.lib.maintainers; {
|
||||
maintainers = [ ma27 ];
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
name = "grocy";
|
||||
meta = with pkgs.lib.maintainers; {
|
||||
maintainers = [ ma27 ];
|
||||
};
|
||||
|
||||
nodes.machine =
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
services.grocy = {
|
||||
enable = true;
|
||||
hostName = "localhost";
|
||||
nginx.enableSSL = false;
|
||||
};
|
||||
environment.systemPackages = [ pkgs.jq ];
|
||||
};
|
||||
|
||||
nodes.machine =
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
services.grocy = {
|
||||
enable = true;
|
||||
hostName = "localhost";
|
||||
nginx.enableSSL = false;
|
||||
};
|
||||
environment.systemPackages = [ pkgs.jq ];
|
||||
};
|
||||
testScript = ''
|
||||
from base64 import b64encode
|
||||
from urllib.parse import quote
|
||||
|
||||
testScript = ''
|
||||
from base64 import b64encode
|
||||
from urllib.parse import quote
|
||||
machine.start()
|
||||
machine.wait_for_open_port(80)
|
||||
machine.wait_for_unit("multi-user.target")
|
||||
|
||||
machine.start()
|
||||
machine.wait_for_open_port(80)
|
||||
machine.wait_for_unit("multi-user.target")
|
||||
# This establishes _something_
|
||||
machine.succeed("curl -sSf http://localhost")
|
||||
# The second request creates the database, unsure why both are required
|
||||
machine.succeed("curl -sSf http://localhost/")
|
||||
|
||||
# This establishes _something_
|
||||
machine.succeed("curl -sSf http://localhost")
|
||||
# The second request creates the database, unsure why both are required
|
||||
machine.succeed("curl -sSf http://localhost/")
|
||||
machine.succeed(
|
||||
"curl -c cookies -sSf -X POST http://localhost/login -d 'username=admin&password=admin'"
|
||||
)
|
||||
|
||||
machine.succeed(
|
||||
"curl -c cookies -sSf -X POST http://localhost/login -d 'username=admin&password=admin'"
|
||||
)
|
||||
cookie = machine.succeed(
|
||||
"grep -v '^#' cookies | awk '{ print $7 }' | sed -e '/^$/d' | perl -pe 'chomp'"
|
||||
)
|
||||
|
||||
cookie = machine.succeed(
|
||||
"grep -v '^#' cookies | awk '{ print $7 }' | sed -e '/^$/d' | perl -pe 'chomp'"
|
||||
)
|
||||
machine.succeed(
|
||||
f"curl -sSf -X POST http://localhost/api/objects/tasks -b 'grocy_session={cookie}' "
|
||||
+ '-d \'{"assigned_to_user_id":1,"name":"Test Task","due_date":"1970-01-01"}\'''
|
||||
+ " --header 'Content-Type: application/json'"
|
||||
)
|
||||
|
||||
machine.succeed(
|
||||
f"curl -sSf -X POST http://localhost/api/objects/tasks -b 'grocy_session={cookie}' "
|
||||
+ '-d \'{"assigned_to_user_id":1,"name":"Test Task","due_date":"1970-01-01"}\'''
|
||||
+ " --header 'Content-Type: application/json'"
|
||||
)
|
||||
task_name = machine.succeed(
|
||||
f"curl -sSf http://localhost/api/tasks -b 'grocy_session={cookie}' --header 'Accept: application/json' | jq '.[].name' | xargs echo | perl -pe 'chomp'"
|
||||
)
|
||||
|
||||
task_name = machine.succeed(
|
||||
f"curl -sSf http://localhost/api/tasks -b 'grocy_session={cookie}' --header 'Accept: application/json' | jq '.[].name' | xargs echo | perl -pe 'chomp'"
|
||||
)
|
||||
assert task_name == "Test Task"
|
||||
|
||||
assert task_name == "Test Task"
|
||||
machine.succeed("curl -sSI http://localhost/api/tasks 2>&1 | grep '401 Unauthorized'")
|
||||
|
||||
machine.succeed("curl -sSI http://localhost/api/tasks 2>&1 | grep '401 Unauthorized'")
|
||||
file_name = "test.txt"
|
||||
file_name_base64 = b64encode(file_name.encode('ascii')).decode('ascii')
|
||||
file_name_base64_urlencode = quote(file_name_base64)
|
||||
|
||||
file_name = "test.txt"
|
||||
file_name_base64 = b64encode(file_name.encode('ascii')).decode('ascii')
|
||||
file_name_base64_urlencode = quote(file_name_base64)
|
||||
machine.succeed(
|
||||
f"echo Sample equipment manual > /tmp/{file_name}"
|
||||
)
|
||||
|
||||
machine.succeed(
|
||||
f"echo Sample equipment manual > /tmp/{file_name}"
|
||||
)
|
||||
machine.succeed(
|
||||
f"curl -sSf -X 'PUT' -b 'grocy_session={cookie}' "
|
||||
+ f" 'http://localhost/api/files/equipmentmanuals/{file_name_base64_urlencode}' "
|
||||
+ " --header 'Accept: */*' "
|
||||
+ " --header 'Content-Type: application/octet-stream' "
|
||||
+ f" --data-binary '@/tmp/{file_name}' "
|
||||
)
|
||||
|
||||
machine.succeed(
|
||||
f"curl -sSf -X 'PUT' -b 'grocy_session={cookie}' "
|
||||
+ f" 'http://localhost/api/files/equipmentmanuals/{file_name_base64_urlencode}' "
|
||||
+ " --header 'Accept: */*' "
|
||||
+ " --header 'Content-Type: application/octet-stream' "
|
||||
+ f" --data-binary '@/tmp/{file_name}' "
|
||||
)
|
||||
machine.succeed(
|
||||
f"curl -sSf -X 'GET' -b 'grocy_session={cookie}' "
|
||||
+ f" 'http://localhost/api/files/equipmentmanuals/{file_name_base64_urlencode}' "
|
||||
+ " --header 'Accept: application/octet-stream' "
|
||||
+ f" | cmp /tmp/{file_name}"
|
||||
)
|
||||
|
||||
machine.succeed(
|
||||
f"curl -sSf -X 'GET' -b 'grocy_session={cookie}' "
|
||||
+ f" 'http://localhost/api/files/equipmentmanuals/{file_name_base64_urlencode}' "
|
||||
+ " --header 'Accept: application/octet-stream' "
|
||||
+ f" | cmp /tmp/{file_name}"
|
||||
)
|
||||
|
||||
machine.shutdown()
|
||||
'';
|
||||
}
|
||||
)
|
||||
machine.shutdown()
|
||||
'';
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue