diff --git a/.github/workflows/hassfest.yaml b/.github/workflows/hassfest.yaml index 18c7d19..8fe5df7 100644 --- a/.github/workflows/hassfest.yaml +++ b/.github/workflows/hassfest.yaml @@ -10,5 +10,5 @@ jobs: validate: runs-on: "ubuntu-latest" steps: - - uses: "actions/checkout@v2" + - uses: "actions/checkout@v4" - uses: home-assistant/actions/hassfest@master diff --git a/.github/workflows/ruff.yml b/.github/workflows/ruff.yml new file mode 100644 index 0000000..5b8f29e --- /dev/null +++ b/.github/workflows/ruff.yml @@ -0,0 +1,10 @@ +name: Ruff + +on: [ push, pull_request ] + +jobs: + ruff: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: chartboost/ruff-action@v1 diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml deleted file mode 100644 index bd1f54f..0000000 --- a/.github/workflows/test.yml +++ /dev/null @@ -1,38 +0,0 @@ -name: Tests - -on: [push, pull_request] - -jobs: - test: - runs-on: ubuntu-latest - strategy: - matrix: - python-version: - - "3.9" - - "3.10" - - "3.11" - steps: - - uses: actions/checkout@v2 - - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v2 - with: - python-version: ${{ matrix.python-version }} - - name: Get full python version - id: full-python-version - run: | - echo ::set-output name=version::$(python -c "import sys; print('-'.join(str(v) for v in sys.version_info[:3]))") - - name: Set up cache - uses: actions/cache@v2 - with: - path: .venv - key: ${{ runner.os }}-venv-${{ steps.full-python-version.outputs.version }}-${{ hashFiles('**/poetry.lock') }} - - name: Build venv - run: python -m venv .venv - - name: Install dependencies - run: .venv/bin/pip3 install isort black pylama - - name: isort - run: .venv/bin/isort --check custom_components/chargeamps - - name: black - run: .venv/bin/black --check custom_components/chargeamps - - name: pylama - run: .venv/bin/pylama custom_components/chargeamps diff --git a/custom_components/chargeamps/__init__.py b/custom_components/chargeamps/__init__.py index 68221ad..098ea7c 100644 --- a/custom_components/chargeamps/__init__.py +++ b/custom_components/chargeamps/__init__.py @@ -309,9 +309,9 @@ async def _update_data(self, charge_point_id, force: bool = False): charge_point_id, connector_status.connector_id ) ) - self.hass.data[DOMAIN_DATA]["connector_settings"][ - key - ] = connector_settings + self.hass.data[DOMAIN_DATA]["connector_settings"][key] = ( + connector_settings + ) total_energy = sum( [ v.total_consumption_kwh @@ -323,13 +323,13 @@ async def _update_data(self, charge_point_id, force: bool = False): charge_point_id, total_energy, ) - self.hass.data[DOMAIN_DATA]["chargepoint_total_energy"][ - charge_point_id - ] = round(total_energy, 2) + self.hass.data[DOMAIN_DATA]["chargepoint_total_energy"][charge_point_id] = ( + round(total_energy, 2) + ) settings = await self.client.get_chargepoint_settings(charge_point_id) - self.hass.data[DOMAIN_DATA]["chargepoint_settings"][ - charge_point_id - ] = settings + self.hass.data[DOMAIN_DATA]["chargepoint_settings"][charge_point_id] = ( + settings + ) except Exception as error: # pylint: disable=broad-except _LOGGER.error("Could not update data - %s", error) diff --git a/custom_components/chargeamps/light.py b/custom_components/chargeamps/light.py index 6c090bb..c2e733b 100644 --- a/custom_components/chargeamps/light.py +++ b/custom_components/chargeamps/light.py @@ -10,9 +10,7 @@ _LOGGER = logging.getLogger(__name__) -async def async_setup_platform( - hass, config, async_add_entities, discovery_info=None -): # pylint: disable=unused-argument +async def async_setup_platform(hass, config, async_add_entities, discovery_info=None): # pylint: disable=unused-argument """Setup light platform.""" lights = [] handler = hass.data[DOMAIN_DATA]["handler"] diff --git a/custom_components/chargeamps/sensor.py b/custom_components/chargeamps/sensor.py index 642b6b9..dfcdc1b 100644 --- a/custom_components/chargeamps/sensor.py +++ b/custom_components/chargeamps/sensor.py @@ -15,9 +15,7 @@ _LOGGER = logging.getLogger(__name__) -async def async_setup_platform( - hass, config, async_add_entities, discovery_info=None -): # pylint: disable=unused-argument +async def async_setup_platform(hass, config, async_add_entities, discovery_info=None): # pylint: disable=unused-argument """Setup sensor platform.""" sensors = [] handler = hass.data[DOMAIN_DATA]["handler"] diff --git a/custom_components/chargeamps/switch.py b/custom_components/chargeamps/switch.py index 4d12ed8..cfbf237 100644 --- a/custom_components/chargeamps/switch.py +++ b/custom_components/chargeamps/switch.py @@ -10,9 +10,7 @@ _LOGGER = logging.getLogger(__name__) -async def async_setup_platform( - hass, config, async_add_entities, discovery_info=None -): # pylint: disable=unused-argument +async def async_setup_platform(hass, config, async_add_entities, discovery_info=None): # pylint: disable=unused-argument """Setup switch platform.""" switches = [] handler = hass.data[DOMAIN_DATA]["handler"] diff --git a/pyproject.toml b/pyproject.toml new file mode 100644 index 0000000..65fa9f8 --- /dev/null +++ b/pyproject.toml @@ -0,0 +1,22 @@ +[tool.isort] +profile = "black" + +[tool.ruff] +line-length = 132 + +[tool.ruff.lint] +select = [ + # pycodestyle + "E", + # Pyflakes + "F", + # pyupgrade + "UP", + # flake8-bugbear + "B", + # flake8-simplify + "SIM", + # isort + "I", +] +ignore = ["I001"]