2020-01-09 10:19:54 +00:00
|
|
|
import ./make-test-python.nix ({ pkgs, ... }:
|
2018-01-26 00:41:36 +00:00
|
|
|
|
|
|
|
let
|
|
|
|
configDir = "/var/lib/foobar";
|
2020-06-20 11:05:30 +01:00
|
|
|
mqttPassword = "secret";
|
2018-01-26 00:41:36 +00:00
|
|
|
in {
|
|
|
|
name = "home-assistant";
|
2018-02-17 18:24:20 +00:00
|
|
|
meta = with pkgs.stdenv.lib; {
|
|
|
|
maintainers = with maintainers; [ dotlambda ];
|
|
|
|
};
|
2018-01-26 00:41:36 +00:00
|
|
|
|
2020-06-20 11:05:30 +01:00
|
|
|
nodes.hass = { pkgs, ... }: {
|
|
|
|
environment.systemPackages = with pkgs; [ mosquitto ];
|
|
|
|
services.home-assistant = {
|
|
|
|
inherit configDir;
|
|
|
|
enable = true;
|
|
|
|
config = {
|
|
|
|
homeassistant = {
|
|
|
|
name = "Home";
|
|
|
|
time_zone = "UTC";
|
|
|
|
latitude = "0.0";
|
|
|
|
longitude = "0.0";
|
|
|
|
elevation = 0;
|
2018-01-26 00:41:36 +00:00
|
|
|
};
|
2020-06-20 11:05:30 +01:00
|
|
|
frontend = {};
|
|
|
|
# uses embedded mqtt broker
|
|
|
|
mqtt.password = mqttPassword;
|
|
|
|
binary_sensor = [{
|
|
|
|
platform = "mqtt";
|
|
|
|
state_topic = "home-assistant/test";
|
|
|
|
payload_on = "let_there_be_light";
|
|
|
|
payload_off = "off";
|
|
|
|
}];
|
|
|
|
logger = {
|
|
|
|
default = "info";
|
|
|
|
logs."homeassistant.components.mqtt" = "debug";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
lovelaceConfig = {
|
|
|
|
title = "My Awesome Home";
|
|
|
|
views = [{
|
|
|
|
title = "Example";
|
|
|
|
cards = [{
|
|
|
|
type = "markdown";
|
|
|
|
title = "Lovelace";
|
|
|
|
content = "Welcome to your **Lovelace UI**.";
|
|
|
|
}];
|
|
|
|
}];
|
2018-01-26 00:41:36 +00:00
|
|
|
};
|
2020-06-20 11:05:30 +01:00
|
|
|
lovelaceConfigWritable = true;
|
|
|
|
};
|
2018-02-01 12:42:07 +00:00
|
|
|
};
|
2018-01-26 00:41:36 +00:00
|
|
|
|
|
|
|
testScript = ''
|
2020-01-09 10:19:54 +00:00
|
|
|
start_all()
|
|
|
|
hass.wait_for_unit("home-assistant.service")
|
|
|
|
with subtest("Check that YAML configuration file is in place"):
|
|
|
|
hass.succeed("test -L ${configDir}/configuration.yaml")
|
|
|
|
with subtest("lovelace config is copied because lovelaceConfigWritable = true"):
|
|
|
|
hass.succeed("test -f ${configDir}/ui-lovelace.yaml")
|
|
|
|
with subtest("Check that Home Assistant's web interface and API can be reached"):
|
|
|
|
hass.wait_for_open_port(8123)
|
2020-05-20 22:41:42 +01:00
|
|
|
hass.succeed("curl --fail http://localhost:8123/lovelace")
|
2020-01-09 10:19:54 +00:00
|
|
|
with subtest("Toggle a binary sensor using MQTT"):
|
2020-06-20 11:05:30 +01:00
|
|
|
# wait for broker to become available
|
2020-01-09 10:19:54 +00:00
|
|
|
hass.wait_until_succeeds(
|
2020-06-20 11:05:30 +01:00
|
|
|
"mosquitto_sub -V mqttv311 -t home-assistant/test -u homeassistant -P '${mqttPassword}' -W 1 -t '*'"
|
2020-01-09 10:19:54 +00:00
|
|
|
)
|
|
|
|
hass.succeed(
|
2020-06-20 11:05:30 +01:00
|
|
|
"mosquitto_pub -V mqttv311 -t home-assistant/test -u homeassistant -P '${mqttPassword}' -m let_there_be_light"
|
2020-01-09 10:19:54 +00:00
|
|
|
)
|
|
|
|
with subtest("Print log to ease debugging"):
|
|
|
|
output_log = hass.succeed("cat ${configDir}/home-assistant.log")
|
|
|
|
print("\n### home-assistant.log ###\n")
|
|
|
|
print(output_log + "\n")
|
2018-05-10 12:11:26 +01:00
|
|
|
|
2020-01-09 10:19:54 +00:00
|
|
|
with subtest("Check that no errors were logged"):
|
|
|
|
assert "ERROR" not in output_log
|
2020-06-20 11:05:30 +01:00
|
|
|
|
|
|
|
# example line: 2020-06-20 10:01:32 DEBUG (MainThread) [homeassistant.components.mqtt] Received message on home-assistant/test: b'let_there_be_light'
|
|
|
|
with subtest("Check we received the mosquitto message"):
|
|
|
|
assert "let_there_be_light" in output_log
|
2018-01-26 00:41:36 +00:00
|
|
|
'';
|
|
|
|
})
|