forked from confluentinc/confluent-kafka-dotnet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAdminClient_NullReferenceChecks.cs
144 lines (132 loc) · 6.24 KB
/
AdminClient_NullReferenceChecks.cs
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
// Copyright 2016-2019 Confluent 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.
//
// Refer to LICENSE for more information.
#pragma warning disable xUnit1026
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using Confluent.Kafka.Admin;
using Xunit;
using Confluent.Kafka.TestsCommon;
namespace Confluent.Kafka.IntegrationTests
{
public partial class Tests
{
/// <summary>
/// Tests the validation of input parameter to guard against uncaught segfaults.
/// </summary>
[Theory, MemberData(nameof(KafkaParameters))]
public void AdminClient_NullReferenceChecks(string bootstrapServers)
{
LogToFile("start AdminClient_NullReferenceChecks");
var topicName1 = Guid.NewGuid().ToString();
string nullTopic = null;
Exception createTopicsException = null;
Exception createPartitionsException = null;
// test creating a null topic throws a related exception
using (var producer = new TestProducerBuilder<Null, Null>(new ProducerConfig { BootstrapServers = bootstrapServers }).Build())
using (var adminClient = new DependentAdminClientBuilder(producer.Handle).Build())
{
try
{
adminClient.CreateTopicsAsync(new TopicSpecification[] { new TopicSpecification { Name = nullTopic, NumPartitions = 1, ReplicationFactor = 1 } }).Wait();
Assert.True(false, "Expected exception.");
}
catch (ArgumentException ex)
{
Assert.Contains("topic", ex.Message.ToLower());
createTopicsException = ex;
}
}
// test creating a partition with null topic throws exception
using (var producer = new TestProducerBuilder<Null, Null>(new ProducerConfig { BootstrapServers = bootstrapServers }).Build())
using (var adminClient = new DependentAdminClientBuilder(producer.Handle).Build())
{
try
{
adminClient.CreateTopicsAsync(new TopicSpecification[] { new TopicSpecification { Name = topicName1, NumPartitions = 1, ReplicationFactor = 1 } }).Wait();
adminClient.CreatePartitionsAsync(new List<PartitionsSpecification> { new PartitionsSpecification { Topic = nullTopic, IncreaseTo = 2 } }).Wait();
Assert.True(false, "Expected exception.");
}
catch (ArgumentException ex)
{
Assert.Contains("topic", ex.Message.ToLower());
createPartitionsException = ex;
}
}
Assert.True(createTopicsException != null && createPartitionsException != null);
Assert.True(createTopicsException.GetType() == createPartitionsException.GetType(), ".CreateTopic and .CreatePartition should have consistent interface for null-related exceptions.");
// test adding a null list of brokers throws null reference exception.
using (var producer = new TestProducerBuilder<Null, Null>(new ProducerConfig { BootstrapServers = bootstrapServers }).Build())
using (var adminClient = new DependentAdminClientBuilder(producer.Handle).Build())
{
try
{
adminClient.AddBrokers(null);
Assert.True(false, "Expected exception.");
}
catch (ArgumentNullException ex)
{
Assert.Contains("broker", ex.Message.ToLower());
}
}
// test retrieving metadata for a null topic
using (var producer = new TestProducerBuilder<Null, Null>(new ProducerConfig { BootstrapServers = bootstrapServers }).Build())
using (var adminClient = new DependentAdminClientBuilder(producer.Handle).Build())
{
try
{
adminClient.GetMetadata(null, TimeSpan.FromSeconds(10));
Assert.True(false, "Expected exception.");
}
catch (ArgumentNullException ex)
{
Assert.Contains("value cannot be null", ex.Message.ToLower());
}
}
// Deleting null topic throws exception
using (var producer = new TestProducerBuilder<Null, Null>(new ProducerConfig { BootstrapServers = bootstrapServers }).Build())
using (var adminClient = new DependentAdminClientBuilder(producer.Handle).Build())
{
try
{
adminClient.DeleteTopicsAsync(new List<string> { topicName1, nullTopic });
Assert.True(false, "Expected exception.");
}
catch(ArgumentException ex)
{
Assert.Contains("topic", ex.Message);
}
}
// ListGroup throws exception if group is null
using (var producer = new TestProducerBuilder<Null, Null>(new ProducerConfig { BootstrapServers = bootstrapServers }).Build())
using (var adminClient = new DependentAdminClientBuilder(producer.Handle).Build())
{
try
{
adminClient.ListGroup(null, TimeSpan.FromSeconds(10));
Assert.True(false, "Expected exception.");
}
catch (ArgumentNullException ex)
{
Assert.Contains("group", ex.Message);
}
}
Assert.Equal(0, Library.HandleCount);
LogToFile("end AdminClient_NullReferenceChecks");
}
}
}