|
19 | 19 |
|
20 | 20 | # pytype: skip-file
|
21 | 21 |
|
| 22 | +import logging |
22 | 23 | import inspect
|
| 24 | +import random |
23 | 25 | import time
|
24 | 26 | import unittest
|
25 | 27 |
|
| 28 | +from parameterized import parameterized |
| 29 | + |
26 | 30 | import apache_beam as beam
|
27 | 31 | from apache_beam.io.restriction_trackers import OffsetRange
|
28 | 32 | from apache_beam.testing.test_pipeline import TestPipeline
|
@@ -157,6 +161,53 @@ def test_processing_time(self):
|
157 | 161 | expected = [0, 2, 4]
|
158 | 162 | assert_that(ret, equal_to(expected, lambda x, y: abs(x - y) < threshold))
|
159 | 163 |
|
| 164 | + @parameterized.expand([0.5, 1, 2, 10]) |
| 165 | + def test_stop_over_by_epsilon(self, interval): |
| 166 | + with TestPipeline() as p: |
| 167 | + ret = ( |
| 168 | + p | PeriodicImpulse( |
| 169 | + start_timestamp=Timestamp(seconds=1), |
| 170 | + stop_timestamp=Timestamp(seconds=1, micros=1), |
| 171 | + data=[1, 2], |
| 172 | + fire_interval=interval) |
| 173 | + | beam.WindowInto(FixedWindows(interval)) |
| 174 | + | beam.WithKeys(0) |
| 175 | + | beam.GroupByKey()) |
| 176 | + expected = [ |
| 177 | + (0, [1]), |
| 178 | + ] |
| 179 | + assert_that(ret, equal_to(expected)) |
| 180 | + |
| 181 | + @parameterized.expand([1, 2]) |
| 182 | + def test_stop_over_by_interval(self, interval): |
| 183 | + with TestPipeline() as p: |
| 184 | + ret = ( |
| 185 | + p | PeriodicImpulse( |
| 186 | + start_timestamp=Timestamp(seconds=1), |
| 187 | + stop_timestamp=Timestamp(seconds=1 + interval), |
| 188 | + data=[1, 2], |
| 189 | + fire_interval=interval) |
| 190 | + | beam.WindowInto(FixedWindows(interval)) |
| 191 | + | beam.WithKeys(0) |
| 192 | + | beam.GroupByKey()) |
| 193 | + expected = [(0, [1])] |
| 194 | + assert_that(ret, equal_to(expected)) |
| 195 | + |
| 196 | + @parameterized.expand([1, 2]) |
| 197 | + def test_stop_over_by_interval_and_epsilon(self, interval): |
| 198 | + with TestPipeline() as p: |
| 199 | + ret = ( |
| 200 | + p | PeriodicImpulse( |
| 201 | + start_timestamp=Timestamp(seconds=1), |
| 202 | + stop_timestamp=Timestamp(seconds=1 + interval, micros=1), |
| 203 | + data=[1, 2], |
| 204 | + fire_interval=interval) |
| 205 | + | beam.WindowInto(FixedWindows(interval)) |
| 206 | + | beam.WithKeys(0) |
| 207 | + | beam.GroupByKey()) |
| 208 | + expected = [(0, [1]), (0, [2])] |
| 209 | + assert_that(ret, equal_to(expected)) |
| 210 | + |
160 | 211 | def test_interval(self):
|
161 | 212 | with TestPipeline() as p:
|
162 | 213 | ret = (
|
@@ -208,15 +259,22 @@ def test_not_enough_timestamped_value(self):
|
208 | 259 | data=data,
|
209 | 260 | fire_interval=0.5))
|
210 | 261 |
|
211 |
| - def test_small_interval(self): |
212 |
| - data = [(Timestamp(1), 1), (Timestamp(2), 2), (Timestamp(3), 3), |
213 |
| - (Timestamp(6), 6), (Timestamp(4), 4), (Timestamp(5), 5), |
214 |
| - (Timestamp(7), 7), (Timestamp(8), 8), (Timestamp(9), 9), |
215 |
| - (Timestamp(10), 10)] |
216 |
| - expected = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] |
217 |
| - with TestPipeline() as p: |
218 |
| - ret = (p | PeriodicImpulse(data=data, fire_interval=0.0001)) |
219 |
| - assert_that(ret, equal_to(expected)) |
| 262 | + def test_fuzzy_interval(self): |
| 263 | + seed = int(time.time() * 1000) |
| 264 | + times = 30 |
| 265 | + logging.warning("random seed=%d", seed) |
| 266 | + random.seed(seed) |
| 267 | + for _ in range(times): |
| 268 | + n = int(random.randint(1, 100)) |
| 269 | + data = list(range(n)) |
| 270 | + m = random.randint(1, 1000) |
| 271 | + interval = m / 1e6 |
| 272 | + now = Timestamp.now() |
| 273 | + with TestPipeline() as p: |
| 274 | + ret = ( |
| 275 | + p | PeriodicImpulse( |
| 276 | + start_timestamp=now, data=data, fire_interval=interval)) |
| 277 | + assert_that(ret, equal_to(data)) |
220 | 278 |
|
221 | 279 |
|
222 | 280 | if __name__ == '__main__':
|
|
0 commit comments