aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-server-common
diff options
context:
space:
mode:
Diffstat (limited to 'server/sonar-server-common')
-rw-r--r--server/sonar-server-common/src/test/java/org/sonar/server/notification/NotificationServiceTest.java220
1 files changed, 92 insertions, 128 deletions
diff --git a/server/sonar-server-common/src/test/java/org/sonar/server/notification/NotificationServiceTest.java b/server/sonar-server-common/src/test/java/org/sonar/server/notification/NotificationServiceTest.java
index d843696b383..17bdbeeda24 100644
--- a/server/sonar-server-common/src/test/java/org/sonar/server/notification/NotificationServiceTest.java
+++ b/server/sonar-server-common/src/test/java/org/sonar/server/notification/NotificationServiceTest.java
@@ -23,7 +23,6 @@ import com.google.common.collect.ImmutableSet;
import java.util.Collections;
import java.util.List;
import java.util.Optional;
-import java.util.Random;
import java.util.stream.Collectors;
import java.util.stream.IntStream;
import org.junit.Before;
@@ -37,7 +36,6 @@ import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
import static org.mockito.ArgumentMatchers.anyCollection;
import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.reset;
import static org.mockito.Mockito.times;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.verifyNoInteractions;
@@ -56,11 +54,11 @@ public class NotificationServiceTest {
@Test
public void deliverEmails_fails_with_IAE_if_type_of_collection_is_Notification() {
- NotificationHandler handler = mock(NotificationHandler1.class);
- List<Notification> notifications = IntStream.range(0, 1 + new Random().nextInt(20))
+ NotificationHandler handler = getMockOfNotificationHandlerForType(Notification1.class);
+ List<Notification> notifications = IntStream.range(0, 10)
.mapToObj(i -> new Notification("i"))
.collect(Collectors.toList());
- NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[] {handler});
+ NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[]{handler});
assertThatThrownBy(() -> underTest.deliverEmails(notifications))
.isInstanceOf(IllegalArgumentException.class)
@@ -69,7 +67,7 @@ public class NotificationServiceTest {
@Test
public void deliverEmails_collection_has_no_effect_if_no_handler_nor_dispatcher() {
- List<Notification> notifications = IntStream.range(0, 1 + new Random().nextInt(20))
+ List<Notification> notifications = IntStream.range(0, 10)
.mapToObj(i -> mock(Notification.class))
.collect(Collectors.toList());
NotificationService underTest = new NotificationService(dbClient);
@@ -81,10 +79,10 @@ public class NotificationServiceTest {
@Test
public void deliverEmails_collection_has_no_effect_if_no_handler() {
NotificationDispatcher dispatcher = mock(NotificationDispatcher.class);
- List<Notification> notifications = IntStream.range(0, new Random().nextInt(20))
+ List<Notification> notifications = IntStream.range(0, 10)
.mapToObj(i -> mock(Notification.class))
.collect(Collectors.toList());
- NotificationService underTest = new NotificationService(dbClient, new NotificationDispatcher[] {dispatcher});
+ NotificationService underTest = new NotificationService(dbClient, new NotificationDispatcher[]{dispatcher});
assertThat(underTest.deliverEmails(notifications)).isZero();
verifyNoInteractions(dispatcher);
@@ -93,10 +91,10 @@ public class NotificationServiceTest {
@Test
public void deliverEmails_collection_returns_0_if_collection_is_empty() {
- NotificationHandler1 handler1 = mock(NotificationHandler1.class);
- NotificationHandler2 handler2 = mock(NotificationHandler2.class);
+ NotificationHandler<Notification1> handler1 = getMockOfNotificationHandlerForType(Notification1.class);
+ NotificationHandler<Notification2> handler2 = getMockOfNotificationHandlerForType(Notification2.class);
NotificationService underTest = new NotificationService(dbClient,
- new NotificationHandler[] {handler1, handler2});
+ new NotificationHandler[]{handler1, handler2});
assertThat(underTest.deliverEmails(Collections.emptyList())).isZero();
verifyNoInteractions(handler1, handler2);
@@ -104,17 +102,17 @@ public class NotificationServiceTest {
@Test
public void deliverEmails_collection_returns_0_if_no_handler_for_the_notification_class() {
- NotificationHandler1 handler1 = mock(NotificationHandler1.class);
- NotificationHandler2 handler2 = mock(NotificationHandler2.class);
- List<Notification1> notification1s = IntStream.range(0, 1 + new Random().nextInt(20))
+ NotificationHandler<Notification1> handler1 = getMockOfNotificationHandlerForType(Notification1.class);
+ NotificationHandler<Notification2> handler2 = getMockOfNotificationHandlerForType(Notification2.class);
+ List<Notification1> notification1s = IntStream.range(0, 10)
.mapToObj(i -> new Notification1())
.collect(Collectors.toList());
- List<Notification2> notification2s = IntStream.range(0, 1 + new Random().nextInt(20))
+ List<Notification2> notification2s = IntStream.range(0, 10)
.mapToObj(i -> new Notification2())
.collect(Collectors.toList());
NotificationService noHandler = new NotificationService(dbClient);
- NotificationService onlyHandler1 = new NotificationService(dbClient, new NotificationHandler[] {handler1});
- NotificationService onlyHandler2 = new NotificationService(dbClient, new NotificationHandler[] {handler2});
+ NotificationService onlyHandler1 = new NotificationService(dbClient, new NotificationHandler[]{handler1});
+ NotificationService onlyHandler2 = new NotificationService(dbClient, new NotificationHandler[]{handler2});
assertThat(noHandler.deliverEmails(notification1s)).isZero();
assertThat(noHandler.deliverEmails(notification2s)).isZero();
@@ -126,96 +124,89 @@ public class NotificationServiceTest {
@Test
public void deliverEmails_collection_calls_deliver_method_of_handler_for_notification_class_and_returns_its_output() {
- Random random = new Random();
- NotificationHandler1 handler1 = mock(NotificationHandler1.class);
- NotificationHandler2 handler2 = mock(NotificationHandler2.class);
- List<Notification1> notification1s = IntStream.range(0, 1 + random.nextInt(20))
+ NotificationHandler<Notification1> handler1 = getMockOfNotificationHandlerForType(Notification1.class);
+ NotificationHandler<Notification2> handler2 = getMockOfNotificationHandlerForType(Notification2.class);
+ List<Notification1> notification1s = IntStream.range(0, 10)
.mapToObj(i -> new Notification1())
.collect(Collectors.toList());
- List<Notification2> notification2s = IntStream.range(0, 1 + random.nextInt(20))
+ List<Notification2> notification2s = IntStream.range(0, 10)
.mapToObj(i -> new Notification2())
.collect(Collectors.toList());
- NotificationService onlyHandler1 = new NotificationService(dbClient, new NotificationHandler[] {handler1});
- NotificationService onlyHandler2 = new NotificationService(dbClient, new NotificationHandler[] {handler2});
- NotificationService bothHandlers = new NotificationService(dbClient, new NotificationHandler[] {handler1, handler2});
+ NotificationService onlyHandler1 = new NotificationService(dbClient, new NotificationHandler[]{handler1});
+ NotificationService onlyHandler2 = new NotificationService(dbClient, new NotificationHandler[]{handler2});
+ NotificationService bothHandlers = new NotificationService(dbClient, new NotificationHandler[]{handler1, handler2});
- int expected = randomDeliveredCount(notification1s);
+ int expected = notification1s.size() - 1;
when(handler1.deliver(notification1s)).thenReturn(expected);
assertThat(onlyHandler1.deliverEmails(notification1s)).isEqualTo(expected);
- verify(handler1).deliver(notification1s);
+ verify(handler1, times(1)).deliver(notification1s);
verify(handler2, times(0)).deliver(anyCollection());
- reset(handler1, handler2);
- expected = randomDeliveredCount(notification2s);
+ expected = notification2s.size() - 2;
when(handler2.deliver(notification2s)).thenReturn(expected);
assertThat(onlyHandler2.deliverEmails(notification2s)).isEqualTo(expected);
- verify(handler2).deliver(notification2s);
- verify(handler1, times(0)).deliver(anyCollection());
+ verify(handler2, times(1)).deliver(notification2s);
+ verify(handler1, times(1)).deliver(anyCollection());
- reset(handler1, handler2);
- expected = randomDeliveredCount(notification1s);
+ expected = notification1s.size() - 1;
when(handler1.deliver(notification1s)).thenReturn(expected);
assertThat(bothHandlers.deliverEmails(notification1s)).isEqualTo(expected);
- verify(handler1).deliver(notification1s);
- verify(handler2, times(0)).deliver(anyCollection());
+ verify(handler1, times(2)).deliver(notification1s);
+ verify(handler2, times(1)).deliver(anyCollection());
- reset(handler1, handler2);
- expected = randomDeliveredCount(notification2s);
+ expected = notification2s.size() - 2;
when(handler2.deliver(notification2s)).thenReturn(expected);
assertThat(bothHandlers.deliverEmails(notification2s)).isEqualTo(expected);
- verify(handler2).deliver(notification2s);
- verify(handler1, times(0)).deliver(anyCollection());
+ verify(handler2, times(2)).deliver(notification2s);
+ verify(handler1, times(2)).deliver(anyCollection());
}
@Test
public void deliver_calls_deliver_method_on_each_handler_for_notification_class_and_returns_sum_of_their_outputs() {
- Random random = new Random();
- NotificationHandler1A handler1A = mock(NotificationHandler1A.class);
- NotificationHandler1B handler1B = mock(NotificationHandler1B.class);
- NotificationHandler2 handler2 = mock(NotificationHandler2.class);
- List<Notification1> notification1s = IntStream.range(0, 1 + random.nextInt(20))
+ NotificationHandler<Notification1> handler1A = getMockOfNotificationHandlerForType(Notification1.class);
+ NotificationHandler<Notification1> handler1B = getMockOfNotificationHandlerForType(Notification1.class);
+ NotificationHandler<Notification2> handler2 = getMockOfNotificationHandlerForType(Notification2.class);
+
+ List<Notification1> notification1s = IntStream.range(0, 10)
.mapToObj(i -> new Notification1())
.collect(Collectors.toList());
- List<Notification2> notification2s = IntStream.range(0, 1 + random.nextInt(20))
+ List<Notification2> notification2s = IntStream.range(0, 10)
.mapToObj(i -> new Notification2())
.collect(Collectors.toList());
- NotificationService onlyHandler1A = new NotificationService(dbClient, new NotificationHandler[] {handler1A});
- NotificationService onlyHandler1B = new NotificationService(dbClient, new NotificationHandler[] {handler1B});
- NotificationService bothHandlers = new NotificationService(dbClient, new NotificationHandler[] {handler1A, handler1B});
- NotificationService allHandlers = new NotificationService(dbClient, new NotificationHandler[] {handler1A, handler1B, handler2});
+ NotificationService onlyHandler1A = new NotificationService(dbClient, new NotificationHandler[]{handler1A});
+ NotificationService onlyHandler1B = new NotificationService(dbClient, new NotificationHandler[]{handler1B});
+ NotificationService bothHandlers = new NotificationService(dbClient, new NotificationHandler[]{handler1A, handler1B});
+ NotificationService allHandlers = new NotificationService(dbClient, new NotificationHandler[]{handler1A, handler1B, handler2});
- int expected = randomDeliveredCount(notification1s);
+ int expected = notification1s.size() - 1;
when(onlyHandler1A.deliverEmails(notification1s)).thenReturn(expected);
assertThat(onlyHandler1A.deliverEmails(notification1s)).isEqualTo(expected);
- verify(handler1A).deliver(notification1s);
+ verify(handler1A, times(1)).deliver(notification1s);
verify(handler1B, times(0)).deliver(anyCollection());
verify(handler2, times(0)).deliver(anyCollection());
- reset(handler1A, handler1B, handler2);
- expected = randomDeliveredCount(notification1s);
+ expected = notification1s.size() - 1;
when(handler1B.deliver(notification1s)).thenReturn(expected);
assertThat(onlyHandler1B.deliverEmails(notification1s)).isEqualTo(expected);
- verify(handler1B).deliver(notification1s);
- verify(handler1A, times(0)).deliver(anyCollection());
+ verify(handler1B, times(1)).deliver(notification1s);
+ verify(handler1A, times(1)).deliver(anyCollection());
verify(handler2, times(0)).deliver(anyCollection());
- reset(handler1A, handler1B, handler2);
- expected = randomDeliveredCount(notification1s);
- int expected2 = randomDeliveredCount(notification1s);
+ expected = notification1s.size() - 1;
+ int expected2 = notification1s.size() - 2;
when(handler1A.deliver(notification1s)).thenReturn(expected);
when(handler1B.deliver(notification1s)).thenReturn(expected2);
assertThat(bothHandlers.deliverEmails(notification1s)).isEqualTo(expected + expected2);
- verify(handler1A).deliver(notification1s);
- verify(handler1B).deliver(notification1s);
+ verify(handler1A, times(2)).deliver(notification1s);
+ verify(handler1B, times(2)).deliver(notification1s);
verify(handler2, times(0)).deliver(anyCollection());
- reset(handler1A, handler1B, handler2);
- expected = randomDeliveredCount(notification2s);
+ expected = notification2s.size() - 2;
when(handler2.deliver(notification2s)).thenReturn(expected);
assertThat(allHandlers.deliverEmails(notification2s)).isEqualTo(expected);
- verify(handler2).deliver(notification2s);
- verify(handler1A, times(0)).deliver(anyCollection());
- verify(handler1B, times(0)).deliver(anyCollection());
+ verify(handler2, times(1)).deliver(notification2s);
+ verify(handler1A, times(2)).deliver(anyCollection());
+ verify(handler1B, times(2)).deliver(anyCollection());
}
@Test
@@ -232,16 +223,20 @@ public class NotificationServiceTest {
String dispatcherKey1A = randomAlphabetic(5);
String dispatcherKey1B = randomAlphabetic(6);
String projectUuid = randomAlphabetic(7);
- NotificationHandler1A handler1A = mock(NotificationHandler1A.class);
+
+ NotificationHandler<Notification1> handler1A = getMockOfNotificationHandlerForType(Notification1.class);
when(handler1A.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey1A)));
- NotificationHandler1B handler1B = mock(NotificationHandler1B.class);
+
+ NotificationHandler<Notification1> handler1B = getMockOfNotificationHandlerForType(Notification1.class);
when(handler1B.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey1B)));
- NotificationHandler2 handler2 = mock(NotificationHandler2.class);
+
+ NotificationHandler<Notification2> handler2 = getMockOfNotificationHandlerForType(Notification2.class);
when(handler2.getMetadata()).thenReturn(Optional.empty());
- boolean expected = new Random().nextBoolean();
+
+ boolean expected = true;
when(propertiesDao.hasProjectNotificationSubscribersForDispatchers(projectUuid, ImmutableSet.of(dispatcherKey1A, dispatcherKey1B)))
.thenReturn(expected);
- NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[] {handler1A, handler1B, handler2});
+ NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[]{handler1A, handler1B, handler2});
boolean flag = underTest.hasProjectSubscribersForTypes(projectUuid, ImmutableSet.of(Notification1.class));
@@ -262,19 +257,22 @@ public class NotificationServiceTest {
String dispatcherKey1B = randomAlphabetic(6);
String dispatcherKey2 = randomAlphabetic(7);
String projectUuid = randomAlphabetic(8);
- NotificationHandler1A handler1A = mock(NotificationHandler1A.class);
+ NotificationHandler<Notification1> handler1A = getMockOfNotificationHandlerForType(Notification1.class);
when(handler1A.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey1A)));
- NotificationHandler1B handler1B = mock(NotificationHandler1B.class);
+
+ NotificationHandler<Notification1> handler1B = getMockOfNotificationHandlerForType(Notification1.class);
when(handler1B.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey1B)));
- NotificationHandler2 handler2 = mock(NotificationHandler2.class);
+
+ NotificationHandler<Notification2> handler2 = getMockOfNotificationHandlerForType(Notification2.class);
when(handler2.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey2)));
- boolean expected1 = new Random().nextBoolean();
+
+ boolean expected1 = false;
when(propertiesDao.hasProjectNotificationSubscribersForDispatchers(projectUuid, ImmutableSet.of(dispatcherKey1A, dispatcherKey1B, dispatcherKey2)))
.thenReturn(expected1);
- boolean expected2 = new Random().nextBoolean();
+ boolean expected2 = true;
when(propertiesDao.hasProjectNotificationSubscribersForDispatchers(projectUuid, ImmutableSet.of(dispatcherKey2)))
.thenReturn(expected2);
- NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[] {handler1A, handler1B, handler2});
+ NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[]{handler1A, handler1B, handler2});
boolean flag = underTest.hasProjectSubscribersForTypes(projectUuid, ImmutableSet.of(Notification1.class, Notification2.class));
@@ -295,13 +293,17 @@ public class NotificationServiceTest {
String dispatcherKey1A = randomAlphabetic(5);
String dispatcherKey1B = randomAlphabetic(6);
String projectUuid = randomAlphabetic(7);
- NotificationHandler1A handler1A = mock(NotificationHandler1A.class);
+
+ NotificationHandler<Notification1> handler1A = getMockOfNotificationHandlerForType(Notification1.class);
when(handler1A.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey1A)));
- NotificationHandler1B handler1B = mock(NotificationHandler1B.class);
+
+ NotificationHandler<Notification1> handler1B = getMockOfNotificationHandlerForType(Notification1.class);
when(handler1B.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey1B)));
- NotificationHandler2 handler2 = mock(NotificationHandler2.class);
+
+ NotificationHandler<Notification2> handler2 = getMockOfNotificationHandlerForType(Notification2.class);
when(handler2.getMetadata()).thenReturn(Optional.empty());
- NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[] {handler1A, handler1B, handler2});
+
+ NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[]{handler1A, handler1B, handler2});
boolean flag = underTest.hasProjectSubscribersForTypes(projectUuid, ImmutableSet.of());
@@ -315,11 +317,14 @@ public class NotificationServiceTest {
String dispatcherKey1A = randomAlphabetic(5);
String dispatcherKey1B = randomAlphabetic(6);
String projectUuid = randomAlphabetic(7);
- NotificationHandler1A handler1A = mock(NotificationHandler1A.class);
+
+ NotificationHandler<Notification1> handler1A = getMockOfNotificationHandlerForType(Notification1.class);
when(handler1A.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey1A)));
- NotificationHandler1B handler1B = mock(NotificationHandler1B.class);
+
+ NotificationHandler<Notification1> handler1B = getMockOfNotificationHandlerForType(Notification1.class);
when(handler1B.getMetadata()).thenReturn(Optional.of(NotificationDispatcherMetadata.create(dispatcherKey1B)));
- NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[] {handler1A, handler1B});
+
+ NotificationService underTest = new NotificationService(dbClient, new NotificationHandler[]{handler1A, handler1B});
boolean flag = underTest.hasProjectSubscribersForTypes(projectUuid, ImmutableSet.of(Notification2.class));
@@ -335,34 +340,10 @@ public class NotificationServiceTest {
}
}
- private static abstract class NotificationHandler1 implements NotificationHandler<Notification1> {
-
- // final to prevent mock to override implementation
- @Override
- public final Class<Notification1> getNotificationClass() {
- return Notification1.class;
- }
-
- }
-
- private static abstract class NotificationHandler1A implements NotificationHandler<Notification1> {
-
- // final to prevent mock to override implementation
- @Override
- public final Class<Notification1> getNotificationClass() {
- return Notification1.class;
- }
-
- }
-
- private static abstract class NotificationHandler1B implements NotificationHandler<Notification1> {
-
- // final to prevent mock to override implementation
- @Override
- public final Class<Notification1> getNotificationClass() {
- return Notification1.class;
- }
-
+ private <T extends Notification> NotificationHandler<T> getMockOfNotificationHandlerForType(Class<T> notificationClass) {
+ NotificationHandler mock = mock(NotificationHandler.class);
+ when(mock.getNotificationClass()).thenReturn(notificationClass);
+ return mock;
}
private static final class Notification2 extends Notification {
@@ -371,21 +352,4 @@ public class NotificationServiceTest {
super("2");
}
}
-
- private static abstract class NotificationHandler2 implements NotificationHandler<Notification2> {
-
- // final to prevent mock to override implementation
- @Override
- public final Class<Notification2> getNotificationClass() {
- return Notification2.class;
- }
- }
-
- private static <T extends Notification> int randomDeliveredCount(List<T> notifications) {
- int size = notifications.size();
- if (size == 1) {
- return size;
- }
- return 1 + new Random().nextInt(size - 1);
- }
}