fix action Action commit Created package file minor updates Add binary_sensor Updated package file Updated package file Fix BinarySensor Class name Add more descriptions Updated package file Move stuff Updated package file add binary_sensor to resources.json Updated package file Add configuration Updated package file Remove switch Adds CONTRIBUTING Fix broken link Remove refrences Fix links fix broken actions Update actions Updated package file Updated package file Black format Fix config issues Updated package file Fix icon for binary_sensor Add switch platform Update README.md (#1) * Update README.md * Update README.md Update CONTRIBUTING.md (#2) Update __init__.py (#3) * Update __init__.py * Set enabled default to `True` Update const.py (#4) cleanup badges/add style (#5) * shield that supports styling * badge cleanup * Change discord ID Correct typo Create manifest.json (#12) Fixes https://github.com/custom-components/blueprint/issues/10 Move manifest to correct dir Fixes #9 by renaming the file Updates, updates, more updates, worst commit messge ever! revert Update main.workflow Delete resources.json Create example.yaml Update README.md Summer update 😎 Adds info about devcontainer Adds pylint Add translation example remove stalebot Adds integrationhelper adds requirements.txt Adds "tabnine.tabnine-vscode" to devcontainer Add support for config_flow configuration Add config_flow "docs" Update README.md use https for pip install ha@dev (#15) Typo on README.md (#18) Fix various typos in comments (#19) Add hassfest action (#22) * Add hassfest action * Fix manifest issue Spring cleaning ☀️ (#23) * Spring cleaning * Actions * Fix branches * Changes for config_flow Show how to only allow one instance Adds HACS validation action (#24) Update postCreateCommand Update tasks Minor updates (#26) * link correction in README.md and info.md * Add READMME.md for .devcontainer * Add automation.yaml file in the configuration * Complete CONTRIBUTING.md Improve README for container dev and library update. (#27) Feature/setup cfg (#28) * Add setup.cfg * Run black and isort. * Add blueprint to first party. * Make const import consistent. Move translation files Fixes #32 Use CoordinatorEntity (#33) Co-authored-by: Joakim Sørensen <hi@ludeeus.dev> Fixed typos (#34) Fix directory name for translations and link to the documentation (#36) Fix info.md (#40) Use debian based devcontainer (#44) Remove sampleclient (#45) Rename [blueprint|Blueprint] -> [integration_blueprint|Integration blueprint] (#47) Change HACS action (#39) Fix wrong path for link (#48) For an unknown reason the link was pointing to a one of my repository. Probably a too quick copy/paste. Add french translation and strings improvements (#49) Reusing work done on strings.json done in #37 Add example tests (#50) Prepare and explain how to step by step debugging (#51) Add version Fix testing by bumping pytest-homeassistant-custom-component (#54) Fix typo in api.py (#55) passeword -> password Fix a typo in the readme (#56) Update .gitignore to include .idea (#57) Update .gitignore to include .idea for those using Py Charm Add iot_class to manifest Use `enable_custom_integrations` fixture by default (#58) Fix typo (#59) retain user input after an error (#52) Update README.md Closes #61 remove async_timeout.timeout loop arg (#65) Correct name "Blueprint" ->"Integration blueprint" (#64) change entity.py to use extra_state_attributes (#66)
		
			
				
	
	
		
			111 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| """Test integration_blueprint config flow."""
 | |
| from unittest.mock import patch
 | |
| 
 | |
| from homeassistant import config_entries, data_entry_flow
 | |
| import pytest
 | |
| from pytest_homeassistant_custom_component.common import MockConfigEntry
 | |
| 
 | |
| from custom_components.integration_blueprint.const import (
 | |
|     BINARY_SENSOR,
 | |
|     DOMAIN,
 | |
|     PLATFORMS,
 | |
|     SENSOR,
 | |
|     SWITCH,
 | |
| )
 | |
| 
 | |
| from .const import MOCK_CONFIG
 | |
| 
 | |
| 
 | |
| # This fixture bypasses the actual setup of the integration
 | |
| # since we only want to test the config flow. We test the
 | |
| # actual functionality of the integration in other test modules.
 | |
| @pytest.fixture(autouse=True)
 | |
| def bypass_setup_fixture():
 | |
|     """Prevent setup."""
 | |
|     with patch(
 | |
|         "custom_components.integration_blueprint.async_setup",
 | |
|         return_value=True,
 | |
|     ), patch(
 | |
|         "custom_components.integration_blueprint.async_setup_entry",
 | |
|         return_value=True,
 | |
|     ):
 | |
|         yield
 | |
| 
 | |
| 
 | |
| # Here we simiulate a successful config flow from the backend.
 | |
| # Note that we use the `bypass_get_data` fixture here because
 | |
| # we want the config flow validation to succeed during the test.
 | |
| async def test_successful_config_flow(hass, bypass_get_data):
 | |
|     """Test a successful config flow."""
 | |
|     # Initialize a config flow
 | |
|     result = await hass.config_entries.flow.async_init(
 | |
|         DOMAIN, context={"source": config_entries.SOURCE_USER}
 | |
|     )
 | |
| 
 | |
|     # Check that the config flow shows the user form as the first step
 | |
|     assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
 | |
|     assert result["step_id"] == "user"
 | |
| 
 | |
|     # If a user were to enter `test_username` for username and `test_password`
 | |
|     # for password, it would result in this function call
 | |
|     result = await hass.config_entries.flow.async_configure(
 | |
|         result["flow_id"], user_input=MOCK_CONFIG
 | |
|     )
 | |
| 
 | |
|     # Check that the config flow is complete and a new entry is created with
 | |
|     # the input data
 | |
|     assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
 | |
|     assert result["title"] == "test_username"
 | |
|     assert result["data"] == MOCK_CONFIG
 | |
|     assert result["result"]
 | |
| 
 | |
| 
 | |
| # In this case, we want to simulate a failure during the config flow.
 | |
| # We use the `error_on_get_data` mock instead of `bypass_get_data`
 | |
| # (note the function parameters) to raise an Exception during
 | |
| # validation of the input config.
 | |
| async def test_failed_config_flow(hass, error_on_get_data):
 | |
|     """Test a failed config flow due to credential validation failure."""
 | |
|     result = await hass.config_entries.flow.async_init(
 | |
|         DOMAIN, context={"source": config_entries.SOURCE_USER}
 | |
|     )
 | |
| 
 | |
|     assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
 | |
|     assert result["step_id"] == "user"
 | |
| 
 | |
|     result = await hass.config_entries.flow.async_configure(
 | |
|         result["flow_id"], user_input=MOCK_CONFIG
 | |
|     )
 | |
| 
 | |
|     assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
 | |
|     assert result["errors"] == {"base": "auth"}
 | |
| 
 | |
| 
 | |
| # Our config flow also has an options flow, so we must test it as well.
 | |
| async def test_options_flow(hass):
 | |
|     """Test an options flow."""
 | |
|     # Create a new MockConfigEntry and add to HASS (we're bypassing config
 | |
|     # flow entirely)
 | |
|     entry = MockConfigEntry(domain=DOMAIN, data=MOCK_CONFIG, entry_id="test")
 | |
|     entry.add_to_hass(hass)
 | |
| 
 | |
|     # Initialize an options flow
 | |
|     result = await hass.config_entries.options.async_init(entry.entry_id)
 | |
| 
 | |
|     # Verify that the first options step is a user form
 | |
|     assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
 | |
|     assert result["step_id"] == "user"
 | |
| 
 | |
|     # Enter some fake data into the form
 | |
|     result = await hass.config_entries.options.async_configure(
 | |
|         result["flow_id"],
 | |
|         user_input={platform: platform != SENSOR for platform in PLATFORMS},
 | |
|     )
 | |
| 
 | |
|     # Verify that the flow finishes
 | |
|     assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
 | |
|     assert result["title"] == "test_username"
 | |
| 
 | |
|     # Verify that the options were updated
 | |
|     assert entry.options == {BINARY_SENSOR: True, SENSOR: False, SWITCH: True}
 |