|
| 1 | +import pytest |
| 2 | +from control import data |
| 3 | +from control.algorithm.algorithm import Algorithm |
| 4 | +from control.chargemode import Chargemode |
| 5 | + |
| 6 | + |
| 7 | +@pytest.fixture() |
| 8 | +def bidi_cps(): |
| 9 | + def _setup(*cps): |
| 10 | + for cp in cps: |
| 11 | + data.data.cp_data[cp].data.get.max_discharge_power = -11000 |
| 12 | + data.data.cp_data[cp].data.get.max_charge_power = 11000 |
| 13 | + data.data.cp_data[cp].data.get.phases_in_use = 3 |
| 14 | + control_parameter = data.data.cp_data[cp].data.control_parameter |
| 15 | + control_parameter.min_current = data.data.cp_data[cp].data.set.charging_ev_data.ev_template.data.min_current |
| 16 | + control_parameter.phases = 3 |
| 17 | + control_parameter.required_currents = [16]*3 |
| 18 | + control_parameter.required_current = 16 |
| 19 | + control_parameter.chargemode = Chargemode.BIDI_CHARGING |
| 20 | + control_parameter.submode = Chargemode.BIDI_CHARGING |
| 21 | + return _setup |
| 22 | + |
| 23 | + |
| 24 | +@pytest.mark.parametrize("grid_power, expected_current", |
| 25 | + [pytest.param(-2000, 2.898550724637681, id="bidi charge"), |
| 26 | + pytest.param(2000, -2.898550724637681, id="bidi discharge")]) |
| 27 | +def test_cp3_bidi(grid_power: float, expected_current: float, bidi_cps, all_cp_not_charging, monkeypatch): |
| 28 | + # setup |
| 29 | + bidi_cps("cp3") |
| 30 | + data.data.counter_data["counter0"].data.get.power = grid_power |
| 31 | + |
| 32 | + # execution |
| 33 | + Algorithm().calc_current() |
| 34 | + |
| 35 | + # evaluation |
| 36 | + assert data.data.cp_data["cp3"].data.set.current == expected_current |
| 37 | + assert data.data.cp_data["cp4"].data.set.current == 0 |
| 38 | + assert data.data.cp_data["cp5"].data.set.current == 0 |
| 39 | + assert data.data.counter_data["counter0"].data.set.surplus_power_left == 0 |
| 40 | + |
| 41 | + |
| 42 | +def test_cp3_cp4_bidi_discharge(bidi_cps, all_cp_not_charging, monkeypatch): |
| 43 | + # setup |
| 44 | + bidi_cps("cp3", "cp4") |
| 45 | + data.data.counter_data["counter0"].data.get.power = 4000 |
| 46 | + |
| 47 | + # execution |
| 48 | + Algorithm().calc_current() |
| 49 | + |
| 50 | + # evaluation |
| 51 | + assert data.data.cp_data["cp3"].data.set.current == -2.898550724637681 |
| 52 | + assert data.data.cp_data["cp4"].data.set.current == -2.898550724637681 |
| 53 | + assert data.data.cp_data["cp5"].data.set.current == 0 |
| 54 | + assert data.data.counter_data["counter0"].data.set.surplus_power_left == 0 |
0 commit comments