Skip to main content

Experimental package to automatically extract test plugins for Home Assistant custom components

Project description

pytest-homeassistant-custom-component

HA core version

Package to automatically extract testing plugins from Home Assistant for custom component testing. The goal is to provide the same functionality as the tests in home-assistant/core. pytest-homeassistant-custom-component is updated daily according to the latest homeassistant release including beta.

Usage:

  • All pytest fixtures can be used as normal, like hass
  • For helpers:
    • home-assistant/core native test: from tests.common import MockConfigEntry
    • custom component test: from pytest_homeassistant_custom_component.common import MockConfigEntry
  • If your integration is inside a custom_components folder, a custom_components/__init__.py file or changes to sys.path may be required.
  • enable_custom_integrations fixture is required (versions >=2021.6.0b0)
  • pytest-asyncio might now require asyncio_mode = auto config, see #129.
  • If using load_fixture, the files need to be in a fixtures folder colocated with the tests. For example, a test in test_sensor.py can load data from some_data.json using load_fixture from this structure:
tests/
   fixtures/
      some_data.json
   test_sensor.py
  • When using syrupy snapshots, add a snapshot fixture to conftest.py to make sure the snapshots are loaded from snapshot folder colocated with the tests.
    from pytest_homeassistant_custom_component.syrupy import HomeAssistantSnapshotExtension
    from syrupy.assertion import SnapshotAssertion


    @pytest.fixture
    def snapshot(snapshot: SnapshotAssertion) -> SnapshotAssertion:
        """Return snapshot assertion fixture with the Home Assistant extension."""
        return snapshot.use_extension(HomeAssistantSnapshotExtension)

Examples:

More Info

This repository is set up to be nearly fully automatic.

  • Version of home-assistant/core is given in ha_version, pytest_homeassistant_custom_component.const, and in the README above.
  • This package is generated against published releases of homeassistant and updated daily.
  • PRs should not include changes to the pytest_homeassistant_custom_component files. CI testing will automatically generate the new files.

Version Strategy

  • When changes in extraction are required, there will be a change in the minor version.
  • A change in the patch version indicates that it was an automatic update with a homeassistant version.
  • This enables tracking back to which versions of pytest-homeassistant-custom-component can be used for extracting testing utilities from which version of homeassistant.

This package was inspired by pytest-homeassistant by @boralyl, but is intended to more closely and automatically track the home-assistant/core library.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file pytest_homeassistant_custom_component_framework-1.0.5.tar.gz.

File metadata

File hashes

Hashes for pytest_homeassistant_custom_component_framework-1.0.5.tar.gz
Algorithm Hash digest
SHA256 1fb821fd7b54f212a5b9b59fcd2163001cf9ace73d593ce0ab9ff145ab833d44
MD5 a96c1ccc8b8c15a7255c8d16a2600e5d
BLAKE2b-256 e5fe85b6539c10a5190281e0d65b0dfedd2e44a8d6cc9a13a640de688bea21c1

See more details on using hashes here.

File details

Details for the file pytest_homeassistant_custom_component_framework-1.0.5-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_homeassistant_custom_component_framework-1.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 ee052e20d8bab4003e6772d6abe3d8da84041f79d226204fee29d90401fad9df
MD5 0a37b82b654ae15002e4fb237f4f26b6
BLAKE2b-256 0ee2086cdee2a9bd7ee0a723f6e121d73d7ee9c87a0d3d3b0c5d157b1083361e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page