mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-04-12 04:17:15 +00:00
Merge pull request #155060 from dotlambda/home-assistant-outsource-tests
home-assistant: outsource component tests
This commit is contained in:
commit
adde93f135
37
pkgs/development/python-modules/rpi-bad-power/default.nix
Normal file
37
pkgs/development/python-modules/rpi-bad-power/default.nix
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
{ lib
|
||||||
|
, buildPythonPackage
|
||||||
|
, fetchFromGitHub
|
||||||
|
, pytestCheckHook
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
pname = "rpi-bad-power";
|
||||||
|
version = "0.1.0";
|
||||||
|
in
|
||||||
|
buildPythonPackage {
|
||||||
|
inherit pname version;
|
||||||
|
format = "pyproject";
|
||||||
|
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "shenxn";
|
||||||
|
repo = pname;
|
||||||
|
rev = "v${version}";
|
||||||
|
hash = "sha256:1yvfz28blq4fdnn614n985vbs5hcw1gm3i9am53k410sfs7ilvkk";
|
||||||
|
};
|
||||||
|
|
||||||
|
pythonImportsCheck = [
|
||||||
|
"rpi_bad_power"
|
||||||
|
];
|
||||||
|
|
||||||
|
checkInputs = [
|
||||||
|
pytestCheckHook
|
||||||
|
];
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "Python library to detect bad power supply on Raspberry Pi";
|
||||||
|
homepage = "https://github.com/shenxn/rpi-bad-power";
|
||||||
|
license = licenses.mit;
|
||||||
|
maintainers = with maintainers; [ hexa ];
|
||||||
|
platforms = platforms.linux;
|
||||||
|
};
|
||||||
|
}
|
@ -725,7 +725,7 @@
|
|||||||
"rpi_gpio" = ps: with ps; [ ]; # missing inputs: RPi.GPIO
|
"rpi_gpio" = ps: with ps; [ ]; # missing inputs: RPi.GPIO
|
||||||
"rpi_gpio_pwm" = ps: with ps; [ ]; # missing inputs: pwmled
|
"rpi_gpio_pwm" = ps: with ps; [ ]; # missing inputs: pwmled
|
||||||
"rpi_pfio" = ps: with ps; [ ]; # missing inputs: pifacecommon pifacedigitalio
|
"rpi_pfio" = ps: with ps; [ ]; # missing inputs: pifacecommon pifacedigitalio
|
||||||
"rpi_power" = ps: with ps; [ ]; # missing inputs: rpi-bad-power
|
"rpi_power" = ps: with ps; [ rpi-bad-power ];
|
||||||
"rpi_rf" = ps: with ps; [ ]; # missing inputs: RPi.GPIO rpi-rf
|
"rpi_rf" = ps: with ps; [ ]; # missing inputs: RPi.GPIO rpi-rf
|
||||||
"rss_feed_template" = ps: with ps; [ aiohttp-cors ];
|
"rss_feed_template" = ps: with ps; [ aiohttp-cors ];
|
||||||
"rtorrent" = ps: with ps; [ ];
|
"rtorrent" = ps: with ps; [ ];
|
||||||
@ -1018,4 +1018,569 @@
|
|||||||
"zwave" = ps: with ps; [ homeassistant-pyozw pydispatcher ];
|
"zwave" = ps: with ps; [ homeassistant-pyozw pydispatcher ];
|
||||||
"zwave_js" = ps: with ps; [ aiohttp-cors pyserial pyudev zwave-js-server-python ];
|
"zwave_js" = ps: with ps; [ aiohttp-cors pyserial pyudev zwave-js-server-python ];
|
||||||
};
|
};
|
||||||
|
# components listed in tests/components for which all dependencies are packaged
|
||||||
|
supportedComponentsWithTests = [
|
||||||
|
"abode"
|
||||||
|
"accuweather"
|
||||||
|
"acmeda"
|
||||||
|
"adax"
|
||||||
|
"adguard"
|
||||||
|
"advantage_air"
|
||||||
|
"aemet"
|
||||||
|
"agent_dvr"
|
||||||
|
"air_quality"
|
||||||
|
"airly"
|
||||||
|
"airnow"
|
||||||
|
"airthings"
|
||||||
|
"airtouch4"
|
||||||
|
"airvisual"
|
||||||
|
"alarm_control_panel"
|
||||||
|
"alarmdecoder"
|
||||||
|
"alert"
|
||||||
|
"alexa"
|
||||||
|
"almond"
|
||||||
|
"ambee"
|
||||||
|
"amberelectric"
|
||||||
|
"ambiclimate"
|
||||||
|
"ambient_station"
|
||||||
|
"analytics"
|
||||||
|
"androidtv"
|
||||||
|
"apache_kafka"
|
||||||
|
"api"
|
||||||
|
"apple_tv"
|
||||||
|
"apprise"
|
||||||
|
"aprs"
|
||||||
|
"arcam_fmj"
|
||||||
|
"arlo"
|
||||||
|
"asuswrt"
|
||||||
|
"atag"
|
||||||
|
"august"
|
||||||
|
"aurora"
|
||||||
|
"auth"
|
||||||
|
"automation"
|
||||||
|
"awair"
|
||||||
|
"aws"
|
||||||
|
"axis"
|
||||||
|
"azure_devops"
|
||||||
|
"azure_event_hub"
|
||||||
|
"balboa"
|
||||||
|
"bayesian"
|
||||||
|
"binary_sensor"
|
||||||
|
"blackbird"
|
||||||
|
"blebox"
|
||||||
|
"blink"
|
||||||
|
"blueprint"
|
||||||
|
"bluetooth_le_tracker"
|
||||||
|
"bmw_connected_drive"
|
||||||
|
"bond"
|
||||||
|
"bosch_shc"
|
||||||
|
"braviatv"
|
||||||
|
"broadlink"
|
||||||
|
"brother"
|
||||||
|
"bsblan"
|
||||||
|
"buienradar"
|
||||||
|
"button"
|
||||||
|
"caldav"
|
||||||
|
"calendar"
|
||||||
|
"camera"
|
||||||
|
"canary"
|
||||||
|
"cast"
|
||||||
|
"cert_expiry"
|
||||||
|
"climacell"
|
||||||
|
"climate"
|
||||||
|
"cloud"
|
||||||
|
"cloudflare"
|
||||||
|
"color_extractor"
|
||||||
|
"comfoconnect"
|
||||||
|
"command_line"
|
||||||
|
"compensation"
|
||||||
|
"config"
|
||||||
|
"configurator"
|
||||||
|
"control4"
|
||||||
|
"conversation"
|
||||||
|
"coolmaster"
|
||||||
|
"coronavirus"
|
||||||
|
"counter"
|
||||||
|
"cover"
|
||||||
|
"crownstone"
|
||||||
|
"daikin"
|
||||||
|
"darksky"
|
||||||
|
"datadog"
|
||||||
|
"debugpy"
|
||||||
|
"deconz"
|
||||||
|
"default_config"
|
||||||
|
"demo"
|
||||||
|
"denonavr"
|
||||||
|
"derivative"
|
||||||
|
"device_automation"
|
||||||
|
"device_sun_light_trigger"
|
||||||
|
"device_tracker"
|
||||||
|
"devolo_home_control"
|
||||||
|
"devolo_home_network"
|
||||||
|
"dexcom"
|
||||||
|
"dhcp"
|
||||||
|
"dialogflow"
|
||||||
|
"directv"
|
||||||
|
"discovery"
|
||||||
|
"dlna_dmr"
|
||||||
|
"doorbird"
|
||||||
|
"dsmr"
|
||||||
|
"dte_energy_bridge"
|
||||||
|
"duckdns"
|
||||||
|
"dunehd"
|
||||||
|
"eafm"
|
||||||
|
"ecobee"
|
||||||
|
"econet"
|
||||||
|
"efergy"
|
||||||
|
"elgato"
|
||||||
|
"elkm1"
|
||||||
|
"emonitor"
|
||||||
|
"emulated_hue"
|
||||||
|
"emulated_kasa"
|
||||||
|
"emulated_roku"
|
||||||
|
"energy"
|
||||||
|
"enocean"
|
||||||
|
"enphase_envoy"
|
||||||
|
"environment_canada"
|
||||||
|
"epson"
|
||||||
|
"esphome"
|
||||||
|
"everlights"
|
||||||
|
"evil_genius_labs"
|
||||||
|
"ezviz"
|
||||||
|
"faa_delays"
|
||||||
|
"facebook"
|
||||||
|
"facebox"
|
||||||
|
"fail2ban"
|
||||||
|
"fan"
|
||||||
|
"feedreader"
|
||||||
|
"ffmpeg"
|
||||||
|
"fido"
|
||||||
|
"file"
|
||||||
|
"filesize"
|
||||||
|
"filter"
|
||||||
|
"fireservicerota"
|
||||||
|
"firmata"
|
||||||
|
"fjaraskupan"
|
||||||
|
"flick_electric"
|
||||||
|
"flipr"
|
||||||
|
"flo"
|
||||||
|
"flume"
|
||||||
|
"flunearyou"
|
||||||
|
"flux"
|
||||||
|
"flux_led"
|
||||||
|
"folder"
|
||||||
|
"folder_watcher"
|
||||||
|
"foobot"
|
||||||
|
"forecast_solar"
|
||||||
|
"foscam"
|
||||||
|
"freebox"
|
||||||
|
"freedns"
|
||||||
|
"freedompro"
|
||||||
|
"fritz"
|
||||||
|
"fritzbox"
|
||||||
|
"fritzbox_callmonitor"
|
||||||
|
"fronius"
|
||||||
|
"frontend"
|
||||||
|
"garages_amsterdam"
|
||||||
|
"gdacs"
|
||||||
|
"generic"
|
||||||
|
"generic_hygrostat"
|
||||||
|
"generic_thermostat"
|
||||||
|
"geo_json_events"
|
||||||
|
"geo_location"
|
||||||
|
"geo_rss_events"
|
||||||
|
"geofency"
|
||||||
|
"geonetnz_quakes"
|
||||||
|
"geonetnz_volcano"
|
||||||
|
"gios"
|
||||||
|
"glances"
|
||||||
|
"goalzero"
|
||||||
|
"gogogate2"
|
||||||
|
"google"
|
||||||
|
"google_assistant"
|
||||||
|
"google_domains"
|
||||||
|
"google_pubsub"
|
||||||
|
"google_translate"
|
||||||
|
"google_travel_time"
|
||||||
|
"google_wifi"
|
||||||
|
"gpslogger"
|
||||||
|
"graphite"
|
||||||
|
"gree"
|
||||||
|
"group"
|
||||||
|
"growatt_server"
|
||||||
|
"guardian"
|
||||||
|
"habitica"
|
||||||
|
"hangouts"
|
||||||
|
"harmony"
|
||||||
|
"hassio"
|
||||||
|
"hddtemp"
|
||||||
|
"heos"
|
||||||
|
"here_travel_time"
|
||||||
|
"hisense_aehw4a1"
|
||||||
|
"history"
|
||||||
|
"history_stats"
|
||||||
|
"hive"
|
||||||
|
"hlk_sw16"
|
||||||
|
"home_connect"
|
||||||
|
"home_plus_control"
|
||||||
|
"homeassistant"
|
||||||
|
"homekit"
|
||||||
|
"homekit_controller"
|
||||||
|
"homematic"
|
||||||
|
"homematicip_cloud"
|
||||||
|
"honeywell"
|
||||||
|
"html5"
|
||||||
|
"http"
|
||||||
|
"huawei_lte"
|
||||||
|
"hue"
|
||||||
|
"huisbaasje"
|
||||||
|
"humidifier"
|
||||||
|
"hunterdouglas_powerview"
|
||||||
|
"hvv_departures"
|
||||||
|
"hyperion"
|
||||||
|
"ialarm"
|
||||||
|
"iaqualink"
|
||||||
|
"icloud"
|
||||||
|
"ifttt"
|
||||||
|
"ign_sismologia"
|
||||||
|
"image"
|
||||||
|
"image_processing"
|
||||||
|
"imap_email_content"
|
||||||
|
"influxdb"
|
||||||
|
"input_boolean"
|
||||||
|
"input_datetime"
|
||||||
|
"input_number"
|
||||||
|
"input_select"
|
||||||
|
"input_text"
|
||||||
|
"insteon"
|
||||||
|
"integration"
|
||||||
|
"intent"
|
||||||
|
"intent_script"
|
||||||
|
"ios"
|
||||||
|
"iotawatt"
|
||||||
|
"ipma"
|
||||||
|
"ipp"
|
||||||
|
"iqvia"
|
||||||
|
"islamic_prayer_times"
|
||||||
|
"isy994"
|
||||||
|
"izone"
|
||||||
|
"jellyfin"
|
||||||
|
"jewish_calendar"
|
||||||
|
"juicenet"
|
||||||
|
"keenetic_ndms2"
|
||||||
|
"kira"
|
||||||
|
"kmtronic"
|
||||||
|
"knx"
|
||||||
|
"kodi"
|
||||||
|
"konnected"
|
||||||
|
"kraken"
|
||||||
|
"kulersky"
|
||||||
|
"lastfm"
|
||||||
|
"lcn"
|
||||||
|
"light"
|
||||||
|
"litterrobot"
|
||||||
|
"local_file"
|
||||||
|
"local_ip"
|
||||||
|
"locative"
|
||||||
|
"lock"
|
||||||
|
"logbook"
|
||||||
|
"logentries"
|
||||||
|
"logger"
|
||||||
|
"london_air"
|
||||||
|
"lookin"
|
||||||
|
"lovelace"
|
||||||
|
"luftdaten"
|
||||||
|
"lutron_caseta"
|
||||||
|
"lyric"
|
||||||
|
"mailbox"
|
||||||
|
"manual"
|
||||||
|
"manual_mqtt"
|
||||||
|
"maxcube"
|
||||||
|
"mazda"
|
||||||
|
"media_player"
|
||||||
|
"media_source"
|
||||||
|
"melcloud"
|
||||||
|
"meraki"
|
||||||
|
"met"
|
||||||
|
"met_eireann"
|
||||||
|
"meteoclimatic"
|
||||||
|
"mhz19"
|
||||||
|
"microsoft_face"
|
||||||
|
"microsoft_face_detect"
|
||||||
|
"microsoft_face_identify"
|
||||||
|
"mikrotik"
|
||||||
|
"mill"
|
||||||
|
"min_max"
|
||||||
|
"minecraft_server"
|
||||||
|
"minio"
|
||||||
|
"mobile_app"
|
||||||
|
"modbus"
|
||||||
|
"modem_callerid"
|
||||||
|
"modern_forms"
|
||||||
|
"mold_indicator"
|
||||||
|
"moon"
|
||||||
|
"motion_blinds"
|
||||||
|
"motioneye"
|
||||||
|
"mqtt"
|
||||||
|
"mqtt_eventstream"
|
||||||
|
"mqtt_json"
|
||||||
|
"mqtt_room"
|
||||||
|
"mqtt_statestream"
|
||||||
|
"mullvad"
|
||||||
|
"mutesync"
|
||||||
|
"my"
|
||||||
|
"myq"
|
||||||
|
"mysensors"
|
||||||
|
"mythicbeastsdns"
|
||||||
|
"nam"
|
||||||
|
"namecheapdns"
|
||||||
|
"nanoleaf"
|
||||||
|
"neato"
|
||||||
|
"ness_alarm"
|
||||||
|
"nest"
|
||||||
|
"netatmo"
|
||||||
|
"network"
|
||||||
|
"nexia"
|
||||||
|
"nightscout"
|
||||||
|
"no_ip"
|
||||||
|
"notify"
|
||||||
|
"notion"
|
||||||
|
"nsw_rural_fire_service_feed"
|
||||||
|
"nuki"
|
||||||
|
"number"
|
||||||
|
"nws"
|
||||||
|
"nx584"
|
||||||
|
"octoprint"
|
||||||
|
"omnilogic"
|
||||||
|
"onboarding"
|
||||||
|
"ondilo_ico"
|
||||||
|
"openalpr_cloud"
|
||||||
|
"openalpr_local"
|
||||||
|
"openerz"
|
||||||
|
"opengarage"
|
||||||
|
"openhardwaremonitor"
|
||||||
|
"opentherm_gw"
|
||||||
|
"openuv"
|
||||||
|
"openweathermap"
|
||||||
|
"opnsense"
|
||||||
|
"ovo_energy"
|
||||||
|
"owntracks"
|
||||||
|
"ozw"
|
||||||
|
"p1_monitor"
|
||||||
|
"panel_custom"
|
||||||
|
"panel_iframe"
|
||||||
|
"persistent_notification"
|
||||||
|
"person"
|
||||||
|
"philips_js"
|
||||||
|
"pi_hole"
|
||||||
|
"picnic"
|
||||||
|
"ping"
|
||||||
|
"plaato"
|
||||||
|
"plant"
|
||||||
|
"plex"
|
||||||
|
"plugwise"
|
||||||
|
"point"
|
||||||
|
"poolsense"
|
||||||
|
"profiler"
|
||||||
|
"prometheus"
|
||||||
|
"prosegur"
|
||||||
|
"proximity"
|
||||||
|
"push"
|
||||||
|
"pushbullet"
|
||||||
|
"pvpc_hourly_pricing"
|
||||||
|
"python_script"
|
||||||
|
"qld_bushfire"
|
||||||
|
"rachio"
|
||||||
|
"radarr"
|
||||||
|
"rainforest_eagle"
|
||||||
|
"rainmachine"
|
||||||
|
"random"
|
||||||
|
"rdw"
|
||||||
|
"recollect_waste"
|
||||||
|
"recorder"
|
||||||
|
"reddit"
|
||||||
|
"remote"
|
||||||
|
"renault"
|
||||||
|
"rest"
|
||||||
|
"rest_command"
|
||||||
|
"rflink"
|
||||||
|
"rfxtrx"
|
||||||
|
"ridwell"
|
||||||
|
"ring"
|
||||||
|
"risco"
|
||||||
|
"rituals_perfume_genie"
|
||||||
|
"rmvtransport"
|
||||||
|
"roku"
|
||||||
|
"roomba"
|
||||||
|
"roon"
|
||||||
|
"rpi_power"
|
||||||
|
"rss_feed_template"
|
||||||
|
"ruckus_unleashed"
|
||||||
|
"safe_mode"
|
||||||
|
"samsungtv"
|
||||||
|
"scene"
|
||||||
|
"screenlogic"
|
||||||
|
"script"
|
||||||
|
"search"
|
||||||
|
"season"
|
||||||
|
"select"
|
||||||
|
"sense"
|
||||||
|
"sensor"
|
||||||
|
"sentry"
|
||||||
|
"seventeentrack"
|
||||||
|
"sharkiq"
|
||||||
|
"shell_command"
|
||||||
|
"shelly"
|
||||||
|
"shopping_list"
|
||||||
|
"sia"
|
||||||
|
"sigfox"
|
||||||
|
"sighthound"
|
||||||
|
"simplisafe"
|
||||||
|
"simulated"
|
||||||
|
"siren"
|
||||||
|
"slack"
|
||||||
|
"sleepiq"
|
||||||
|
"sma"
|
||||||
|
"smappee"
|
||||||
|
"smart_meter_texas"
|
||||||
|
"smarthab"
|
||||||
|
"smartthings"
|
||||||
|
"smarttub"
|
||||||
|
"smhi"
|
||||||
|
"smtp"
|
||||||
|
"snips"
|
||||||
|
"solaredge"
|
||||||
|
"solarlog"
|
||||||
|
"soma"
|
||||||
|
"somfy"
|
||||||
|
"somfy_mylink"
|
||||||
|
"sonarr"
|
||||||
|
"songpal"
|
||||||
|
"sonos"
|
||||||
|
"soundtouch"
|
||||||
|
"spaceapi"
|
||||||
|
"spc"
|
||||||
|
"speedtestdotnet"
|
||||||
|
"spider"
|
||||||
|
"spotify"
|
||||||
|
"sql"
|
||||||
|
"squeezebox"
|
||||||
|
"srp_energy"
|
||||||
|
"ssdp"
|
||||||
|
"starline"
|
||||||
|
"startca"
|
||||||
|
"statistics"
|
||||||
|
"statsd"
|
||||||
|
"stream"
|
||||||
|
"stt"
|
||||||
|
"subaru"
|
||||||
|
"sun"
|
||||||
|
"surepetcare"
|
||||||
|
"switch"
|
||||||
|
"switchbot"
|
||||||
|
"switcher_kis"
|
||||||
|
"syncthing"
|
||||||
|
"syncthru"
|
||||||
|
"synology_dsm"
|
||||||
|
"system_bridge"
|
||||||
|
"system_health"
|
||||||
|
"system_log"
|
||||||
|
"tado"
|
||||||
|
"tag"
|
||||||
|
"tailscale"
|
||||||
|
"tasmota"
|
||||||
|
"tcp"
|
||||||
|
"telegram"
|
||||||
|
"tellduslive"
|
||||||
|
"template"
|
||||||
|
"tesla_wall_connector"
|
||||||
|
"threshold"
|
||||||
|
"tibber"
|
||||||
|
"tile"
|
||||||
|
"time_date"
|
||||||
|
"timer"
|
||||||
|
"tod"
|
||||||
|
"tolo"
|
||||||
|
"tomato"
|
||||||
|
"toon"
|
||||||
|
"totalconnect"
|
||||||
|
"tplink"
|
||||||
|
"traccar"
|
||||||
|
"trace"
|
||||||
|
"tractive"
|
||||||
|
"tradfri"
|
||||||
|
"trafikverket_weatherstation"
|
||||||
|
"transmission"
|
||||||
|
"transport_nsw"
|
||||||
|
"trend"
|
||||||
|
"tts"
|
||||||
|
"tuya"
|
||||||
|
"twentemilieu"
|
||||||
|
"twilio"
|
||||||
|
"twinkly"
|
||||||
|
"twitch"
|
||||||
|
"uk_transport"
|
||||||
|
"unifi"
|
||||||
|
"unifi_direct"
|
||||||
|
"universal"
|
||||||
|
"upb"
|
||||||
|
"upcloud"
|
||||||
|
"updater"
|
||||||
|
"upnp"
|
||||||
|
"uptime"
|
||||||
|
"uptimerobot"
|
||||||
|
"usb"
|
||||||
|
"usgs_earthquakes_feed"
|
||||||
|
"utility_meter"
|
||||||
|
"uvc"
|
||||||
|
"vacuum"
|
||||||
|
"velbus"
|
||||||
|
"venstar"
|
||||||
|
"vera"
|
||||||
|
"verisure"
|
||||||
|
"version"
|
||||||
|
"vesync"
|
||||||
|
"vicare"
|
||||||
|
"vilfo"
|
||||||
|
"vizio"
|
||||||
|
"vlc_telnet"
|
||||||
|
"voicerss"
|
||||||
|
"volumio"
|
||||||
|
"vultr"
|
||||||
|
"wake_on_lan"
|
||||||
|
"wallbox"
|
||||||
|
"water_heater"
|
||||||
|
"watttime"
|
||||||
|
"waze_travel_time"
|
||||||
|
"weather"
|
||||||
|
"webhook"
|
||||||
|
"webostv"
|
||||||
|
"websocket_api"
|
||||||
|
"wemo"
|
||||||
|
"whirlpool"
|
||||||
|
"wiffi"
|
||||||
|
"wilight"
|
||||||
|
"wled"
|
||||||
|
"workday"
|
||||||
|
"worldclock"
|
||||||
|
"wsdot"
|
||||||
|
"xbox"
|
||||||
|
"xiaomi"
|
||||||
|
"xiaomi_aqara"
|
||||||
|
"xiaomi_miio"
|
||||||
|
"yale_smart_alarm"
|
||||||
|
"yamaha"
|
||||||
|
"yamaha_musiccast"
|
||||||
|
"yandex_transport"
|
||||||
|
"yandextts"
|
||||||
|
"yeelight"
|
||||||
|
"youless"
|
||||||
|
"zeroconf"
|
||||||
|
"zerproc"
|
||||||
|
"zha"
|
||||||
|
"zodiac"
|
||||||
|
"zone"
|
||||||
|
"zwave"
|
||||||
|
"zwave_js"
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
{ stdenv
|
{ stdenv
|
||||||
, lib
|
, lib
|
||||||
|
, callPackage
|
||||||
, fetchFromGitHub
|
, fetchFromGitHub
|
||||||
, fetchpatch
|
, fetchpatch
|
||||||
, python3
|
, python3
|
||||||
@ -40,87 +41,6 @@ let
|
|||||||
# Override the version of some packages pinned in Home Assistant's setup.py and requirements_all.txt
|
# Override the version of some packages pinned in Home Assistant's setup.py and requirements_all.txt
|
||||||
(mkOverride "python-slugify" "4.0.1" "69a517766e00c1268e5bbfc0d010a0a8508de0b18d30ad5a1ff357f8ae724270")
|
(mkOverride "python-slugify" "4.0.1" "69a517766e00c1268e5bbfc0d010a0a8508de0b18d30ad5a1ff357f8ae724270")
|
||||||
|
|
||||||
(self: super: {
|
|
||||||
httpcore = super.httpcore.overridePythonAttrs (oldAttrs: rec {
|
|
||||||
version = "0.14.3";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "encode";
|
|
||||||
repo = "httpcore";
|
|
||||||
rev = version;
|
|
||||||
sha256 = "sha256-jPsbMhY1lWKBXlh6hsX6DGKXi/g7VQSU00tF6H7qkOo=";
|
|
||||||
};
|
|
||||||
propagatedBuildInputs = oldAttrs.propagatedBuildInputs ++ [ python3.pkgs.certifi ];
|
|
||||||
doCheck = false;
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
(self: super: {
|
|
||||||
httpx = super.httpx.overridePythonAttrs (oldAttrs: rec {
|
|
||||||
version = "0.21.1";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "encode";
|
|
||||||
repo = "httpx";
|
|
||||||
rev = version;
|
|
||||||
sha256 = "sha256-ayhLP+1hPWAx2ds227CKp5cebVkD5B2Z59L+3dzdINc=";
|
|
||||||
};
|
|
||||||
doCheck = false;
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
(self: super: {
|
|
||||||
pytest-httpx = super.pytest-httpx.overridePythonAttrs (oldAttrs: rec {
|
|
||||||
version = "0.15.0";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "Colin-bin";
|
|
||||||
repo = "pytest_httpx";
|
|
||||||
rev = "v${version}";
|
|
||||||
sha256 = "08dxvjkxlnam3r0yp17495d1vksyawzzkpykacjql1gi6hqlfrwg";
|
|
||||||
};
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
(self: super: {
|
|
||||||
respx = super.respx.overridePythonAttrs (oldAttrs: rec {
|
|
||||||
version = "0.19.0";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "lundberg";
|
|
||||||
repo = "respx";
|
|
||||||
rev = version;
|
|
||||||
sha256 = "sha256-xiAt42kc1+rro99KMwzYKi3XC+wxYVqOY11tM+M/uV8=";
|
|
||||||
};
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
(self: super: {
|
|
||||||
envoy-reader = super.envoy-reader.overridePythonAttrs (oldAttrs: rec {
|
|
||||||
patches = [
|
|
||||||
# Support for later httpx, https://github.com/jesserizzo/envoy_reader/pull/82
|
|
||||||
(fetchpatch {
|
|
||||||
name = "support-later-httpx.patch";
|
|
||||||
url = "https://github.com/jesserizzo/envoy_reader/commit/6019a89419fe9c830ba839be7d39ec54725268b0.patch";
|
|
||||||
sha256 = "17vsrx13rskvh8swvjisb2dk6x1jdbjcm8ikkpidia35pa24h272";
|
|
||||||
})
|
|
||||||
];
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
(self: super: {
|
|
||||||
sanic = super.sanic.overridePythonAttrs (oldAttrs: rec {
|
|
||||||
version = "21.9.3";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "sanic-org";
|
|
||||||
repo = "sanic";
|
|
||||||
rev = "v${version}";
|
|
||||||
sha256 = "0m18jdw1mvf7jhpnrxhm96p24pxvv0h9m71a8c7sqqkwnnpa3p5i";
|
|
||||||
};
|
|
||||||
disabledTests = oldAttrs.disabledTests ++ [
|
|
||||||
"test_redirect"
|
|
||||||
"test_chained_redirect"
|
|
||||||
"test_unix_connection"
|
|
||||||
];
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
(self: super: {
|
(self: super: {
|
||||||
huawei-lte-api = super.huawei-lte-api.overridePythonAttrs (oldAttrs: rec {
|
huawei-lte-api = super.huawei-lte-api.overridePythonAttrs (oldAttrs: rec {
|
||||||
version = "1.4.18";
|
version = "1.4.18";
|
||||||
@ -222,33 +142,6 @@ let
|
|||||||
});
|
});
|
||||||
})
|
})
|
||||||
|
|
||||||
# Remove as soon the dependency is updated and pytest-httpx > 0.15
|
|
||||||
(self: super: {
|
|
||||||
luftdaten = super.luftdaten.overridePythonAttrs (oldAttrs: rec {
|
|
||||||
version = "0.7.1";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "home-assistant-ecosystem";
|
|
||||||
repo = "python-luftdaten";
|
|
||||||
rev = version;
|
|
||||||
sha256 = "sha256-76Y5TJet0WtzYXuK8Og0rmpsUIlXK7b37oesh+MliU8=";
|
|
||||||
};
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
# Remove as soon the dependency is updated and pytest-httpx > 0.15
|
|
||||||
(self: super: {
|
|
||||||
pyrmvtransport = super.pyrmvtransport.overridePythonAttrs (oldAttrs: rec {
|
|
||||||
version = "0.3.3";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "cgtobi";
|
|
||||||
repo = "pyrmvtransport";
|
|
||||||
rev = "v${version}";
|
|
||||||
sha256 = "sha256-nFxGEyO+wyRzPayjjv8WNIJ+XIWbVn0dyyjQKHiyr40=";
|
|
||||||
};
|
|
||||||
doCheck = false;
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
# home-assistant-frontend does not exist in python3.pkgs
|
# home-assistant-frontend does not exist in python3.pkgs
|
||||||
(self: super: {
|
(self: super: {
|
||||||
home-assistant-frontend = self.callPackage ./frontend.nix { };
|
home-assistant-frontend = self.callPackage ./frontend.nix { };
|
||||||
@ -265,7 +158,7 @@ let
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
py = python3.override {
|
python = python3.override {
|
||||||
# Put packageOverrides at the start so they are applied after defaultOverrides
|
# Put packageOverrides at the start so they are applied after defaultOverrides
|
||||||
packageOverrides = lib.foldr lib.composeExtensions (self: super: { }) ([ packageOverrides ] ++ defaultOverrides);
|
packageOverrides = lib.foldr lib.composeExtensions (self: super: { }) ([ packageOverrides ] ++ defaultOverrides);
|
||||||
};
|
};
|
||||||
@ -274,22 +167,24 @@ let
|
|||||||
|
|
||||||
availableComponents = builtins.attrNames componentPackages.components;
|
availableComponents = builtins.attrNames componentPackages.components;
|
||||||
|
|
||||||
getPackages = component: builtins.getAttr component componentPackages.components;
|
inherit (componentPackages) supportedComponentsWithTests;
|
||||||
|
|
||||||
componentBuildInputs = lib.concatMap (component: getPackages component py.pkgs) extraComponents;
|
getPackages = component: componentPackages.components.${component};
|
||||||
|
|
||||||
|
componentBuildInputs = lib.concatMap (component: getPackages component python.pkgs) extraComponents;
|
||||||
|
|
||||||
# Ensure that we are using a consistent package set
|
# Ensure that we are using a consistent package set
|
||||||
extraBuildInputs = extraPackages py.pkgs;
|
extraBuildInputs = extraPackages python.pkgs;
|
||||||
|
|
||||||
# Don't forget to run parse-requirements.py after updating
|
# Don't forget to run parse-requirements.py after updating
|
||||||
hassVersion = "2021.12.9";
|
hassVersion = "2021.12.9";
|
||||||
|
|
||||||
in with py.pkgs; buildPythonApplication rec {
|
in python.pkgs.buildPythonApplication rec {
|
||||||
pname = "homeassistant";
|
pname = "homeassistant";
|
||||||
version = assert (componentPackages.version == hassVersion); hassVersion;
|
version = assert (componentPackages.version == hassVersion); hassVersion;
|
||||||
|
|
||||||
# check REQUIRED_PYTHON_VER in homeassistant/const.py
|
# check REQUIRED_PYTHON_VER in homeassistant/const.py
|
||||||
disabled = pythonOlder "3.8";
|
disabled = python.pythonOlder "3.8";
|
||||||
|
|
||||||
# don't try and fail to strip 6600+ python files, it takes minutes!
|
# don't try and fail to strip 6600+ python files, it takes minutes!
|
||||||
dontStrip = true;
|
dontStrip = true;
|
||||||
@ -325,7 +220,7 @@ in with py.pkgs; buildPythonApplication rec {
|
|||||||
substituteInPlace tests/test_config.py --replace '"/usr"' '"/build/media"'
|
substituteInPlace tests/test_config.py --replace '"/usr"' '"/build/media"'
|
||||||
'';
|
'';
|
||||||
|
|
||||||
propagatedBuildInputs = [
|
propagatedBuildInputs = with python.pkgs; [
|
||||||
# Only packages required in setup.py
|
# Only packages required in setup.py
|
||||||
aiohttp
|
aiohttp
|
||||||
astral
|
astral
|
||||||
@ -361,9 +256,10 @@ in with py.pkgs; buildPythonApplication rec {
|
|||||||
# upstream only tests on Linux, so do we.
|
# upstream only tests on Linux, so do we.
|
||||||
doCheck = stdenv.isLinux;
|
doCheck = stdenv.isLinux;
|
||||||
|
|
||||||
checkInputs = [
|
checkInputs = with python.pkgs; [
|
||||||
# test infrastructure (selectively from requirement_test.txt)
|
# test infrastructure (selectively from requirement_test.txt)
|
||||||
freezegun
|
freezegun
|
||||||
|
jsonpickle
|
||||||
pytest-aiohttp
|
pytest-aiohttp
|
||||||
pytest-freezegun
|
pytest-freezegun
|
||||||
pytest-mock
|
pytest-mock
|
||||||
@ -372,541 +268,15 @@ in with py.pkgs; buildPythonApplication rec {
|
|||||||
pytest-xdist
|
pytest-xdist
|
||||||
pytestCheckHook
|
pytestCheckHook
|
||||||
requests-mock
|
requests-mock
|
||||||
stdlib-list
|
|
||||||
jsonpickle
|
|
||||||
respx
|
respx
|
||||||
|
stdlib-list
|
||||||
|
tqdm
|
||||||
# required by tests/auth/mfa_modules
|
# required by tests/auth/mfa_modules
|
||||||
pyotp
|
pyotp
|
||||||
] ++ lib.concatMap (component: getPackages component py.pkgs) componentTests;
|
] ++ lib.concatMap (component: getPackages component python.pkgs) [
|
||||||
|
# some components are needed even if tests in tests/components are disabled
|
||||||
# We can reasonably test components that don't communicate with any network
|
|
||||||
# services. Before adding new components to this list make sure we have all
|
|
||||||
# its dependencies packaged and listed in ./component-packages.nix.
|
|
||||||
componentTests = [
|
|
||||||
"abode"
|
|
||||||
"accuweather"
|
|
||||||
"acmeda"
|
|
||||||
"adguard"
|
|
||||||
"advantage_air"
|
|
||||||
"aemet"
|
|
||||||
"agent_dvr"
|
|
||||||
"air_quality"
|
|
||||||
"airly"
|
|
||||||
"airnow"
|
|
||||||
"airthings"
|
|
||||||
"airvisual"
|
|
||||||
"alarm_control_panel"
|
|
||||||
"alarmdecoder"
|
|
||||||
"alert"
|
|
||||||
"alexa"
|
|
||||||
"almond"
|
|
||||||
"ambiclimate"
|
|
||||||
"ambient_station"
|
|
||||||
"analytics"
|
|
||||||
"androidtv"
|
|
||||||
"apache_kafka"
|
|
||||||
"api"
|
|
||||||
"apple_tv"
|
|
||||||
"apprise"
|
|
||||||
"aprs"
|
|
||||||
"arcam_fmj"
|
|
||||||
"arlo"
|
|
||||||
"asuswrt"
|
|
||||||
"atag"
|
|
||||||
"august"
|
|
||||||
"aurora"
|
|
||||||
"auth"
|
|
||||||
"automation"
|
|
||||||
"awair"
|
|
||||||
"aws"
|
|
||||||
"axis"
|
|
||||||
"azure_devops"
|
|
||||||
"azure_event_hub"
|
|
||||||
"bayesian"
|
|
||||||
"binary_sensor"
|
|
||||||
"blackbird"
|
|
||||||
"blebox"
|
|
||||||
"blink"
|
|
||||||
"blueprint"
|
|
||||||
"bluetooth_le_tracker"
|
|
||||||
"bmw_connected_drive"
|
|
||||||
"bond"
|
|
||||||
"bosch_shc"
|
|
||||||
"braviatv"
|
|
||||||
"broadlink"
|
|
||||||
"brother"
|
|
||||||
"bsblan"
|
|
||||||
"buienradar"
|
|
||||||
"caldav"
|
|
||||||
"calendar"
|
|
||||||
"camera"
|
|
||||||
"canary"
|
|
||||||
"cast"
|
|
||||||
"cert_expiry"
|
|
||||||
"climacell"
|
|
||||||
"climate"
|
|
||||||
"cloud"
|
|
||||||
"cloudflare"
|
|
||||||
"color_extractor"
|
|
||||||
"comfoconnect"
|
|
||||||
"command_line"
|
|
||||||
"compensation"
|
|
||||||
"config"
|
|
||||||
"configurator"
|
|
||||||
"control4"
|
|
||||||
"conversation"
|
|
||||||
"coolmaster"
|
|
||||||
"coronavirus"
|
|
||||||
"counter"
|
|
||||||
"cover"
|
|
||||||
"daikin"
|
|
||||||
"darksky"
|
|
||||||
"datadog"
|
|
||||||
"deconz"
|
|
||||||
"default_config"
|
"default_config"
|
||||||
"demo"
|
|
||||||
"denonavr"
|
|
||||||
"derivative"
|
|
||||||
"device_automation"
|
|
||||||
"device_sun_light_trigger"
|
|
||||||
"device_tracker"
|
|
||||||
"devolo_home_control"
|
|
||||||
"dexcom"
|
|
||||||
"dhcp"
|
|
||||||
"dialogflow"
|
|
||||||
"directv"
|
|
||||||
"discovery"
|
|
||||||
"doorbird"
|
|
||||||
"dsmr"
|
|
||||||
"dte_energy_bridge"
|
|
||||||
"duckdns"
|
|
||||||
"dunehd"
|
|
||||||
"eafm"
|
|
||||||
"ecobee"
|
|
||||||
"econet"
|
|
||||||
"efergy"
|
|
||||||
"elgato"
|
|
||||||
"elkm1"
|
|
||||||
"emonitor"
|
|
||||||
"emulated_hue"
|
|
||||||
"emulated_kasa"
|
|
||||||
"emulated_roku"
|
|
||||||
"enocean"
|
|
||||||
"enphase_envoy"
|
|
||||||
"epson"
|
|
||||||
"esphome"
|
|
||||||
"everlights"
|
|
||||||
"ezviz"
|
|
||||||
"faa_delays"
|
|
||||||
"facebook"
|
|
||||||
"facebox"
|
|
||||||
"fail2ban"
|
|
||||||
"fan"
|
|
||||||
"feedreader"
|
|
||||||
"ffmpeg"
|
|
||||||
"fido"
|
|
||||||
"file"
|
|
||||||
"filesize"
|
|
||||||
"filter"
|
|
||||||
"fireservicerota"
|
|
||||||
"firmata"
|
|
||||||
"fjaraskupan"
|
|
||||||
"flick_electric"
|
|
||||||
"flipr"
|
|
||||||
"flo"
|
|
||||||
"flume"
|
|
||||||
"flunearyou"
|
|
||||||
"flux"
|
|
||||||
"folder"
|
|
||||||
"folder_watcher"
|
|
||||||
"foobot"
|
|
||||||
"foscam"
|
|
||||||
"freebox"
|
|
||||||
"freedns"
|
|
||||||
"fritz"
|
|
||||||
"fritzbox"
|
|
||||||
"fritzbox_callmonitor"
|
|
||||||
"frontend"
|
|
||||||
"garages_amsterdam"
|
|
||||||
"gdacs"
|
|
||||||
"generic"
|
|
||||||
"generic_thermostat"
|
|
||||||
"geo_json_events"
|
|
||||||
"geo_location"
|
|
||||||
"geo_rss_events"
|
|
||||||
"geofency"
|
|
||||||
"geonetnz_quakes"
|
|
||||||
"geonetnz_volcano"
|
|
||||||
"gios"
|
|
||||||
# updated to incompatible version and overriding is annoying because of async_timeout<4 pin
|
|
||||||
# "glances"
|
|
||||||
"goalzero"
|
|
||||||
"gogogate2"
|
|
||||||
"google"
|
|
||||||
"google_assistant"
|
|
||||||
"google_domains"
|
|
||||||
"google_pubsub"
|
|
||||||
"google_translate"
|
|
||||||
"google_travel_time"
|
|
||||||
"google_wifi"
|
|
||||||
"gpslogger"
|
|
||||||
"graphite"
|
|
||||||
"gree"
|
|
||||||
"group"
|
|
||||||
"growatt_server"
|
|
||||||
"guardian"
|
|
||||||
"habitica"
|
|
||||||
"hangouts"
|
|
||||||
"harmony"
|
|
||||||
"hassio"
|
|
||||||
"hddtemp"
|
|
||||||
"heos"
|
|
||||||
"here_travel_time"
|
|
||||||
"hisense_aehw4a1"
|
|
||||||
"history"
|
|
||||||
"history_stats"
|
|
||||||
"hive"
|
|
||||||
"hlk_sw16"
|
|
||||||
"home_connect"
|
|
||||||
"home_plus_control"
|
|
||||||
"homeassistant"
|
|
||||||
# disable homekit tests because they fail in the network component
|
|
||||||
#"homekit"
|
|
||||||
"homekit_controller"
|
|
||||||
"homematic"
|
|
||||||
"homematicip_cloud"
|
|
||||||
"honeywell"
|
|
||||||
"html5"
|
|
||||||
"http"
|
|
||||||
"huawei_lte"
|
|
||||||
"hue"
|
"hue"
|
||||||
"huisbaasje"
|
|
||||||
"humidifier"
|
|
||||||
"hunterdouglas_powerview"
|
|
||||||
"hvv_departures"
|
|
||||||
"hyperion"
|
|
||||||
"ialarm"
|
|
||||||
"iaqualink"
|
|
||||||
"icloud"
|
|
||||||
"ifttt"
|
|
||||||
"ign_sismologia"
|
|
||||||
"image"
|
|
||||||
"image_processing"
|
|
||||||
"imap_email_content"
|
|
||||||
"influxdb"
|
|
||||||
"input_boolean"
|
|
||||||
"input_datetime"
|
|
||||||
"input_number"
|
|
||||||
"input_select"
|
|
||||||
"input_text"
|
|
||||||
"insteon"
|
|
||||||
"integration"
|
|
||||||
"intent"
|
|
||||||
"intent_script"
|
|
||||||
"ios"
|
|
||||||
"ipma"
|
|
||||||
"ipp"
|
|
||||||
"iqvia"
|
|
||||||
"islamic_prayer_times"
|
|
||||||
"isy994"
|
|
||||||
"izone"
|
|
||||||
"jewish_calendar"
|
|
||||||
"juicenet"
|
|
||||||
"keenetic_ndms2"
|
|
||||||
"kira"
|
|
||||||
"kmtronic"
|
|
||||||
"knx"
|
|
||||||
"kodi"
|
|
||||||
"konnected"
|
|
||||||
"kraken"
|
|
||||||
"kulersky"
|
|
||||||
"lastfm"
|
|
||||||
"lcn"
|
|
||||||
"light"
|
|
||||||
"litterrobot"
|
|
||||||
"local_file"
|
|
||||||
"local_ip"
|
|
||||||
"locative"
|
|
||||||
"lock"
|
|
||||||
"logbook"
|
|
||||||
"logentries"
|
|
||||||
"logger"
|
|
||||||
"london_air"
|
|
||||||
"lovelace"
|
|
||||||
"luftdaten"
|
|
||||||
"lutron_caseta"
|
|
||||||
"lyric"
|
|
||||||
"mailbox"
|
|
||||||
"manual"
|
|
||||||
"manual_mqtt"
|
|
||||||
"maxcube"
|
|
||||||
"mazda"
|
|
||||||
"media_player"
|
|
||||||
"media_source"
|
|
||||||
"melcloud"
|
|
||||||
"meraki"
|
|
||||||
"met"
|
|
||||||
"met_eireann"
|
|
||||||
"meteoclimatic"
|
|
||||||
"mhz19"
|
|
||||||
"microsoft_face"
|
|
||||||
"microsoft_face_detect"
|
|
||||||
"microsoft_face_identify"
|
|
||||||
"mikrotik"
|
|
||||||
"mill"
|
|
||||||
"min_max"
|
|
||||||
"minecraft_server"
|
|
||||||
"minio"
|
|
||||||
"mobile_app"
|
|
||||||
"modbus"
|
|
||||||
"mold_indicator"
|
|
||||||
"moon"
|
|
||||||
"motion_blinds"
|
|
||||||
"motioneye"
|
|
||||||
"mqtt"
|
|
||||||
"mqtt_eventstream"
|
|
||||||
"mqtt_json"
|
|
||||||
"mqtt_room"
|
|
||||||
"mqtt_statestream"
|
|
||||||
"mullvad"
|
|
||||||
"mutesync"
|
|
||||||
"my"
|
|
||||||
"myq"
|
|
||||||
"mysensors"
|
|
||||||
"mythicbeastsdns"
|
|
||||||
"nam"
|
|
||||||
"namecheapdns"
|
|
||||||
"neato"
|
|
||||||
"ness_alarm"
|
|
||||||
# python-nest has an unfree license, this prevents builds through ofborg
|
|
||||||
# "nest"
|
|
||||||
"netatmo"
|
|
||||||
"nexia"
|
|
||||||
"nightscout"
|
|
||||||
"no_ip"
|
|
||||||
"notify"
|
|
||||||
"notion"
|
|
||||||
"nsw_rural_fire_service_feed"
|
|
||||||
"nuki"
|
|
||||||
"number"
|
|
||||||
"nws"
|
|
||||||
"nx584"
|
|
||||||
"octoprint"
|
|
||||||
"omnilogic"
|
|
||||||
"onboarding"
|
|
||||||
"ondilo_ico"
|
|
||||||
"openalpr_cloud"
|
|
||||||
"openalpr_local"
|
|
||||||
"openerz"
|
|
||||||
"openhardwaremonitor"
|
|
||||||
"opentherm_gw"
|
|
||||||
"openuv"
|
|
||||||
"openweathermap"
|
|
||||||
"opnsense"
|
|
||||||
"ovo_energy"
|
|
||||||
"owntracks"
|
|
||||||
"ozw"
|
|
||||||
"p1_monitor"
|
|
||||||
"panel_custom"
|
|
||||||
"panel_iframe"
|
|
||||||
"persistent_notification"
|
|
||||||
"person"
|
|
||||||
"philips_js"
|
|
||||||
"pi_hole"
|
|
||||||
"picnic"
|
|
||||||
"ping"
|
|
||||||
"plaato"
|
|
||||||
"plant"
|
|
||||||
"plex"
|
|
||||||
"plugwise"
|
|
||||||
"point"
|
|
||||||
"poolsense"
|
|
||||||
"profiler"
|
|
||||||
"prometheus"
|
|
||||||
"proximity"
|
|
||||||
"push"
|
|
||||||
"pushbullet"
|
|
||||||
"pvpc_hourly_pricing"
|
|
||||||
"python_script"
|
|
||||||
"qld_bushfire"
|
|
||||||
"rachio"
|
|
||||||
"radarr"
|
|
||||||
"rainmachine"
|
|
||||||
"random"
|
|
||||||
"recollect_waste"
|
|
||||||
"recorder"
|
|
||||||
"reddit"
|
|
||||||
"remote"
|
|
||||||
"renault"
|
|
||||||
"rest"
|
|
||||||
"rest_command"
|
|
||||||
"rflink"
|
|
||||||
"rfxtrx"
|
|
||||||
"ring"
|
|
||||||
"risco"
|
|
||||||
"rituals_perfume_genie"
|
|
||||||
"rmvtransport"
|
|
||||||
"roku"
|
|
||||||
"roomba"
|
|
||||||
"roon"
|
|
||||||
"rss_feed_template"
|
|
||||||
"ruckus_unleashed"
|
|
||||||
"safe_mode"
|
|
||||||
"samsungtv"
|
|
||||||
"scene"
|
|
||||||
"screenlogic"
|
|
||||||
"script"
|
|
||||||
"search"
|
|
||||||
"season"
|
|
||||||
"sense"
|
|
||||||
"sensor"
|
|
||||||
"sentry"
|
|
||||||
"sharkiq"
|
|
||||||
"shell_command"
|
|
||||||
"shelly"
|
|
||||||
"shopping_list"
|
|
||||||
"sia"
|
|
||||||
"sigfox"
|
|
||||||
"sighthound"
|
|
||||||
"simplisafe"
|
|
||||||
"simulated"
|
|
||||||
"slack"
|
|
||||||
"sleepiq"
|
|
||||||
"sma"
|
|
||||||
"smappee"
|
|
||||||
"smart_meter_texas"
|
|
||||||
"smarthab"
|
|
||||||
"smartthings"
|
|
||||||
"smarttub"
|
|
||||||
"smhi"
|
|
||||||
"smtp"
|
|
||||||
"snips"
|
|
||||||
"solaredge"
|
|
||||||
"soma"
|
|
||||||
"somfy"
|
|
||||||
"somfy_mylink"
|
|
||||||
"sonarr"
|
|
||||||
"songpal"
|
|
||||||
# disable sonos components test because they rely on ssdp, which doesn't work in our sandbox
|
|
||||||
# "sonos"
|
|
||||||
"soundtouch"
|
|
||||||
"spaceapi"
|
|
||||||
"spc"
|
|
||||||
"speedtestdotnet"
|
|
||||||
"spider"
|
|
||||||
"spotify"
|
|
||||||
"sql"
|
|
||||||
"squeezebox"
|
|
||||||
"srp_energy"
|
|
||||||
"ssdp"
|
|
||||||
"starline"
|
|
||||||
"startca"
|
|
||||||
"statistics"
|
|
||||||
"statsd"
|
|
||||||
"stream"
|
|
||||||
"stt"
|
|
||||||
"subaru"
|
|
||||||
"sun"
|
|
||||||
"surepetcare"
|
|
||||||
"switch"
|
|
||||||
"switcher_kis"
|
|
||||||
"syncthing"
|
|
||||||
"syncthru"
|
|
||||||
"synology_dsm"
|
|
||||||
"system_health"
|
|
||||||
"system_log"
|
|
||||||
"tado"
|
|
||||||
"tag"
|
|
||||||
"tasmota"
|
|
||||||
"tcp"
|
|
||||||
"telegram"
|
|
||||||
"tellduslive"
|
|
||||||
"template"
|
|
||||||
"threshold"
|
|
||||||
"tibber"
|
|
||||||
"tile"
|
|
||||||
"time_date"
|
|
||||||
"timer"
|
|
||||||
"tod"
|
|
||||||
"tomato"
|
|
||||||
"toon"
|
|
||||||
"totalconnect"
|
|
||||||
"tplink"
|
|
||||||
"traccar"
|
|
||||||
"trace"
|
|
||||||
"tradfri"
|
|
||||||
"transmission"
|
|
||||||
"transport_nsw"
|
|
||||||
"trend"
|
|
||||||
"tts"
|
|
||||||
"tuya"
|
|
||||||
"twentemilieu"
|
|
||||||
"twilio"
|
|
||||||
"twinkly"
|
|
||||||
"twitch"
|
|
||||||
"uk_transport"
|
|
||||||
"unifi"
|
|
||||||
"unifi_direct"
|
|
||||||
"universal"
|
|
||||||
"upb"
|
|
||||||
"upcloud"
|
|
||||||
"updater"
|
|
||||||
# disabled, because it tries to join a multicast group and fails to find a usable network interface
|
|
||||||
# "upnp"
|
|
||||||
"uptime"
|
|
||||||
"uptimerobot"
|
|
||||||
"usgs_earthquakes_feed"
|
|
||||||
"utility_meter"
|
|
||||||
"uvc"
|
|
||||||
"vacuum"
|
|
||||||
"velbus"
|
|
||||||
# disabled, because it includes onewire component tests, for which we lack p1wire dependency
|
|
||||||
# "venstar"
|
|
||||||
"vera"
|
|
||||||
"verisure"
|
|
||||||
"version"
|
|
||||||
"vesync"
|
|
||||||
"vilfo"
|
|
||||||
"vizio"
|
|
||||||
"vlc_telnet"
|
|
||||||
"voicerss"
|
|
||||||
"volumio"
|
|
||||||
"vultr"
|
|
||||||
"wake_on_lan"
|
|
||||||
"wallbox"
|
|
||||||
"water_heater"
|
|
||||||
"waze_travel_time"
|
|
||||||
"weather"
|
|
||||||
"webhook"
|
|
||||||
"webostv"
|
|
||||||
"websocket_api"
|
|
||||||
"wemo"
|
|
||||||
"wiffi"
|
|
||||||
"wilight"
|
|
||||||
"wled"
|
|
||||||
"workday"
|
|
||||||
"worldclock"
|
|
||||||
"wsdot"
|
|
||||||
"xbox"
|
|
||||||
"xiaomi"
|
|
||||||
"xiaomi_aqara"
|
|
||||||
# disabled, because we require cryptography>=35.0 for the miio package
|
|
||||||
# "xiaomi_miio"
|
|
||||||
"yamaha"
|
|
||||||
"yandex_transport"
|
|
||||||
"yandextts"
|
|
||||||
"yeelight"
|
|
||||||
"youless"
|
|
||||||
# disabled, because it tries to join a multicast group and fails to find a usable network interface
|
|
||||||
# "zeroconf"
|
|
||||||
"zerproc"
|
|
||||||
"zha"
|
|
||||||
"zodiac"
|
|
||||||
"zone"
|
|
||||||
"zwave"
|
|
||||||
"zwave_js"
|
|
||||||
] ++ lib.optionals (builtins.any (s: s == stdenv.hostPlatform.system) debugpy.meta.platforms) [
|
|
||||||
"debugpy"
|
|
||||||
];
|
];
|
||||||
|
|
||||||
pytestFlagsArray = [
|
pytestFlagsArray = [
|
||||||
@ -919,120 +289,46 @@ in with py.pkgs; buildPythonApplication rec {
|
|||||||
"--only-rerun RuntimeError"
|
"--only-rerun RuntimeError"
|
||||||
# enable full variable printing on error
|
# enable full variable printing on error
|
||||||
"--showlocals"
|
"--showlocals"
|
||||||
# here_travel_time/test_sensor.py: Tries to access HERE API: herepy.error.HEREError: Error occured on __get
|
|
||||||
"--deselect tests/components/here_travel_time/test_sensor.py::test_invalid_credentials"
|
|
||||||
# screenlogic/test_config_flow.py: Tries to send out UDP broadcasts
|
|
||||||
"--deselect tests/components/screenlogic/test_config_flow.py::test_form_cannot_connect"
|
|
||||||
# abode/test_camera.py: Race condition in pickle file creationg
|
|
||||||
"--deselect tests/components/abode/test_camera.py::test_camera_off"
|
|
||||||
# asuswrt/test_config_flow.py: Sandbox network limitations, fails with unexpected error
|
|
||||||
"--deselect tests/components/asuswrt/test_config_flow.py::test_on_connect_failed"
|
|
||||||
# shelly/test_config_flow.py: Tries to join multicast group
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_form"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_title_without_name"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_form_auth"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_form_errors_test_connection"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_user_setup_ignored_device"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_form_auth_errors_test_connection"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_form_auth_errors_test_connection"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_form_auth_errors_test_connection"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_zeroconf"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_zeroconf_sleeping_device"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_zeroconf_sleeping_device_error"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_zeroconf_sleeping_device_error"
|
|
||||||
"--deselect tests/components/shelly/test_config_flow.py::test_zeroconf_require_auth"
|
|
||||||
# prometheus/test_init.py: Spurious AssertionError regarding humidifier_target_humidity_percent metric
|
|
||||||
"--deselect tests/components/prometheus/test_init.py::test_view"
|
|
||||||
# smhi/test_init.py: Tries to fetch data from the network: socket.gaierror: [Errno -2] Name or service not known
|
|
||||||
"--deselect tests/components/smhi/test_init.py::test_remove_entry"
|
|
||||||
# wallbox/test_config_flow.py: Tries to connect to api.wall-box.cim: Failed to establish a new connection: [Errno -2] Name or service not known
|
|
||||||
"--deselect tests/components/wallbox/test_config_flow.py::test_form_invalid_auth"
|
|
||||||
"--deselect tests/components/wallbox/test_config_flow.py::test_form_cannot_connect"
|
|
||||||
# default_config/test_init.py: Tries to check for updates and fails ungracefully without network access
|
|
||||||
"--deselect tests/components/default_config/test_init.py::test_setup"
|
|
||||||
# local_ip/test_{init,config_flow}.py: tries to lookup a route towards a multicast address and fails
|
|
||||||
"--deselect tests/components/local_ip/test_init.py::test_basic_setup"
|
|
||||||
"--deselect tests/components/local_ip/test_config_flow.py::test_config_flow"
|
|
||||||
# netatmo/test_select.py: NoneType object has no attribute state
|
|
||||||
"--deselect tests/components/netatmo/test_select.py::test_select_schedule_thermostats"
|
|
||||||
# wemo/test_sensor.py: KeyError for various power attributes
|
|
||||||
"--deselect tests/components/wemo/test_sensor.py::TestInsightTodayEnergy::test_state_unavailable"
|
|
||||||
"--deselect tests/components/wemo/test_sensor.py::TestInsightCurrentPower::test_state_unavailable"
|
|
||||||
# helpers/test_system_info.py: AssertionError: assert 'Unknown' == 'Home Assistant Container'
|
# helpers/test_system_info.py: AssertionError: assert 'Unknown' == 'Home Assistant Container'
|
||||||
"--deselect tests/helpers/test_system_info.py::test_container_installationtype"
|
"--deselect tests/helpers/test_system_info.py::test_container_installationtype"
|
||||||
# tests are located in tests/
|
# tests are located in tests/
|
||||||
"tests"
|
"tests"
|
||||||
# dynamically add packages required for component tests
|
];
|
||||||
] ++ map (component: "tests/components/" + component) componentTests;
|
|
||||||
|
|
||||||
disabledTestPaths = [
|
disabledTestPaths = [
|
||||||
# don't bulk test all components
|
# don't bulk test all components
|
||||||
"tests/components"
|
"tests/components"
|
||||||
# pyotp since v2.4.0 complains about the short mock keys, hass pins v2.3.0
|
# pyotp since v2.4.0 complains about the short mock keys, hass pins v2.3.0
|
||||||
"tests/auth/mfa_modules/test_notify.py"
|
"tests/auth/mfa_modules/test_notify.py"
|
||||||
# emulated_hue/test_upnp.py: Tries to establish the public ipv4 address
|
|
||||||
"tests/components/emulated_hue/test_upnp.py"
|
|
||||||
# tado/test_{climate,water_heater}.py: Tries to connect to my.tado.com
|
|
||||||
"tests/components/tado/test_climate.py"
|
|
||||||
"tests/components/tado/test_water_heater.py"
|
|
||||||
];
|
];
|
||||||
|
|
||||||
disabledTests = [
|
disabledTests = [
|
||||||
# AssertionError: assert 1 == 0
|
# AssertionError: assert 1 == 0
|
||||||
"test_error_posted_as_event"
|
|
||||||
"test_merge"
|
"test_merge"
|
||||||
# ModuleNotFoundError: No module named 'pyqwikswitch'
|
|
||||||
"test_merge_id_schema"
|
|
||||||
# keyring.errors.NoKeyringError: No recommended backend was available.
|
|
||||||
"test_secrets_from_unrelated_fails"
|
|
||||||
"test_secrets_credstash"
|
|
||||||
# generic/test_camera.py: AssertionError: 500 == 200
|
|
||||||
"test_fetching_without_verify_ssl"
|
|
||||||
"test_fetching_url_with_verify_ssl"
|
|
||||||
# util/test_package.py: AssertionError on package.is_installed('homeassistant>=999.999.999')
|
|
||||||
"test_check_package_version_does_not_match"
|
|
||||||
# homeassistant/util/thread.py:51: SystemError
|
|
||||||
"test_executor_shutdown_can_interrupt_threads"
|
|
||||||
# {'theme_color': '#03A9F4'} != {'theme_color': 'blue'}
|
|
||||||
"test_webhook_handle_get_config"
|
|
||||||
# onboarding tests rpi_power component, for which we are lacking rpi_bad_power library
|
|
||||||
"test_onboarding_core_sets_up_rpi_power"
|
|
||||||
"test_onboarding_core_no_rpi_power"
|
|
||||||
# hue/test_sensor_base.py: Race condition when counting events
|
|
||||||
"test_hue_events"
|
|
||||||
# august/test_lock.py: AssertionError: assert 'unlocked' == 'locked' / assert 'off' == 'on'
|
|
||||||
"test_lock_update_via_pubnub"
|
|
||||||
"test_door_sense_update_via_pubnub"
|
|
||||||
# Tests are flaky
|
# Tests are flaky
|
||||||
"test_config_platform_valid"
|
"test_config_platform_valid"
|
||||||
"test_hls_stream"
|
|
||||||
];
|
];
|
||||||
|
|
||||||
preCheck = ''
|
preCheck = ''
|
||||||
export HOME="$TEMPDIR"
|
export HOME="$TEMPDIR"
|
||||||
|
|
||||||
patch -p1 < ${./patches/tests-mock-source-ip.patch}
|
|
||||||
|
|
||||||
# the tests require the existance of a media dir
|
# the tests require the existance of a media dir
|
||||||
mkdir /build/media
|
mkdir /build/media
|
||||||
|
|
||||||
# put ping binary into PATH, e.g. for wake_on_lan tests
|
# put ping binary into PATH, e.g. for wake_on_lan tests
|
||||||
export PATH=${inetutils}/bin:$PATH
|
export PATH=${inetutils}/bin:$PATH
|
||||||
|
|
||||||
# error out when component test directory is missing, otherwise hidden by xdist execution :(
|
|
||||||
for component in ${lib.concatStringsSep " " (map lib.escapeShellArg componentTests)}; do
|
|
||||||
test -d "tests/components/$component" || {
|
|
||||||
>2& echo "ERROR: Tests for component '$component' were enabled, but they do not exist!"
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
done
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
passthru = {
|
passthru = {
|
||||||
inherit availableComponents extraComponents;
|
inherit
|
||||||
python = py;
|
availableComponents
|
||||||
|
extraComponents
|
||||||
|
getPackages
|
||||||
|
python
|
||||||
|
supportedComponentsWithTests;
|
||||||
tests = {
|
tests = {
|
||||||
inherit (nixosTests) home-assistant;
|
nixos = nixosTests.home-assistant;
|
||||||
|
components = callPackage ./tests.nix { };
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -62,6 +62,7 @@ def get_version():
|
|||||||
|
|
||||||
def parse_components(version: str = "master"):
|
def parse_components(version: str = "master"):
|
||||||
components = {}
|
components = {}
|
||||||
|
components_with_tests = []
|
||||||
with tempfile.TemporaryDirectory() as tmp:
|
with tempfile.TemporaryDirectory() as tmp:
|
||||||
with urlopen(
|
with urlopen(
|
||||||
f"https://github.com/home-assistant/home-assistant/archive/{version}.tar.gz"
|
f"https://github.com/home-assistant/home-assistant/archive/{version}.tar.gz"
|
||||||
@ -69,9 +70,13 @@ def parse_components(version: str = "master"):
|
|||||||
tarfile.open(fileobj=BytesIO(response.read())).extractall(tmp)
|
tarfile.open(fileobj=BytesIO(response.read())).extractall(tmp)
|
||||||
# Use part of a script from the Home Assistant codebase
|
# Use part of a script from the Home Assistant codebase
|
||||||
core_path = os.path.join(tmp, f"core-{version}")
|
core_path = os.path.join(tmp, f"core-{version}")
|
||||||
|
|
||||||
|
for entry in os.scandir(os.path.join(core_path, "tests/components")):
|
||||||
|
if entry.is_dir():
|
||||||
|
components_with_tests.append(entry.name)
|
||||||
|
|
||||||
sys.path.append(core_path)
|
sys.path.append(core_path)
|
||||||
from script.hassfest.model import Integration
|
from script.hassfest.model import Integration
|
||||||
|
|
||||||
integrations = Integration.load_dir(
|
integrations = Integration.load_dir(
|
||||||
pathlib.Path(
|
pathlib.Path(
|
||||||
os.path.join(core_path, "homeassistant/components")
|
os.path.join(core_path, "homeassistant/components")
|
||||||
@ -81,7 +86,8 @@ def parse_components(version: str = "master"):
|
|||||||
integration = integrations[domain]
|
integration = integrations[domain]
|
||||||
if not integration.disabled:
|
if not integration.disabled:
|
||||||
components[domain] = integration.manifest
|
components[domain] = integration.manifest
|
||||||
return components
|
|
||||||
|
return components, components_with_tests
|
||||||
|
|
||||||
|
|
||||||
# Recursively get the requirements of a component and its dependencies
|
# Recursively get the requirements of a component and its dependencies
|
||||||
@ -162,7 +168,7 @@ def main() -> None:
|
|||||||
packages = dump_packages()
|
packages = dump_packages()
|
||||||
version = get_version()
|
version = get_version()
|
||||||
print("Generating component-packages.nix for version {}".format(version))
|
print("Generating component-packages.nix for version {}".format(version))
|
||||||
components = parse_components(version=version)
|
components, components_with_tests = parse_components(version=version)
|
||||||
build_inputs = {}
|
build_inputs = {}
|
||||||
outdated = {}
|
outdated = {}
|
||||||
for component in sorted(components.keys()):
|
for component in sorted(components.keys()):
|
||||||
@ -205,6 +211,13 @@ def main() -> None:
|
|||||||
f.write(f" # missing inputs: {' '.join(missing)}")
|
f.write(f" # missing inputs: {' '.join(missing)}")
|
||||||
f.write("\n")
|
f.write("\n")
|
||||||
f.write(" };\n")
|
f.write(" };\n")
|
||||||
|
f.write(" # components listed in tests/components for which all dependencies are packaged\n")
|
||||||
|
f.write(" supportedComponentsWithTests = [\n")
|
||||||
|
for component, deps in build_inputs.items():
|
||||||
|
available, missing = deps
|
||||||
|
if len(missing) == 0 and component in components_with_tests:
|
||||||
|
f.write(f' "{component}"' + "\n")
|
||||||
|
f.write(" ];\n")
|
||||||
f.write("}\n")
|
f.write("}\n")
|
||||||
|
|
||||||
supported_components = reduce(lambda n, c: n + (build_inputs[c][1] == []),
|
supported_components = reduce(lambda n, c: n + (build_inputs[c][1] == []),
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
diff --git a/homeassistant/components/network/__init__.py b/homeassistant/components/network/__init__.py
|
diff --git a/homeassistant/components/network/__init__.py b/homeassistant/components/network/__init__.py
|
||||||
index 7cc864727d..69333a5454 100644
|
index b3ef88e7ab..b7a8471e1a 100644
|
||||||
--- a/homeassistant/components/network/__init__.py
|
--- a/homeassistant/components/network/__init__.py
|
||||||
+++ b/homeassistant/components/network/__init__.py
|
+++ b/homeassistant/components/network/__init__.py
|
||||||
@@ -26,7 +26,7 @@ async def async_get_source_ip(
|
@@ -30,7 +30,7 @@ async def async_get_source_ip(
|
||||||
) -> str:
|
) -> str:
|
||||||
"""Get the source ip for a target ip."""
|
"""Get the source ip for a target ip."""
|
||||||
adapters = await async_get_adapters(hass)
|
adapters = await async_get_adapters(hass)
|
||||||
|
69
pkgs/servers/home-assistant/tests.nix
Normal file
69
pkgs/servers/home-assistant/tests.nix
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
{ lib
|
||||||
|
, home-assistant
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
# some components' tests have additional dependencies
|
||||||
|
extraCheckInputs = with home-assistant.python.pkgs; {
|
||||||
|
alexa = [ ha-av ];
|
||||||
|
camera = [ ha-av ];
|
||||||
|
cloud = [ mutagen ];
|
||||||
|
config = [ pydispatcher ];
|
||||||
|
generic = [ ha-av ];
|
||||||
|
google_translate = [ mutagen ];
|
||||||
|
nest = [ ha-av ];
|
||||||
|
onboarding = [ pymetno rpi-bad-power ];
|
||||||
|
voicerss = [ mutagen ];
|
||||||
|
yandextts = [ mutagen ];
|
||||||
|
zha = [ pydeconz ];
|
||||||
|
zwave_js = [ homeassistant-pyozw ];
|
||||||
|
};
|
||||||
|
|
||||||
|
extraDisabledTestPaths = {
|
||||||
|
tado = [
|
||||||
|
# tado/test_{climate,water_heater}.py: Tries to connect to my.tado.com
|
||||||
|
"tests/components/tado/test_climate.py"
|
||||||
|
"tests/components/tado/test_water_heater.py"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
extraPytestFlagsArray = {
|
||||||
|
asuswrt = [
|
||||||
|
# asuswrt/test_config_flow.py: Sandbox network limitations, fails with unexpected error
|
||||||
|
"--deselect tests/components/asuswrt/test_config_flow.py::test_on_connect_failed"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
in lib.listToAttrs (map (component: lib.nameValuePair component (
|
||||||
|
home-assistant.overridePythonAttrs (old: {
|
||||||
|
pname = "homeassistant-test-${component}";
|
||||||
|
|
||||||
|
dontBuild = true;
|
||||||
|
dontInstall = true;
|
||||||
|
|
||||||
|
checkInputs = old.checkInputs
|
||||||
|
++ home-assistant.getPackages component home-assistant.python.pkgs
|
||||||
|
++ extraCheckInputs.${component} or [ ];
|
||||||
|
|
||||||
|
disabledTestPaths = old.disabledTestPaths ++ extraDisabledTestPaths.${component} or [ ];
|
||||||
|
|
||||||
|
pytestFlagsArray = lib.remove "tests" old.pytestFlagsArray
|
||||||
|
++ extraPytestFlagsArray.${component} or [ ]
|
||||||
|
++ [ "tests/components/${component}" ];
|
||||||
|
|
||||||
|
preCheck = old.preCheck + lib.optionalString (component != "network") ''
|
||||||
|
patch -p1 < ${./patches/tests-mock-source-ip.patch}
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = old.meta // {
|
||||||
|
broken = lib.elem component [
|
||||||
|
"airtouch4"
|
||||||
|
"glances"
|
||||||
|
"ridwell"
|
||||||
|
"venstar"
|
||||||
|
"yamaha_musiccast"
|
||||||
|
];
|
||||||
|
# upstream only tests on Linux, so do we.
|
||||||
|
platforms = lib.platforms.linux;
|
||||||
|
};
|
||||||
|
})
|
||||||
|
)) home-assistant.supportedComponentsWithTests)
|
@ -21066,6 +21066,8 @@ with pkgs;
|
|||||||
|
|
||||||
home-assistant-cli = callPackage ../servers/home-assistant/cli.nix { };
|
home-assistant-cli = callPackage ../servers/home-assistant/cli.nix { };
|
||||||
|
|
||||||
|
home-assistant-component-tests = recurseIntoAttrs home-assistant.tests.components;
|
||||||
|
|
||||||
hqplayerd = callPackage ../servers/hqplayerd { };
|
hqplayerd = callPackage ../servers/hqplayerd { };
|
||||||
|
|
||||||
https-dns-proxy = callPackage ../servers/dns/https-dns-proxy { };
|
https-dns-proxy = callPackage ../servers/dns/https-dns-proxy { };
|
||||||
|
@ -8639,6 +8639,8 @@ in {
|
|||||||
|
|
||||||
rpdb = callPackage ../development/python-modules/rpdb { };
|
rpdb = callPackage ../development/python-modules/rpdb { };
|
||||||
|
|
||||||
|
rpi-bad-power = callPackage ../development/python-modules/rpi-bad-power { };
|
||||||
|
|
||||||
rply = callPackage ../development/python-modules/rply { };
|
rply = callPackage ../development/python-modules/rply { };
|
||||||
|
|
||||||
rpm = toPythonModule (pkgs.rpm.override {
|
rpm = toPythonModule (pkgs.rpm.override {
|
||||||
|
Loading…
Reference in New Issue
Block a user