nixpkgs/nixos/tests/couchdb.nix

99 lines
2.9 KiB
Nix
Raw Normal View History

2020-04-04 11:20:03 +02:00
let
makeNode = couchpkg: user: passwd:
{ pkgs, ... } :
{ environment.systemPackages = with pkgs; [ jq ];
services.couchdb.enable = true;
services.couchdb.package = couchpkg;
services.couchdb.adminUser = user;
services.couchdb.adminPass = passwd;
};
testuser = "testadmin";
testpass = "cowabunga";
testlogin = "${testuser}:${testpass}@";
in import ./make-test-python.nix ({ pkgs, lib, ...}:
2017-11-19 17:36:47 +01:00
with lib;
{
name = "couchdb";
meta = with pkgs.stdenv.lib.maintainers; {
maintainers = [ fpletz ];
};
nodes = {
2020-04-04 11:20:03 +02:00
couchdb1 = makeNode pkgs.couchdb testuser testpass;
couchdb2 = makeNode pkgs.couchdb2 testuser testpass;
couchdb3 = makeNode pkgs.couchdb3 testuser testpass;
2017-11-19 17:36:47 +01:00
};
testScript = let
2020-04-04 11:20:03 +02:00
curlJqCheck = login: action: path: jqexpr: result:
2017-11-19 17:36:47 +01:00
pkgs.writeScript "curl-jq-check-${action}-${path}.sh" ''
2020-04-04 11:20:03 +02:00
RESULT=$(curl -X ${action} http://${login}127.0.0.1:5984/${path} | jq -r '${jqexpr}')
2017-11-19 17:36:47 +01:00
echo $RESULT >&2
if [ "$RESULT" != "${result}" ]; then
exit 1
fi
'';
in ''
2019-11-06 20:53:18 +01:00
start_all()
couchdb1.wait_for_unit("couchdb.service")
couchdb1.wait_until_succeeds(
2020-04-04 11:20:03 +02:00
"${curlJqCheck "" "GET" "" ".couchdb" "Welcome"}"
2019-11-06 20:53:18 +01:00
)
couchdb1.wait_until_succeeds(
2020-04-04 11:20:03 +02:00
"${curlJqCheck "" "GET" "_all_dbs" ". | length" "2"}"
2019-11-06 20:53:18 +01:00
)
2020-04-04 11:20:03 +02:00
couchdb1.succeed("${curlJqCheck testlogin "PUT" "foo" ".ok" "true"}")
2019-11-06 20:53:18 +01:00
couchdb1.succeed(
2020-04-04 11:20:03 +02:00
"${curlJqCheck "" "GET" "_all_dbs" ". | length" "3"}"
2019-11-06 20:53:18 +01:00
)
couchdb1.succeed(
2020-04-04 11:20:03 +02:00
"${curlJqCheck testlogin "DELETE" "foo" ".ok" "true"}"
2019-11-06 20:53:18 +01:00
)
couchdb1.succeed(
2020-04-04 11:20:03 +02:00
"${curlJqCheck "" "GET" "_all_dbs" ". | length" "2"}"
2019-11-06 20:53:18 +01:00
)
couchdb2.wait_for_unit("couchdb.service")
couchdb2.wait_until_succeeds(
2020-04-04 11:20:03 +02:00
"${curlJqCheck "" "GET" "" ".couchdb" "Welcome"}"
2019-11-06 20:53:18 +01:00
)
couchdb2.wait_until_succeeds(
2020-04-04 11:20:03 +02:00
"${curlJqCheck "" "GET" "_all_dbs" ". | length" "0"}"
2019-11-06 20:53:18 +01:00
)
2020-04-04 11:20:03 +02:00
couchdb2.succeed("${curlJqCheck testlogin "PUT" "foo" ".ok" "true"}")
2019-11-06 20:53:18 +01:00
couchdb2.succeed(
2020-04-04 11:20:03 +02:00
"${curlJqCheck "" "GET" "_all_dbs" ". | length" "1"}"
2019-11-06 20:53:18 +01:00
)
couchdb2.succeed(
2020-04-04 11:20:03 +02:00
"${curlJqCheck testlogin "DELETE" "foo" ".ok" "true"}"
2019-11-06 20:53:18 +01:00
)
couchdb2.succeed(
2020-04-04 11:20:03 +02:00
"${curlJqCheck "" "GET" "_all_dbs" ". | length" "0"}"
)
couchdb3.wait_for_unit("couchdb.service")
couchdb3.wait_until_succeeds(
"${curlJqCheck testlogin "GET" "" ".couchdb" "Welcome"}"
)
couchdb3.wait_until_succeeds(
"${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "0"}"
)
couchdb3.succeed("${curlJqCheck testlogin "PUT" "foo" ".ok" "true"}")
couchdb3.succeed(
"${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "1"}"
)
couchdb3.succeed(
"${curlJqCheck testlogin "DELETE" "foo" ".ok" "true"}"
)
couchdb3.succeed(
"${curlJqCheck testlogin "GET" "_all_dbs" ". | length" "0"}"
2019-11-06 20:53:18 +01:00
)
2017-11-19 17:36:47 +01:00
'';
})