nixpkgs/nixos/tests/solr.nix

57 lines
1.7 KiB
Nix
Raw Normal View History

2020-02-13 22:40:47 +01:00
import ./make-test-python.nix ({ pkgs, ... }:
2019-03-28 15:47:41 +01:00
2020-01-18 14:31:43 +01:00
{
name = "solr";
meta.maintainers = [ pkgs.lib.maintainers.aanderse ];
2020-01-18 14:31:43 +01:00
machine =
{ config, pkgs, ... }:
{
# Ensure the virtual machine has enough memory for Solr to avoid the following error:
#
# OpenJDK 64-Bit Server VM warning:
# INFO: os::commit_memory(0x00000000e8000000, 402653184, 0)
# failed; error='Cannot allocate memory' (errno=12)
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (mmap) failed to map 402653184 bytes for committing reserved memory.
virtualisation.memorySize = 2000;
2020-01-18 14:31:43 +01:00
services.solr.enable = true;
};
2020-01-18 14:31:43 +01:00
testScript = ''
2020-02-13 22:40:47 +01:00
start_all()
2019-03-28 15:47:41 +01:00
2020-02-13 22:40:47 +01:00
machine.wait_for_unit("solr.service")
machine.wait_for_open_port(8983)
machine.succeed("curl --fail http://localhost:8983/solr/")
2020-01-18 14:31:43 +01:00
# adapted from pkgs.solr/examples/films/README.txt
2020-02-13 22:40:47 +01:00
machine.succeed("sudo -u solr solr create -c films")
assert '"status":0' in machine.succeed(
"""
curl http://localhost:8983/solr/films/schema -X POST -H 'Content-type:application/json' --data-binary '{
"add-field" : {
"name":"name",
"type":"text_general",
"multiValued":false,
"stored":true
},
"add-field" : {
"name":"initial_release_date",
"type":"pdate",
"stored":true
}
}'
"""
)
machine.succeed(
"sudo -u solr post -c films ${pkgs.solr}/example/films/films.json"
)
assert '"name":"Batman Begins"' in machine.succeed(
"curl http://localhost:8983/solr/films/query?q=name:batman"
)
2020-01-18 14:31:43 +01:00
'';
})