nixpkgs-suyu/pkgs/servers/home-assistant/default.nix

210 lines
6.4 KiB
Nix
Raw Normal View History

2020-06-20 12:05:30 +02:00
{ stdenv, nixosTests, lib, fetchurl, fetchFromGitHub, fetchpatch, python3, protobuf3_6
# Look up dependencies of specified components in component-packages.nix
2019-12-20 08:25:56 +01:00
, extraComponents ? [ ]
# Additional packages to add to propagatedBuildInputs
2018-01-14 22:26:52 +01:00
, extraPackages ? ps: []
# Override Python packages using
# self: super: { pkg = super.pkg.overridePythonAttrs (oldAttrs: { ... }); }
# Applied after defaultOverrides
, packageOverrides ? self: super: {
}
# Skip pip install of required packages on startup
2018-01-14 22:26:52 +01:00
, skipPip ? true }:
let
defaultOverrides = [
2018-06-26 22:36:14 +02:00
# Override the version of some packages pinned in Home Assistant's setup.py
2018-11-10 13:42:15 +01:00
2020-10-08 23:13:48 +02:00
# Pinned due to API changes in astral>=2.0, required by the sun/moon plugins
# https://github.com/home-assistant/core/issues/36636
(mkOverride "astral" "1.10.1"
"d2a67243c4503131c856cafb1b1276de52a86e5b8a1d507b7e08bee51cb67bf1")
2020-10-08 23:13:48 +02:00
# Pinned, because v1.5.0 broke the google_translate integration
# https://github.com/home-assistant/core/pull/38428
(mkOverride "yarl" "1.4.2"
"0jzpgrdl6415zzl8js7095q8ks14555lhgxah76mimffkr39rkaq")
2020-08-18 10:07:27 +02:00
# hass-frontend does not exist in python3.pkgs
(self: super: {
hass-frontend = self.callPackage ./frontend.nix { };
})
];
mkOverride = attrname: version: sha256:
self: super: {
${attrname} = super.${attrname}.overridePythonAttrs (oldAttrs: {
inherit version;
2018-05-11 19:39:37 +02:00
src = oldAttrs.src.override {
inherit version sha256;
2018-05-11 19:39:37 +02:00
};
});
2018-01-14 22:26:52 +01:00
};
py = python3.override {
# Put packageOverrides at the start so they are applied after defaultOverrides
packageOverrides = lib.foldr lib.composeExtensions (self: super: { }) ([ packageOverrides ] ++ defaultOverrides);
2018-01-14 22:26:52 +01:00
};
componentPackages = import ./component-packages.nix;
availableComponents = builtins.attrNames componentPackages.components;
getPackages = component: builtins.getAttr component componentPackages.components;
componentBuildInputs = lib.concatMap (component: getPackages component py.pkgs) extraComponents;
2018-01-14 22:26:52 +01:00
# Ensure that we are using a consistent package set
extraBuildInputs = extraPackages py.pkgs;
# Don't forget to run parse-requirements.py after updating
2021-01-10 23:04:18 +01:00
hassVersion = "2021.1.1";
2018-01-14 22:26:52 +01:00
in with py.pkgs; buildPythonApplication rec {
pname = "homeassistant";
version = assert (componentPackages.version == hassVersion); hassVersion;
2018-01-14 22:26:52 +01:00
2020-10-07 20:28:25 +02:00
# check REQUIRED_PYTHON_VER in homeassistant/const.py
disabled = pythonOlder "3.7.1";
2020-02-26 16:51:25 +01:00
# don't try and fail to strip 6600+ python files, it takes minutes!
dontStrip = true;
inherit availableComponents;
2018-01-14 22:26:52 +01:00
# PyPI tarball is missing tests/ directory
src = fetchFromGitHub {
owner = "home-assistant";
2020-05-20 23:41:42 +02:00
repo = "core";
2018-01-14 22:26:52 +01:00
rev = version;
2021-01-10 23:04:18 +01:00
sha256 = "1linjv1hryqsh8y1rql1i95b4lz4h8siw847gm78m1z8niacz7ss";
2018-01-14 22:26:52 +01:00
};
2020-11-04 12:52:54 +01:00
# leave this in, so users don't have to constantly update their downstream patch handling
patches = [];
2020-08-18 10:07:27 +02:00
postPatch = ''
substituteInPlace setup.py \
2020-11-18 19:59:07 +01:00
--replace "aiohttp==3.7.1" "aiohttp>=3.6.3" \
2020-12-11 14:30:12 +01:00
--replace "attrs==19.3.0" "attrs>=19.3.0" \
2020-10-08 23:13:48 +02:00
--replace "bcrypt==3.1.7" "bcrypt>=3.1.7" \
2020-11-04 12:52:54 +01:00
--replace "cryptography==3.2" "cryptography" \
2020-12-11 14:30:12 +01:00
--replace "pip>=8.0.3,<20.3" "pip" \
2020-11-18 19:59:07 +01:00
--replace "requests==2.25.0" "requests>=2.24.0" \
2020-10-08 23:13:48 +02:00
--replace "ruamel.yaml==0.15.100" "ruamel.yaml>=0.15.100"
2020-10-07 20:28:25 +02:00
substituteInPlace tests/test_config.py --replace '"/usr"' '"/build/media"'
2020-08-18 10:07:27 +02:00
'';
2018-01-14 22:26:52 +01:00
propagatedBuildInputs = [
# From setup.py
2020-10-28 20:12:49 +01:00
aiohttp astral async-timeout attrs bcrypt certifi ciso8601 httpx jinja2
2019-07-20 04:29:51 +02:00
pyjwt cryptography pip python-slugify pytz pyyaml requests ruamel_yaml
2020-10-08 23:13:48 +02:00
setuptools voluptuous voluptuous-serialize yarl
# From default_config. frontend, http, image, mobile_app and recorder components as well as
# the auth.mfa_modules.totp module
2020-10-08 23:13:48 +02:00
aiohttp-cors defusedxml distro emoji hass-frontend pynacl pillow pyotp
pyqrcode sqlalchemy
] ++ componentBuildInputs ++ extraBuildInputs;
2018-01-14 22:26:52 +01:00
2020-05-06 08:27:19 +02:00
# upstream only tests on Linux, so do we.
doCheck = stdenv.isLinux;
2018-01-14 22:26:52 +01:00
checkInputs = [
asynctest pytestCheckHook pytest-aiohttp pytest_xdist requests-mock hass-nabucasa netdisco pydispatcher
2019-12-20 08:25:56 +01:00
];
# We cannot test all components, since they'd introduce lots of dependencies, some of which are unpackaged,
# but we should test very common stuff, like what's in `default_config`.
componentTests = [
"api"
"automation"
"config"
"configurator"
"default_config"
"demo"
"discovery"
"frontend"
"group"
"history"
"homeassistant"
"http"
"input_boolean"
"input_datetime"
"input_text"
"input_number"
"input_select"
"logbook"
"logger"
"media_source"
"mobile_app"
"person"
"scene"
"script"
"shell_command"
"ssdp"
"sun"
"system_health"
"system_log"
"tag"
"websocket_api"
"zeroconf"
"zone"
];
pytestFlagsArray = [
"-n auto"
# don't bulk test all components
"--ignore tests/components"
# prone to race conditions due to parallel file access
"--ignore tests/test_config.py"
# tries to import unpackaged dependencies
"--ignore tests/test_loader.py"
# pyotp since v2.4.0 complains about the short mock keys, hass pins v2.3.0
"--ignore tests/auth/mfa_modules/test_notify.py"
"tests"
] ++ map (component: "tests/components/" + component) componentTests;
disabledTests = [
# AssertionError: merge_log_err.call_count != 0
"test_merge"
# ModuleNotFoundError: No module named 'pyqwikswitch'
"test_merge_id_schema"
# AssertionError: assert 'unknown' == 'not_home'
"test_device_tracker_not_home"
# Racy https://github.com/home-assistant/core/issues/41425
"test_cached_event_message"
home-assistant: disable test_media_view DEBUG:homeassistant.components.http.auth:Authenticated 127.0.0.1 for /media/local/test.mp3 using bearer token DEBUG:homeassistant.components.http.view:Serving /media/local/test.mp3 to 127.0.0.1 (auth: True) ERROR:aiohttp.server:Unhandled exception Traceback (most recent call last): File "/nix/store/8y4x6km9q2ik0hcgh0klx6rl46pcw6qf-python3.8-aiohttp-3.7.3/lib/python3.8/site-packages/aiohttp/web_protocol.py", line 485, in start resp, reset = await task File "/nix/store/8y4x6km9q2ik0hcgh0klx6rl46pcw6qf-python3.8-aiohttp-3.7.3/lib/python3.8/site-packages/aiohttp/web_protocol.py", line 440, in _handle_request reset = await self.finish_response(request, resp, start_time) File "/nix/store/8y4x6km9q2ik0hcgh0klx6rl46pcw6qf-python3.8-aiohttp-3.7.3/lib/python3.8/site-packages/aiohttp/web_protocol.py", line 591, in finish_response await prepare_meth(request) File "/nix/store/8y4x6km9q2ik0hcgh0klx6rl46pcw6qf-python3.8-aiohttp-3.7.3/lib/python3.8/site-packages/aiohttp/web_fileresponse.py", line 241, in prepare return await self._sendfile(request, fobj, offset, count) File "/nix/store/8y4x6km9q2ik0hcgh0klx6rl46pcw6qf-python3.8-aiohttp-3.7.3/lib/python3.8/site-packages/aiohttp/web_fileresponse.py", line 96, in _sendfile await loop.sendfile(transport, fobj, offset, count) File "/nix/store/i9lzacdfrwlj1ayw551c016s0fq71p7j-python3-3.8.6/lib/python3.8/asyncio/base_events.py", line 1120, in sendfile return await self._sendfile_native(transport, file, File "/nix/store/i9lzacdfrwlj1ayw551c016s0fq71p7j-python3-3.8.6/lib/python3.8/asyncio/selector_events.py", line 578, in _sendfile_native return await self.sock_sendfile(transp._sock, file, offset, count, File "/nix/store/i9lzacdfrwlj1ayw551c016s0fq71p7j-python3-3.8.6/lib/python3.8/asyncio/base_events.py", line 836, in sock_sendfile self._check_sendfile_params(sock, file, offset, count) File "/nix/store/i9lzacdfrwlj1ayw551c016s0fq71p7j-python3-3.8.6/lib/python3.8/asyncio/base_events.py", line 889, in _check_sendfile_params raise ValueError( ValueError: count must be a positive integer (got 0)
2020-12-11 14:32:39 +01:00
# ValueError: count must be a positive integer (got 0)
"test_media_view"
2021-01-06 19:57:47 +01:00
# AssertionError: len(events) == 1
"test_error_posted_as_event"
# keyring.errors.NoKeyringError: No recommended backend was available.
"test_secrets_from_unrelated_fails"
"test_secrets_credstash"
];
preCheck = ''
# the tests require the existance of a media dir
mkdir /build/media
2018-01-14 22:26:52 +01:00
'';
2018-02-10 23:19:19 +01:00
makeWrapperArgs = lib.optional skipPip "--add-flags --skip-pip";
2018-01-14 22:26:52 +01:00
2020-05-06 08:39:44 +02:00
passthru = {
inherit (py.pkgs) hass-frontend;
2020-06-20 12:05:30 +02:00
tests = {
inherit (nixosTests) home-assistant;
};
2020-05-06 08:39:44 +02:00
};
2018-02-10 23:19:19 +01:00
meta = with lib; {
homepage = "https://home-assistant.io/";
description = "Open source home automation that puts local control and privacy first";
2018-01-14 22:26:52 +01:00
license = licenses.asl20;
maintainers = with maintainers; [ dotlambda globin mic92 hexa ];
2018-01-14 22:26:52 +01:00
};
}