|
| 1 | +import pickle |
| 2 | +import sys |
| 3 | + |
| 4 | +import pytest |
| 5 | + |
| 6 | +from influxdb_client import InfluxDBClient, WriteOptions |
| 7 | +from influxdb_client.client.write_api import WriteType |
| 8 | +from tests.base_test import current_milli_time, BaseTest |
| 9 | + |
| 10 | + |
| 11 | +class InfluxDBWriterToPickle: |
| 12 | + |
| 13 | + def __init__(self): |
| 14 | + self.client = InfluxDBClient(url="http://localhost:9999", token="my-token", org="my-org", debug=False) |
| 15 | + self.write_api = self.client.write_api( |
| 16 | + write_options=WriteOptions(write_type=WriteType.batching, batch_size=50_000, flush_interval=10_000)) |
| 17 | + |
| 18 | + def write(self, record): |
| 19 | + self.write_api.write(bucket="my-bucket", record=record) |
| 20 | + |
| 21 | + def terminate(self) -> None: |
| 22 | + self.write_api.__del__() |
| 23 | + self.client.__del__() |
| 24 | + |
| 25 | + |
| 26 | +class WriteApiPickle(BaseTest): |
| 27 | + |
| 28 | + def setUp(self) -> None: |
| 29 | + super().setUp() |
| 30 | + |
| 31 | + def tearDown(self) -> None: |
| 32 | + super().tearDown() |
| 33 | + |
| 34 | + @pytest.mark.skipif(sys.version_info < (3, 7), reason="requires python3.7 or higher") |
| 35 | + def test_write_line_protocol(self): |
| 36 | + writer = InfluxDBWriterToPickle() |
| 37 | + |
| 38 | + pickle_out = open("writer.pickle", "wb") |
| 39 | + pickle.dump(writer, pickle_out) |
| 40 | + pickle_out.close() |
| 41 | + |
| 42 | + writer = pickle.load(open("writer.pickle", "rb")) |
| 43 | + |
| 44 | + measurement = "h2o_feet_" + str(current_milli_time()) |
| 45 | + writer.write(record=f"{measurement},location=coyote_creek water_level=1.0") |
| 46 | + writer.terminate() |
| 47 | + |
| 48 | + tables = self.query_api.query( |
| 49 | + f'from(bucket: "my-bucket") |> range(start: 0) |> filter(fn: (r) => r._measurement == "{measurement}")') |
| 50 | + |
| 51 | + self.assertEqual(len(tables), 1) |
| 52 | + self.assertEqual(len(tables[0].records), 1) |
| 53 | + self.assertEqual(tables[0].records[0].get_measurement(), measurement) |
| 54 | + self.assertEqual(tables[0].records[0].get_value(), 1.0) |
| 55 | + self.assertEqual(tables[0].records[0].get_field(), "water_level") |
0 commit comments