|
4 | 4 | """Tests for the logical meter.""" |
5 | 5 |
|
6 | 6 |
|
7 | | -import asyncio |
8 | | -from datetime import datetime, timezone |
9 | | - |
10 | 7 | from pytest_mock import MockerFixture |
11 | 8 |
|
12 | 9 | from frequenz.sdk import microgrid |
13 | | -from frequenz.sdk.timeseries._quantities import Frequency, Power |
14 | | -from tests.utils import component_data_wrapper |
| 10 | +from frequenz.sdk.timeseries._quantities import Power |
15 | 11 |
|
16 | | -from ._formula_engine.utils import equal_float_lists |
17 | 12 | from .mock_microgrid import MockMicrogrid |
18 | 13 |
|
19 | 14 | # pylint: disable=too-many-locals |
|
23 | 18 | class TestLogicalMeter: # pylint: disable=too-many-public-methods |
24 | 19 | """Tests for the logical meter.""" |
25 | 20 |
|
26 | | - async def test_grid_frequency_1(self, mocker: MockerFixture) -> None: |
27 | | - """Test the grid frequency formula.""" |
28 | | - mockgrid = MockMicrogrid(grid_meter=True) |
29 | | - mockgrid.add_batteries(2) |
30 | | - mockgrid.add_solar_inverters(1) |
31 | | - await mockgrid.start(mocker) |
32 | | - |
33 | | - grid_freq = microgrid.frequency() |
34 | | - grid_freq_recv = grid_freq.new_receiver() |
35 | | - |
36 | | - assert grid_freq._task is not None |
37 | | - # We have to wait for the metric request to be sent |
38 | | - await grid_freq._task |
39 | | - # And consumed |
40 | | - await asyncio.sleep(0) |
41 | | - |
42 | | - results = [] |
43 | | - grid_meter_data = [] |
44 | | - for count in range(10): |
45 | | - freq = float(50.0 + (1 if count % 2 == 0 else -1) * 0.01) |
46 | | - await mockgrid.mock_client.send( |
47 | | - component_data_wrapper.MeterDataWrapper( |
48 | | - mockgrid.meter_ids[0], datetime.now(tz=timezone.utc), frequency=freq |
49 | | - ) |
50 | | - ) |
51 | | - |
52 | | - grid_meter_data.append(Frequency.from_hertz(freq)) |
53 | | - val = await grid_freq_recv.receive() |
54 | | - assert val is not None and val.value is not None |
55 | | - results.append(val.value) |
56 | | - await mockgrid.cleanup() |
57 | | - assert equal_float_lists(results, grid_meter_data) |
58 | | - |
59 | | - async def test_grid_frequency_no_grid_meter_no_consumer_meter( |
60 | | - self, |
61 | | - mocker: MockerFixture, |
62 | | - ) -> None: |
63 | | - """Test the grid frequency formula without a grid side meter.""" |
64 | | - mockgrid = MockMicrogrid(grid_meter=False) |
65 | | - mockgrid.add_consumer_meters() |
66 | | - mockgrid.add_batteries(1, no_meter=False) |
67 | | - mockgrid.add_batteries(1, no_meter=False) |
68 | | - await mockgrid.start(mocker) |
69 | | - grid_freq = microgrid.frequency() |
70 | | - |
71 | | - grid_freq_recv = grid_freq.new_receiver() |
72 | | - # We have to wait for the metric request to be sent |
73 | | - assert grid_freq._task is not None |
74 | | - await grid_freq._task |
75 | | - # And consumed |
76 | | - await asyncio.sleep(0) |
77 | | - |
78 | | - results = [] |
79 | | - meter_data = [] |
80 | | - for count in range(10): |
81 | | - freq = float(50.0 + (1 if count % 2 == 0 else -1) * 0.01) |
82 | | - await mockgrid.mock_client.send( |
83 | | - component_data_wrapper.MeterDataWrapper( |
84 | | - mockgrid.meter_ids[0], datetime.now(tz=timezone.utc), frequency=freq |
85 | | - ) |
86 | | - ) |
87 | | - meter_data.append(Frequency.from_hertz(freq)) |
88 | | - |
89 | | - val = await grid_freq_recv.receive() |
90 | | - assert val is not None and val.value is not None |
91 | | - results.append(val.value) |
92 | | - await mockgrid.cleanup() |
93 | | - assert equal_float_lists(results, meter_data) |
94 | | - |
95 | | - async def test_grid_frequency_no_grid_meter( |
96 | | - self, |
97 | | - mocker: MockerFixture, |
98 | | - ) -> None: |
99 | | - """Test the grid frequency formula without a grid side meter.""" |
100 | | - mockgrid = MockMicrogrid(grid_meter=False) |
101 | | - mockgrid.add_batteries(1, no_meter=False) |
102 | | - mockgrid.add_batteries(1, no_meter=True) |
103 | | - await mockgrid.start(mocker) |
104 | | - grid_freq = microgrid.frequency() |
105 | | - |
106 | | - grid_freq_recv = grid_freq.new_receiver() |
107 | | - # We have to wait for the metric request to be sent |
108 | | - assert grid_freq._task is not None |
109 | | - await grid_freq._task |
110 | | - # And consumed |
111 | | - await asyncio.sleep(0) |
112 | | - |
113 | | - results = [] |
114 | | - meter_data = [] |
115 | | - for count in range(10): |
116 | | - freq = float(50.0 + (1 if count % 2 == 0 else -1) * 0.01) |
117 | | - await mockgrid.mock_client.send( |
118 | | - component_data_wrapper.MeterDataWrapper( |
119 | | - mockgrid.meter_ids[0], datetime.now(tz=timezone.utc), frequency=freq |
120 | | - ) |
121 | | - ) |
122 | | - meter_data.append(Frequency.from_hertz(freq)) |
123 | | - |
124 | | - val = await grid_freq_recv.receive() |
125 | | - assert val is not None and val.value is not None |
126 | | - results.append(val.value) |
127 | | - await mockgrid.cleanup() |
128 | | - assert equal_float_lists(results, meter_data) |
129 | | - |
130 | | - async def test_grid_frequency_only_inverter( |
131 | | - self, |
132 | | - mocker: MockerFixture, |
133 | | - ) -> None: |
134 | | - """Test the grid frequency formula without any meter but only inverters.""" |
135 | | - mockgrid = MockMicrogrid(grid_meter=False) |
136 | | - mockgrid.add_batteries(2, no_meter=True) |
137 | | - await mockgrid.start(mocker) |
138 | | - |
139 | | - grid_freq = microgrid.frequency() |
140 | | - grid_freq_recv = grid_freq.new_receiver() |
141 | | - # We have to wait for the metric request to be sent |
142 | | - assert grid_freq._task is not None |
143 | | - await grid_freq._task |
144 | | - # And consumed |
145 | | - await asyncio.sleep(0) |
146 | | - |
147 | | - results = [] |
148 | | - meter_data = [] |
149 | | - for count in range(10): |
150 | | - freq = float(50.0 + (1 if count % 2 == 0 else -1) * 0.01) |
151 | | - |
152 | | - await mockgrid.mock_client.send( |
153 | | - component_data_wrapper.InverterDataWrapper( |
154 | | - mockgrid.battery_inverter_ids[0], |
155 | | - datetime.now(tz=timezone.utc), |
156 | | - frequency=freq, |
157 | | - ) |
158 | | - ) |
159 | | - |
160 | | - meter_data.append(Frequency.from_hertz(freq)) |
161 | | - val = await grid_freq_recv.receive() |
162 | | - assert val is not None and val.value is not None |
163 | | - results.append(val.value) |
164 | | - await mockgrid.cleanup() |
165 | | - assert equal_float_lists(results, meter_data) |
166 | | - |
167 | 21 | async def test_chp_power(self, mocker: MockerFixture) -> None: |
168 | 22 | """Test the chp power formula.""" |
169 | 23 | mockgrid = MockMicrogrid(grid_meter=False) |
|
0 commit comments