-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathdestination_integration_test.go
72 lines (58 loc) · 2.04 KB
/
destination_integration_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
// Copyright © 2022 Meroxa, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package kafka
import (
"context"
"testing"
"github.com/conduitio/conduit-connector-kafka/destination"
"github.com/conduitio/conduit-connector-kafka/source"
"github.com/conduitio/conduit-connector-kafka/test"
"github.com/matryer/is"
)
func TestDestination_Integration_WriteExistingTopic(t *testing.T) {
cfgMap := test.DestinationConfigMap(t)
cfg := test.ParseConfigMap[destination.Config](t, cfgMap)
test.CreateTopics(t, cfg.Servers, []string{cfg.Topic})
testDestinationIntegrationWrite(t, cfgMap)
}
func TestDestination_Integration_WriteCreateTopic(t *testing.T) {
cfgMap := test.DestinationConfigMap(t)
testDestinationIntegrationWrite(t, cfgMap)
}
func testDestinationIntegrationWrite(t *testing.T, cfg map[string]string) {
is := is.New(t)
ctx := context.Background()
wantRecords := test.GenerateSDKRecords(1, 6)
underTest := NewDestination()
defer func() {
err := underTest.Teardown(ctx)
is.NoErr(err)
}()
err := underTest.Configure(ctx, cfg)
is.NoErr(err)
err = underTest.Open(ctx)
is.NoErr(err)
count, err := underTest.Write(ctx, wantRecords)
is.NoErr(err)
is.Equal(count, len(wantRecords))
// source config needs "topics" param
cfg["topics"] = cfg["topic"]
cfg["topic"] = ""
srcCfg := test.ParseConfigMap[source.Config](t, cfg)
gotRecords := test.Consume(t, srcCfg.Servers, srcCfg.Topics[0], len(wantRecords))
is.Equal(len(wantRecords), len(gotRecords))
for i, got := range gotRecords {
is.Equal(got.Value, wantRecords[i].Bytes())
}
}