|
1
|
|
|
import unittest |
|
2
|
|
|
import mock |
|
3
|
|
|
import pytest |
|
4
|
|
|
|
|
5
|
|
|
confluent = pytest.importorskip('kafka_influxdb.reader.confluent') |
|
6
|
|
|
|
|
7
|
|
|
|
|
8
|
|
|
class KafkaError(object): |
|
9
|
|
|
def __init__(self): |
|
10
|
|
|
""" |
|
11
|
|
|
Error types raised by confluent kafka |
|
12
|
|
|
""" |
|
13
|
|
|
self._PARTITION_EOF = 1 |
|
14
|
|
|
|
|
15
|
|
|
|
|
16
|
|
|
class TestConfluentKafka(unittest.TestCase): |
|
17
|
|
|
def setUp(self): |
|
18
|
|
|
self.host = "myhost" |
|
19
|
|
|
self.port = 1234 |
|
20
|
|
|
self.group = "mygroup" |
|
21
|
|
|
self.topic = "mytopic" |
|
22
|
|
|
self.reconnect_wait_time = 0.01 |
|
23
|
|
|
self.reader = self.create_reader() |
|
24
|
|
|
|
|
25
|
|
|
def create_reader(self): |
|
26
|
|
|
reader = confluent.Reader(self.host, |
|
27
|
|
|
self.port, |
|
28
|
|
|
self.group, |
|
29
|
|
|
self.topic) |
|
30
|
|
|
reader.consumer = mock.MagicMock() |
|
31
|
|
|
return reader |
|
32
|
|
|
|
|
33
|
|
|
@staticmethod |
|
34
|
|
|
def create_kafka_message(key, value, kafka_error_type=None): |
|
35
|
|
|
message = mock.MagicMock() |
|
36
|
|
|
message.return_value = True |
|
37
|
|
|
message.key.return_value = key |
|
38
|
|
|
message.value.return_value = value |
|
39
|
|
|
if kafka_error_type: |
|
40
|
|
|
message.error.return_value = True |
|
41
|
|
|
message.error.code.return_value = kafka_error_type |
|
42
|
|
|
else: |
|
43
|
|
|
message.error.return_value = False |
|
44
|
|
|
return message |
|
45
|
|
|
|
|
46
|
|
|
def sample_messages(self, payload, count): |
|
47
|
|
|
message = self.create_kafka_message(None, payload) |
|
48
|
|
|
return count * [message], count * [payload] |
|
49
|
|
|
|
|
50
|
|
|
def test_handle_read(self): |
|
51
|
|
|
sample_messages, extracted_messages = self.sample_messages("hello", 3) |
|
52
|
|
|
self.reader.consumer.poll.side_effect = sample_messages |
|
53
|
|
|
self.reader._connect = mock.MagicMock() |
|
54
|
|
|
received_messages = list(self.reader._handle_read()) |
|
55
|
|
|
self.assertEqual(received_messages, extracted_messages) |
|
56
|
|
|
|
|
57
|
|
|
def receive_messages(self): |
|
58
|
|
|
for message in self.reader.read(): |
|
59
|
|
|
yield message |
|
60
|
|
|
|