Skip to content

Commit

Permalink
add test with throwing listeners
Browse files Browse the repository at this point in the history
  • Loading branch information
tepi committed Dec 5, 2024
1 parent 5da146f commit fd17bc7
Showing 1 changed file with 72 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicReference;
import java.util.stream.Collectors;

Expand Down Expand Up @@ -63,6 +64,7 @@

import static org.hamcrest.CoreMatchers.containsString;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.junit.Assert.assertThrows;

/**
*
Expand Down Expand Up @@ -99,6 +101,34 @@ public void sessionDestroy(SessionDestroyEvent event) {
}
}

private class ThrowingSessionDestroyListener
implements SessionDestroyListener {

@Override
public void sessionDestroy(SessionDestroyEvent event) {
throw new RuntimeException();
}
}

private class TestServiceDestroyListener implements ServiceDestroyListener {

int callCount = 0;

@Override
public void serviceDestroy(ServiceDestroyEvent event) {
callCount++;
}
}

private class ThrowingServiceDestroyListener
implements ServiceDestroyListener {

@Override
public void serviceDestroy(ServiceDestroyEvent event) {
throw new RuntimeException();
}
}

private String createCriticalNotification(String caption, String message,
String details, String url) {
return VaadinService.createCriticalNotificationJSON(caption, message,
Expand Down Expand Up @@ -298,6 +328,48 @@ public void testFireSessionDestroy()
1, listener.callCount);
}

@Test
public void testSessionDestroyListenerCalled_whenAnotherListenerThrows()
throws ServiceException {
VaadinService service = createService();

ThrowingSessionDestroyListener throwingListener = new ThrowingSessionDestroyListener();
TestSessionDestroyListener listener = new TestSessionDestroyListener();

service.addSessionDestroyListener(throwingListener);
service.addSessionDestroyListener(listener);

final AtomicInteger errorCount = new AtomicInteger();
MockVaadinSession vaadinSession = new MockVaadinSession(service);
vaadinSession.lock();
vaadinSession.setErrorHandler(e -> errorCount.getAndIncrement());
vaadinSession.unlock();
service.fireSessionDestroy(vaadinSession);

Assert.assertEquals("ErrorHandler not called exactly once", 1,
errorCount.get());

Assert.assertEquals("SessionDestroyListener not called exactly once", 1,
listener.callCount);
}

@Test
public void testServiceDestroyListenerCalled_whenAnotherListenerThrows()
throws ServletException, ServiceException {
VaadinService service = createService();

ThrowingServiceDestroyListener throwingListener = new ThrowingServiceDestroyListener();
TestServiceDestroyListener listener = new TestServiceDestroyListener();

service.addServiceDestroyListener(throwingListener);
service.addServiceDestroyListener(listener);

assertThrows(RuntimeException.class, () -> service.destroy());

Assert.assertEquals("ServiceDestroyListener not called exactly once", 1,
listener.callCount);
}

@Test
public void captionIsSetToACriticalNotification() {
String notification = createCriticalNotification("foobar", "message",
Expand Down

0 comments on commit fd17bc7

Please # to comment.