nixpkgs/nixos/tests/evcc.nix

108 lines
2.9 KiB
Nix
Raw Normal View History

import ./make-test-python.nix (
{ pkgs, lib, ... }:
2021-07-27 13:14:24 +00:00
{
name = "evcc";
meta.maintainers = with lib.maintainers; [ hexa ];
2021-07-27 13:14:24 +00:00
nodes = {
machine =
{ config, ... }:
{
services.evcc = {
enable = true;
settings = {
network = {
schema = "http";
host = "localhost";
port = 7070;
};
2021-07-27 13:14:24 +00:00
log = "info";
2021-07-27 13:14:24 +00:00
site = {
title = "NixOS Test";
meters = {
grid = "grid";
pv = "pv";
};
};
2021-07-27 13:14:24 +00:00
meters = [
{
type = "custom";
name = "grid";
power = {
source = "script";
cmd = "/bin/sh -c 'echo -4500'";
};
}
{
type = "custom";
name = "pv";
power = {
source = "script";
cmd = "/bin/sh -c 'echo 7500'";
};
}
];
2021-07-27 13:14:24 +00:00
chargers = [
{
name = "dummy-charger";
type = "custom";
status = {
source = "script";
cmd = "/bin/sh -c 'echo charger status A'";
};
enabled = {
source = "script";
cmd = "/bin/sh -c 'echo charger enabled state false'";
};
enable = {
source = "script";
cmd = "/bin/sh -c 'echo set charger enabled state true'";
};
maxcurrent = {
source = "script";
cmd = "/bin/sh -c 'echo set charger max current 7200'";
};
}
];
2021-07-27 13:14:24 +00:00
loadpoints = [
{
title = "Dummy";
charger = "dummy-charger";
}
];
};
};
2021-07-27 13:14:24 +00:00
};
};
testScript = ''
start_all()
2021-07-27 13:14:24 +00:00
machine.wait_for_unit("evcc.service")
machine.wait_for_open_port(7070)
2021-07-27 13:14:24 +00:00
with subtest("Check package version propagates into frontend"):
machine.fail(
"curl --fail http://localhost:7070 | grep '0.0.1-alpha'"
)
machine.succeed(
"curl --fail http://localhost:7070 | grep '${pkgs.evcc.version}'"
)
2021-07-27 13:14:24 +00:00
with subtest("Check journal for errors"):
_, output = machine.execute("journalctl -o cat -u evcc.service")
assert "FATAL" not in output
2021-07-27 13:14:24 +00:00
with subtest("Check systemd hardening"):
_, output = machine.execute("systemd-analyze security evcc.service | grep -v ''")
machine.log(output)
'';
}
)