mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-22 23:13:19 +00:00
hiawatha: Add package test
Tests whether curl can communicate with hiawatha via http and https.
This commit is contained in:
parent
d7cfd8c029
commit
c2928b54bc
@ -1,5 +1,6 @@
|
|||||||
{ lib, stdenv
|
{ lib, stdenv
|
||||||
, fetchFromGitLab
|
, fetchFromGitLab
|
||||||
|
, callPackage
|
||||||
|
|
||||||
, cmake
|
, cmake
|
||||||
, ninja
|
, ninja
|
||||||
@ -16,14 +17,14 @@
|
|||||||
, enableToolkit ? true # The URL Toolkit.
|
, enableToolkit ? true # The URL Toolkit.
|
||||||
}:
|
}:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation (finalAttrs: {
|
||||||
pname = "hiawatha";
|
pname = "hiawatha";
|
||||||
version = "10.11";
|
version = "10.11";
|
||||||
|
|
||||||
src = fetchFromGitLab {
|
src = fetchFromGitLab {
|
||||||
owner = "hsleisink";
|
owner = "hsleisink";
|
||||||
repo = "hiawatha";
|
repo = "hiawatha";
|
||||||
rev = "v${version}";
|
rev = "v${finalAttrs.version}";
|
||||||
sha256 = "10a7dqj37zrbmgnhwsw0mqm5x25kasl8p95g01rzakviwxkdrkid";
|
sha256 = "10a7dqj37zrbmgnhwsw0mqm5x25kasl8p95g01rzakviwxkdrkid";
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -46,12 +47,18 @@ stdenv.mkDerivation rec {
|
|||||||
( if enableToolkit then "-DENABLE_TOOLKIT=on" else "-DENABLE_TOOLKIT=off" )
|
( if enableToolkit then "-DENABLE_TOOLKIT=on" else "-DENABLE_TOOLKIT=off" )
|
||||||
];
|
];
|
||||||
|
|
||||||
|
passthru.tests.serve-static-files = callPackage ./test.nix {
|
||||||
|
hiawatha = finalAttrs.finalPackage;
|
||||||
|
inherit enableTls;
|
||||||
|
};
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
homepage = "https://www.hiawatha-webserver.org";
|
homepage = "https://www.hiawatha-webserver.org";
|
||||||
description = "Advanced and secure webserver";
|
description = "Advanced and secure webserver";
|
||||||
license = licenses.gpl2Only;
|
license = licenses.gpl2Only;
|
||||||
platforms = platforms.unix; # "Hiawatha runs perfectly on Linux, BSD and MacOS X"
|
platforms = platforms.unix; # "Hiawatha runs perfectly on Linux, BSD and MacOS X"
|
||||||
|
mainProgram = "hiawatha";
|
||||||
maintainers = [];
|
maintainers = [];
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
})
|
||||||
|
84
pkgs/servers/http/hiawatha/test.nix
Normal file
84
pkgs/servers/http/hiawatha/test.nix
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
{ lib
|
||||||
|
, stdenvNoCC
|
||||||
|
, hiawatha
|
||||||
|
, curl
|
||||||
|
, mbedtls
|
||||||
|
, enableTls
|
||||||
|
}:
|
||||||
|
|
||||||
|
stdenvNoCC.mkDerivation {
|
||||||
|
name = "hiawatha-test";
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
hiawatha
|
||||||
|
curl
|
||||||
|
] ++ lib.optional enableTls mbedtls;
|
||||||
|
|
||||||
|
env = {
|
||||||
|
inherit enableTls;
|
||||||
|
};
|
||||||
|
|
||||||
|
buildCommand = ''
|
||||||
|
cp -r --no-preserve=mode ${hiawatha}/etc/hiawatha config
|
||||||
|
sed "1i set TEST_DIR = $(pwd)" $serverConfigPath > config/hiawatha.conf
|
||||||
|
|
||||||
|
mkdir www
|
||||||
|
echo "it works" > www/index.html
|
||||||
|
|
||||||
|
if [ -n "$enableTls" ]; then
|
||||||
|
echo "Generating self-signed certificate"
|
||||||
|
gen_key type=ec filename=server.key
|
||||||
|
cert_write selfsign=1 issuer_key=server.key output_file=server.crt
|
||||||
|
cat server.crt server.key > config/server.crt
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Checking server configuration"
|
||||||
|
hiawatha -c ./config -k
|
||||||
|
|
||||||
|
echo "Starting server"
|
||||||
|
hiawatha -c ./config
|
||||||
|
|
||||||
|
testUrl() {
|
||||||
|
echo "Testing $1"
|
||||||
|
curl --verbose --insecure --fail "$1" | tee response
|
||||||
|
grep -q "it works" response
|
||||||
|
}
|
||||||
|
|
||||||
|
testUrl http://127.0.0.1:8000
|
||||||
|
if [ -n "$enableTls" ]; then
|
||||||
|
testUrl https://127.0.0.1:8443
|
||||||
|
fi
|
||||||
|
|
||||||
|
touch $out
|
||||||
|
'';
|
||||||
|
|
||||||
|
serverConfig = ''
|
||||||
|
# By default the server uses read-only directories like /var/lib and /etc
|
||||||
|
WorkDirectory = TEST_DIR
|
||||||
|
PIDfile = TEST_DIR/hiawatha.pid
|
||||||
|
SystemLogfile = TEST_DIR/system.log
|
||||||
|
GarbageLogfile = TEST_DIR/garbage.log
|
||||||
|
ExploitLogfile = TEST_DIR/exploit.log
|
||||||
|
AccessLogfile = TEST_DIR/access.log
|
||||||
|
ErrorLogfile = TEST_DIR/error.log
|
||||||
|
|
||||||
|
Binding {
|
||||||
|
Interface = 127.0.0.1
|
||||||
|
Port = 8000
|
||||||
|
}
|
||||||
|
|
||||||
|
${lib.optionalString enableTls ''
|
||||||
|
Binding {
|
||||||
|
Interface = 127.0.0.1
|
||||||
|
Port = 8443
|
||||||
|
TLScertFile = TEST_DIR/config/server.crt
|
||||||
|
}
|
||||||
|
''}
|
||||||
|
|
||||||
|
Hostname = 127.0.0.1
|
||||||
|
WebsiteRoot = TEST_DIR/www
|
||||||
|
StartFile = index.html
|
||||||
|
'';
|
||||||
|
|
||||||
|
passAsFile = [ "serverConfig" ];
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user