blob: abec85fa593b8b6b0894e318e547e6f3e2ebd71a [file] [log] [blame]
Scott Baker2c1c4822019-10-16 11:02:41 -07001/*
2 * Copyright 2018-present Open Networking Foundation
3
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7
8 * http://www.apache.org/licenses/LICENSE-2.0
9
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16package kafka
17
18import (
19 "github.com/stretchr/testify/assert"
20 "testing"
21)
22
23func TestDefaultKafkaProxy(t *testing.T) {
Matteo Scandolo2ba00d32020-01-16 17:33:03 -080024 actualResult, error := newInterContainerProxy()
Scott Baker2c1c4822019-10-16 11:02:41 -070025 assert.Equal(t, error, nil)
26 assert.Equal(t, actualResult.kafkaHost, DefaultKafkaHost)
27 assert.Equal(t, actualResult.kafkaPort, DefaultKafkaPort)
28 assert.Equal(t, actualResult.defaultRequestHandlerInterface, interface{}(nil))
29}
30
31func TestKafkaProxyOptionHost(t *testing.T) {
Matteo Scandolo2ba00d32020-01-16 17:33:03 -080032 actualResult, error := newInterContainerProxy(InterContainerHost("10.20.30.40"))
Scott Baker2c1c4822019-10-16 11:02:41 -070033 assert.Equal(t, error, nil)
34 assert.Equal(t, actualResult.kafkaHost, "10.20.30.40")
35 assert.Equal(t, actualResult.kafkaPort, DefaultKafkaPort)
36 assert.Equal(t, actualResult.defaultRequestHandlerInterface, interface{}(nil))
37}
38
39func TestKafkaProxyOptionPort(t *testing.T) {
Matteo Scandolo2ba00d32020-01-16 17:33:03 -080040 actualResult, error := newInterContainerProxy(InterContainerPort(1020))
Scott Baker2c1c4822019-10-16 11:02:41 -070041 assert.Equal(t, error, nil)
42 assert.Equal(t, actualResult.kafkaHost, DefaultKafkaHost)
43 assert.Equal(t, actualResult.kafkaPort, 1020)
44 assert.Equal(t, actualResult.defaultRequestHandlerInterface, interface{}(nil))
45}
46
47func TestKafkaProxyOptionTopic(t *testing.T) {
Matteo Scandolo2ba00d32020-01-16 17:33:03 -080048 actualResult, error := newInterContainerProxy(DefaultTopic(&Topic{Name: "Adapter"}))
Scott Baker2c1c4822019-10-16 11:02:41 -070049 assert.Equal(t, error, nil)
50 assert.Equal(t, actualResult.kafkaHost, DefaultKafkaHost)
51 assert.Equal(t, actualResult.kafkaPort, DefaultKafkaPort)
52 assert.Equal(t, actualResult.defaultRequestHandlerInterface, interface{}(nil))
Matteo Scandolof346a2d2020-01-24 13:14:54 -080053 assert.Equal(t, actualResult.defaultTopic.Name, "Adapter")
Scott Baker2c1c4822019-10-16 11:02:41 -070054}
55
56type myInterface struct {
57}
58
59func (m *myInterface) doSomething() {
60}
61
62func TestKafkaProxyOptionTargetInterface(t *testing.T) {
63 var m *myInterface
Matteo Scandolo2ba00d32020-01-16 17:33:03 -080064 actualResult, error := newInterContainerProxy(RequestHandlerInterface(m))
Scott Baker2c1c4822019-10-16 11:02:41 -070065 assert.Equal(t, error, nil)
66 assert.Equal(t, actualResult.kafkaHost, DefaultKafkaHost)
67 assert.Equal(t, actualResult.kafkaPort, DefaultKafkaPort)
68 assert.Equal(t, actualResult.defaultRequestHandlerInterface, m)
69}
70
71func TestKafkaProxyChangeAllOptions(t *testing.T) {
72 var m *myInterface
Matteo Scandolo2ba00d32020-01-16 17:33:03 -080073 actualResult, error := newInterContainerProxy(
Scott Baker2c1c4822019-10-16 11:02:41 -070074 InterContainerHost("10.20.30.40"),
75 InterContainerPort(1020),
76 DefaultTopic(&Topic{Name: "Adapter"}),
77 RequestHandlerInterface(m))
78 assert.Equal(t, error, nil)
79 assert.Equal(t, actualResult.kafkaHost, "10.20.30.40")
80 assert.Equal(t, actualResult.kafkaPort, 1020)
81 assert.Equal(t, actualResult.defaultRequestHandlerInterface, m)
Matteo Scandolof346a2d2020-01-24 13:14:54 -080082 assert.Equal(t, actualResult.defaultTopic.Name, "Adapter")
Scott Baker2c1c4822019-10-16 11:02:41 -070083}
Scott Baker104b67d2019-10-29 15:56:27 -070084
85func TestKafkaProxyEnableLivenessChannel(t *testing.T) {
86 var m *myInterface
87
88 // Note: This doesn't actually start the client
89 client := NewSaramaClient()
90
Matteo Scandolo2ba00d32020-01-16 17:33:03 -080091 probe, err := newInterContainerProxy(
Scott Baker104b67d2019-10-29 15:56:27 -070092 InterContainerHost("10.20.30.40"),
93 InterContainerPort(1020),
94 DefaultTopic(&Topic{Name: "Adapter"}),
95 RequestHandlerInterface(m),
96 MsgClient(client),
97 )
98
99 assert.Nil(t, err)
100
101 ch := probe.EnableLivenessChannel(true)
102
103 // The channel should have one "true" message on it
104 assert.NotEmpty(t, ch)
105
106 select {
107 case stuff := <-ch:
108 assert.True(t, stuff)
109 default:
110 t.Error("Failed to read from the channel")
111 }
112}