You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@kafka.apache.org by mi...@apache.org on 2022/07/25 17:47:25 UTC
[kafka] branch trunk updated: KAFKA-13158: Migrate ConnectClusterStateImpl to Mockito (#12423)
This is an automated email from the ASF dual-hosted git repository.
mimaison pushed a commit to branch trunk
in repository https://gitbox.apache.org/repos/asf/kafka.git
The following commit(s) were added to refs/heads/trunk by this push:
new 6b76c01cf8 KAFKA-13158: Migrate ConnectClusterStateImpl to Mockito (#12423)
6b76c01cf8 is described below
commit 6b76c01cf895db0651e2cdcc07c2c392f00a8ceb
Author: Christo Lolov <lo...@amazon.com>
AuthorDate: Mon Jul 25 18:47:08 2022 +0100
KAFKA-13158: Migrate ConnectClusterStateImpl to Mockito (#12423)
Reviewers: Mickael Maison <mi...@gmail.com>, Chris Egerton <fe...@gmail.com>
---
build.gradle | 2 +-
.../health/ConnectClusterStateImplTest.java | 43 ++++++++++++----------
2 files changed, 24 insertions(+), 21 deletions(-)
diff --git a/build.gradle b/build.gradle
index 73c36c3117..a85d429a04 100644
--- a/build.gradle
+++ b/build.gradle
@@ -402,7 +402,7 @@ subprojects {
if (JavaVersion.current().isCompatibleWith(JavaVersion.VERSION_16)) {
testsToExclude.addAll([
// connect tests
- "**/AbstractHerderTest.*", "**/ConnectClusterStateImplTest.*", "**/ConnectorPluginsResourceTest.*",
+ "**/AbstractHerderTest.*", "**/ConnectorPluginsResourceTest.*",
"**/ConnectorsResourceTest.*", "**/DistributedHerderTest.*", "**/FileOffsetBakingStoreTest.*",
"**/ErrorHandlingTaskTest.*", "**/KafkaConfigBackingStoreTest.*", "**/KafkaOffsetBackingStoreTest.*",
"**/KafkaBasedLogTest.*", "**/OffsetStorageWriterTest.*", "**/StandaloneHerderTest.*",
diff --git a/connect/runtime/src/test/java/org/apache/kafka/connect/runtime/health/ConnectClusterStateImplTest.java b/connect/runtime/src/test/java/org/apache/kafka/connect/runtime/health/ConnectClusterStateImplTest.java
index 58eb5a9e97..33af4ad3d2 100644
--- a/connect/runtime/src/test/java/org/apache/kafka/connect/runtime/health/ConnectClusterStateImplTest.java
+++ b/connect/runtime/src/test/java/org/apache/kafka/connect/runtime/health/ConnectClusterStateImplTest.java
@@ -19,13 +19,12 @@ package org.apache.kafka.connect.runtime.health;
import org.apache.kafka.connect.errors.ConnectException;
import org.apache.kafka.connect.runtime.Herder;
import org.apache.kafka.connect.util.Callback;
-import org.easymock.Capture;
-import org.easymock.EasyMock;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
-import org.powermock.api.easymock.annotation.Mock;
-import org.powermock.modules.junit4.PowerMockRunner;
+import org.mockito.ArgumentCaptor;
+import org.mockito.Mock;
+import org.mockito.junit.MockitoJUnitRunner;
import java.util.Arrays;
import java.util.Collection;
@@ -37,8 +36,10 @@ import java.util.concurrent.TimeoutException;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotSame;
import static org.junit.Assert.assertThrows;
+import static org.mockito.ArgumentMatchers.eq;
+import static org.mockito.Mockito.doAnswer;
-@RunWith(PowerMockRunner.class)
+@RunWith(MockitoJUnitRunner.class)
public class ConnectClusterStateImplTest {
protected static final String KAFKA_CLUSTER_ID = "franzwashere";
@@ -60,13 +61,13 @@ public class ConnectClusterStateImplTest {
@Test
public void connectors() {
- Capture<Callback<Collection<String>>> callback = EasyMock.newCapture();
- herder.connectors(EasyMock.capture(callback));
- EasyMock.expectLastCall().andAnswer(() -> {
+ @SuppressWarnings("unchecked")
+ ArgumentCaptor<Callback<Collection<String>>> callback = ArgumentCaptor.forClass(Callback.class);
+ doAnswer(invocation -> {
callback.getValue().onCompletion(null, expectedConnectors);
return null;
- });
- EasyMock.replay(herder);
+ }).when(herder).connectors(callback.capture());
+
assertEquals(expectedConnectors, connectClusterState.connectors());
}
@@ -74,14 +75,16 @@ public class ConnectClusterStateImplTest {
public void connectorConfig() {
final String connName = "sink6";
final Map<String, String> expectedConfig = Collections.singletonMap("key", "value");
- Capture<Callback<Map<String, String>>> callback = EasyMock.newCapture();
- herder.connectorConfig(EasyMock.eq(connName), EasyMock.capture(callback));
- EasyMock.expectLastCall().andAnswer(() -> {
+
+ @SuppressWarnings("unchecked")
+ ArgumentCaptor<Callback<Map<String, String>>> callback = ArgumentCaptor.forClass(Callback.class);
+ doAnswer(invocation -> {
callback.getValue().onCompletion(null, expectedConfig);
return null;
- });
- EasyMock.replay(herder);
+ }).when(herder).connectorConfig(eq(connName), callback.capture());
+
Map<String, String> actualConfig = connectClusterState.connectorConfig(connName);
+
assertEquals(expectedConfig, actualConfig);
assertNotSame(
"Config should be copied in order to avoid mutation by REST extensions",
@@ -97,14 +100,14 @@ public class ConnectClusterStateImplTest {
@Test
public void connectorsFailure() {
- Capture<Callback<Collection<String>>> callback = EasyMock.newCapture();
- herder.connectors(EasyMock.capture(callback));
- EasyMock.expectLastCall().andAnswer(() -> {
+ @SuppressWarnings("unchecked")
+ ArgumentCaptor<Callback<Collection<String>>> callback = ArgumentCaptor.forClass(Callback.class);
+ doAnswer(invocation -> {
Throwable timeout = new TimeoutException();
callback.getValue().onCompletion(timeout, null);
return null;
- });
- EasyMock.replay(herder);
+ }).when(herder).connectors(callback.capture());
+
assertThrows(ConnectException.class, connectClusterState::connectors);
}
}