Merge branch 'main' of https://github.com/Fabian-Schmidt/esphome-truma_inetbox
This commit is contained in:
commit
e09137ef94
96
.github/workflows/main.yml
vendored
Normal file
96
.github/workflows/main.yml
vendored
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
|
||||||
|
---
|
||||||
|
name: CI
|
||||||
|
|
||||||
|
# yamllint disable-line rule:truthy
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [dev, beta, release]
|
||||||
|
|
||||||
|
pull_request:
|
||||||
|
merge_group:
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
# yamllint disable-line rule:line-length
|
||||||
|
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
ci:
|
||||||
|
name: ${{ matrix.name }}
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- id: test
|
||||||
|
file: tests/test1.yaml
|
||||||
|
name: Test tests/test1.yaml
|
||||||
|
pio_cache_key: test1
|
||||||
|
#- id: test
|
||||||
|
# file: tests/test2.yaml
|
||||||
|
# name: Test tests/test2.yaml
|
||||||
|
# pio_cache_key: test2
|
||||||
|
#- id: test
|
||||||
|
# file: tests/test3.yaml
|
||||||
|
# name: Test tests/test3.yaml
|
||||||
|
# pio_cache_key: test3
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- name: Set up Python
|
||||||
|
uses: actions/setup-python@v4
|
||||||
|
id: python
|
||||||
|
with:
|
||||||
|
python-version: "3.9"
|
||||||
|
|
||||||
|
- name: Cache virtualenv
|
||||||
|
uses: actions/cache@v3
|
||||||
|
with:
|
||||||
|
path: .venv
|
||||||
|
# yamllint disable-line rule:line-length
|
||||||
|
key: venv-${{ steps.python.outputs.python-version }}-${{ hashFiles('requirements*.txt') }}
|
||||||
|
restore-keys: |
|
||||||
|
venv-${{ steps.python.outputs.python-version }}-
|
||||||
|
|
||||||
|
- name: Set up virtualenv
|
||||||
|
# yamllint disable rule:line-length
|
||||||
|
run: |
|
||||||
|
python -m venv .venv
|
||||||
|
source .venv/bin/activate
|
||||||
|
pip install -U pip
|
||||||
|
pip install esphome
|
||||||
|
echo "$GITHUB_WORKSPACE/.venv/bin" >> $GITHUB_PATH
|
||||||
|
echo "VIRTUAL_ENV=$GITHUB_WORKSPACE/.venv" >> $GITHUB_ENV
|
||||||
|
# yamllint enable rule:line-length
|
||||||
|
|
||||||
|
# Use per check platformio cache because checks use different parts
|
||||||
|
- name: Cache platformio
|
||||||
|
uses: actions/cache@v3
|
||||||
|
with:
|
||||||
|
path: ~/.platformio
|
||||||
|
# yamllint disable-line rule:line-length
|
||||||
|
key: platformio-${{ matrix.pio_cache_key }}-${{ hashFiles('platformio.ini') }}
|
||||||
|
if: matrix.id == 'test' || matrix.id == 'clang-tidy'
|
||||||
|
|
||||||
|
- run: esphome compile ${{ matrix.file }}
|
||||||
|
if: matrix.id == 'test'
|
||||||
|
env:
|
||||||
|
# Also cache libdeps, store them in a ~/.platformio subfolder
|
||||||
|
PLATFORMIO_LIBDEPS_DIR: ~/.platformio/libdeps
|
||||||
|
|
||||||
|
ci-status:
|
||||||
|
name: CI Status
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: [ci]
|
||||||
|
if: always()
|
||||||
|
steps:
|
||||||
|
- name: Successful deploy
|
||||||
|
if: ${{ !(contains(needs.*.result, 'failure')) }}
|
||||||
|
run: exit 0
|
||||||
|
- name: Failing deploy
|
||||||
|
if: ${{ contains(needs.*.result, 'failure') }}
|
||||||
|
run: exit 1
|
||||||
242
test/test1.yaml
Normal file
242
test/test1.yaml
Normal file
@ -0,0 +1,242 @@
|
|||||||
|
esphome:
|
||||||
|
name: "truma_esp32_ard"
|
||||||
|
|
||||||
|
on_boot:
|
||||||
|
then:
|
||||||
|
# read time from external source (connected via I2C)
|
||||||
|
- ds1307.read_time
|
||||||
|
|
||||||
|
external_components:
|
||||||
|
- source:
|
||||||
|
type: local
|
||||||
|
path: ./components
|
||||||
|
components: ["truma_inetbox", "uart"]
|
||||||
|
|
||||||
|
esp32:
|
||||||
|
board: mhetesp32devkit
|
||||||
|
framework:
|
||||||
|
type: arduino
|
||||||
|
|
||||||
|
i2c:
|
||||||
|
sda: 14
|
||||||
|
scl: 27
|
||||||
|
scan: false
|
||||||
|
id: i2c_bus_a
|
||||||
|
|
||||||
|
time:
|
||||||
|
- platform: ds1307
|
||||||
|
update_interval: never
|
||||||
|
id: esptime
|
||||||
|
|
||||||
|
uart:
|
||||||
|
- id: lin_uart_bus
|
||||||
|
tx_pin: 17
|
||||||
|
rx_pin: 16
|
||||||
|
baud_rate: 9600
|
||||||
|
data_bits: 8
|
||||||
|
parity: NONE
|
||||||
|
stop_bits: 2
|
||||||
|
|
||||||
|
truma_inetbox:
|
||||||
|
uart_id: lin_uart_bus
|
||||||
|
time_id: esptime
|
||||||
|
cs_pin: 5
|
||||||
|
fault_pin: 18
|
||||||
|
# Advanced users can use `on_heater_message` action. The heater data is in the `message` variable.
|
||||||
|
on_heater_message:
|
||||||
|
then:
|
||||||
|
- logger.log: "Message from CP Plus."
|
||||||
|
- if:
|
||||||
|
condition:
|
||||||
|
lambda: return message->operating_status == truma_inetbox::OperatingStatus::OPERATING_STATUS_OFF;
|
||||||
|
then:
|
||||||
|
- logger.log: "Heater is off."
|
||||||
|
|
||||||
|
binary_sensor:
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "CP Plus alive"
|
||||||
|
type: CP_PLUS_CONNECTED
|
||||||
|
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Room Heater active"
|
||||||
|
type: HEATER_ROOM
|
||||||
|
id: HEATER_ROOM
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Water Heater active"
|
||||||
|
type: HEATER_WATER
|
||||||
|
id: HEATER_WATER
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Heater mode Gas"
|
||||||
|
type: HEATER_GAS
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Heater mode Mix 1"
|
||||||
|
type: HEATER_MIX_1
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Heater mode Mix 2"
|
||||||
|
type: HEATER_MIX_2
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Heater mode Elec"
|
||||||
|
type: HEATER_ELECTRICITY
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Heater has error"
|
||||||
|
type: HEATER_HAS_ERROR
|
||||||
|
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Timer active"
|
||||||
|
type: TIMER_ACTIVE
|
||||||
|
id: TIMER_ACTIVE
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Timer Room Heater active"
|
||||||
|
type: TIMER_ROOM
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Timer Water Heater active"
|
||||||
|
type: TIMER_WATER
|
||||||
|
|
||||||
|
climate:
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Truma Room"
|
||||||
|
type: ROOM
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Truma Water"
|
||||||
|
type: WATER
|
||||||
|
|
||||||
|
number:
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Target Room Temperature"
|
||||||
|
type: TARGET_ROOM_TEMPERATURE
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Target Water Temperature"
|
||||||
|
type: TARGET_WATER_TEMPERATURE
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "electric power level"
|
||||||
|
type: ELECTRIC_POWER_LEVEL
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Current Room Temperature"
|
||||||
|
type: CURRENT_ROOM_TEMPERATURE
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Current Water Temperature"
|
||||||
|
type: CURRENT_WATER_TEMPERATURE
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Target Room Temperature"
|
||||||
|
type: TARGET_ROOM_TEMPERATURE
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Target Water Temperature"
|
||||||
|
type: TARGET_WATER_TEMPERATURE
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Heating mode"
|
||||||
|
type: HEATING_MODE
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "electric power level"
|
||||||
|
type: ELECTRIC_POWER_LEVEL
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Energy mix"
|
||||||
|
type: ENERGY_MIX
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Operating status"
|
||||||
|
type: OPERATING_STATUS
|
||||||
|
- platform: truma_inetbox
|
||||||
|
name: "Heater error code"
|
||||||
|
type: HEATER_ERROR_CODE
|
||||||
|
|
||||||
|
switch:
|
||||||
|
- platform: template
|
||||||
|
name: "Activate Room Heater"
|
||||||
|
lambda: |-
|
||||||
|
return id(HEATER_ROOM).state;
|
||||||
|
turn_on_action:
|
||||||
|
- truma_inetbox.heater.set_target_room_temperature:
|
||||||
|
# You can use lambda functions
|
||||||
|
temperature: !lambda |-
|
||||||
|
return 16;
|
||||||
|
# Optional set heating mode: `"OFF"`, `ECO`, `HIGH`, `BOOST`
|
||||||
|
heating_mode: ECO
|
||||||
|
turn_off_action:
|
||||||
|
- truma_inetbox.heater.set_target_room_temperature:
|
||||||
|
# Disable heater by setting temperature to `0`.
|
||||||
|
temperature: 0
|
||||||
|
- platform: template
|
||||||
|
name: "Activate Water Heater"
|
||||||
|
lambda: |-
|
||||||
|
return id(HEATER_WATER).state;
|
||||||
|
turn_on_action:
|
||||||
|
- truma_inetbox.heater.set_target_water_temperature:
|
||||||
|
# Set water temp as number: `0`, `40`, `60`, `80`
|
||||||
|
temperature: 40
|
||||||
|
turn_off_action:
|
||||||
|
- truma_inetbox.heater.set_target_water_temperature:
|
||||||
|
# Disable heater by setting temperature to `0`.
|
||||||
|
temperature: 0
|
||||||
|
- platform: template
|
||||||
|
name: "Activate Water Heater (enum)"
|
||||||
|
lambda: |-
|
||||||
|
return id(HEATER_WATER).state;
|
||||||
|
turn_on_action:
|
||||||
|
- truma_inetbox.heater.set_target_water_temperature_enum:
|
||||||
|
# Set water temp as text: `"OFF"`, `ECO`, `HIGH`, `BOOST`
|
||||||
|
temperature: ECO
|
||||||
|
turn_off_action:
|
||||||
|
# You can also use the simplified syntax.
|
||||||
|
- truma_inetbox.heater.set_target_water_temperature_enum: "OFF"
|
||||||
|
- platform: template
|
||||||
|
name: "Active Timer"
|
||||||
|
lambda: |-
|
||||||
|
return id(TIMER_ACTIVE).state;
|
||||||
|
turn_on_action:
|
||||||
|
- truma_inetbox.timer.activate:
|
||||||
|
start: 7:00
|
||||||
|
stop: 9:30
|
||||||
|
# Required: Set room temp to a number between 5 and 30
|
||||||
|
room_temperature: 13
|
||||||
|
# Optional: Set heating mode: `"OFF"`, `ECO`, `HIGH`, `BOOST`
|
||||||
|
heating_mode: ECO
|
||||||
|
# Optional: Set water temp as number: `0`, `40`, `60`, `80`
|
||||||
|
water_temperature: 0
|
||||||
|
# Optional: Set energy mix to: `GAS`, `MIX`, `ELECTRICITY`
|
||||||
|
energy_mix: GAS
|
||||||
|
# Optional: Set electricity level to `0`, `900`, `1800`
|
||||||
|
watt: 0
|
||||||
|
|
||||||
|
turn_off_action:
|
||||||
|
# You can also use the simplified syntax.
|
||||||
|
- truma_inetbox.timer.disable
|
||||||
|
|
||||||
|
button:
|
||||||
|
- platform: template
|
||||||
|
name: "Energy mix GAS only"
|
||||||
|
on_press:
|
||||||
|
- truma_inetbox.heater.set_energy_mix:
|
||||||
|
# Set energy mix to: `GAS`, `MIX`, `ELECTRICITY`
|
||||||
|
energy_mix: GAS
|
||||||
|
- platform: template
|
||||||
|
name: "Energy mix MIX 1"
|
||||||
|
on_press:
|
||||||
|
- truma_inetbox.heater.set_energy_mix:
|
||||||
|
energy_mix: MIX
|
||||||
|
# Set electricity level to `0`, `900`, `1800`
|
||||||
|
watt: 900W
|
||||||
|
- platform: template
|
||||||
|
name: "Energy mix MIX 2"
|
||||||
|
on_press:
|
||||||
|
- truma_inetbox.heater.set_energy_mix:
|
||||||
|
energy_mix: MIX
|
||||||
|
watt: 1800
|
||||||
|
- platform: template
|
||||||
|
name: "Energy mix ELECTRICITY only"
|
||||||
|
on_press:
|
||||||
|
- truma_inetbox.heater.set_energy_mix:
|
||||||
|
energy_mix: ELECTRICITY
|
||||||
|
watt: 1800W
|
||||||
|
- platform: template
|
||||||
|
name: "Set electric power level to 0 Watt"
|
||||||
|
on_press:
|
||||||
|
- truma_inetbox.heater.set_electric_power_level: 0
|
||||||
|
- platform: template
|
||||||
|
name: "Set electric power level to 900 Watt"
|
||||||
|
on_press:
|
||||||
|
- truma_inetbox.heater.set_electric_power_level: 900
|
||||||
|
- platform: template
|
||||||
|
name: "Set electric power level to 1800 Watt"
|
||||||
|
on_press:
|
||||||
|
- truma_inetbox.heater.set_electric_power_level: 1800
|
||||||
Loading…
x
Reference in New Issue
Block a user