forked from box/mojito
-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
25a7396
commit b3fdfde
Showing
1 changed file
with
220 additions
and
0 deletions.
There are no files selected for viewing
220 changes: 220 additions & 0 deletions
220
webapp/src/test/java/com/box/l10n/mojito/pagerduty/PagerDutyClientTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,220 @@ | ||
package com.box.l10n.mojito.pagerduty; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertEquals; | ||
import static org.junit.jupiter.api.Assertions.fail; | ||
import static org.mockito.Mockito.mock; | ||
import static org.mockito.Mockito.never; | ||
import static org.mockito.Mockito.times; | ||
import static org.mockito.Mockito.verify; | ||
import static org.mockito.Mockito.when; | ||
|
||
import java.io.IOException; | ||
import java.net.http.HttpClient; | ||
import java.net.http.HttpRequest; | ||
import java.net.http.HttpResponse; | ||
import java.text.MessageFormat; | ||
import java.util.HashMap; | ||
import java.util.Map; | ||
import java.util.concurrent.atomic.AtomicInteger; | ||
import org.junit.jupiter.api.BeforeEach; | ||
import org.junit.jupiter.api.Test; | ||
import org.mockito.Mockito; | ||
import org.mockito.stubbing.Answer; | ||
|
||
public class PagerDutyClientTest { | ||
private PagerDutyClient pagerDutyClient; | ||
private HttpClient httpClient; | ||
|
||
@SuppressWarnings("rawtypes") | ||
private HttpResponse httpResponse; | ||
|
||
private PagerDutyPayload samplePayload; | ||
|
||
@BeforeEach | ||
public void setup() { | ||
// Setup Slack clients | ||
httpClient = mock(HttpClient.class); | ||
httpResponse = mock(HttpResponse.class); | ||
|
||
pagerDutyClient = new PagerDutyClient("xxxyyyzzz", httpClient); | ||
|
||
Map<String, String> customDetails = new HashMap<>(); | ||
customDetails.put("Example Custom Details", "Example Value"); | ||
samplePayload = | ||
new PagerDutyPayload( | ||
"Job Failed.", "Mojito", PagerDutyPayload.Severity.ERROR, customDetails); | ||
} | ||
|
||
@Test | ||
public void testNormalTriggerResolve() throws IOException, InterruptedException { | ||
when(httpResponse.statusCode()).thenReturn(202); | ||
when(httpClient.send( | ||
Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class))) | ||
.thenReturn(httpResponse); | ||
|
||
try { | ||
pagerDutyClient.triggerIncident("dedpuKey", samplePayload); | ||
pagerDutyClient.resolveIncident("dedupKey"); | ||
} catch (PagerDutyException e) { | ||
fail("PagerDutyClient should not throw exception when the response code is 202."); | ||
} | ||
|
||
verify(httpClient, times(2)) | ||
.send(Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class)); | ||
} | ||
|
||
@Test | ||
public void testFailsWithMaxRetries() throws IOException, InterruptedException { | ||
int statusCode = 500; | ||
String responseBody = "{ Some type of Response Body }"; | ||
|
||
when(httpResponse.statusCode()).thenReturn(statusCode); | ||
when(httpResponse.body()).thenReturn(responseBody); | ||
when(httpClient.send( | ||
Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class))) | ||
.thenReturn(httpResponse); | ||
|
||
try { | ||
pagerDutyClient.triggerIncident("dedpuKey", samplePayload); | ||
fail("PagerDutyClient should have thrown an error from 500 internal server error."); | ||
} catch (PagerDutyException e) { | ||
assertEquals( | ||
e.getMessage(), | ||
MessageFormat.format(PagerDutyClient.exceptionTemplate, statusCode, responseBody)); | ||
} | ||
|
||
verify(httpClient, times(PagerDutyClient.MAX_RETRIES)) | ||
.send(Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class)); | ||
} | ||
|
||
@Test | ||
public void testRecoversFromFailedAttemptsEarly() throws IOException, InterruptedException { | ||
when(httpResponse.statusCode()).thenReturn(500, 202); | ||
when(httpClient.send( | ||
Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class))) | ||
.thenReturn(httpResponse); | ||
|
||
try { | ||
pagerDutyClient.triggerIncident("dedpuKey", samplePayload); | ||
verify(httpClient, times(2)) | ||
.send(Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class)); | ||
} catch (PagerDutyException e) { | ||
fail("PagerDutyClient should have recovered from failing attempts."); | ||
} | ||
} | ||
|
||
@Test | ||
public void testRecoversFromFailedAttemptsMaxRetries() throws IOException, InterruptedException { | ||
AtomicInteger callCount = new AtomicInteger(0); | ||
when(httpResponse.statusCode()) | ||
.thenAnswer( | ||
(Answer<Integer>) | ||
i -> { | ||
if (callCount.getAndIncrement() < PagerDutyClient.MAX_RETRIES - 1) { | ||
return 500; | ||
} else { | ||
return 202; | ||
} | ||
}); | ||
|
||
when(httpClient.send( | ||
Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class))) | ||
.thenReturn(httpResponse); | ||
|
||
try { | ||
pagerDutyClient.triggerIncident("dedpuKey", samplePayload); | ||
verify(httpClient, times(PagerDutyClient.MAX_RETRIES)) | ||
.send(Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class)); | ||
} catch (PagerDutyException e) { | ||
fail("PagerDutyClient should have recovered from failing attempts."); | ||
} | ||
} | ||
|
||
@Test | ||
public void ioExceptionReachesMaxRetries() throws IOException, InterruptedException { | ||
when(httpClient.send( | ||
Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class))) | ||
.thenThrow(IOException.class); | ||
|
||
try { | ||
pagerDutyClient.triggerIncident("dedpuKey", samplePayload); | ||
fail("PagerDutyClient should have thrown an error from io exception."); | ||
} catch (PagerDutyException e) { | ||
verify(httpClient, times(PagerDutyClient.MAX_RETRIES)) | ||
.send(Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class)); | ||
} | ||
} | ||
|
||
@Test | ||
public void testBadRequest() throws IOException, InterruptedException { | ||
when(httpResponse.statusCode()).thenReturn(400); | ||
when(httpClient.send( | ||
Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class))) | ||
.thenReturn(httpResponse); | ||
|
||
try { | ||
pagerDutyClient.triggerIncident("dedpuKey", samplePayload); | ||
fail("PagerDutyClient should throw exception for 400 bad request."); | ||
} catch (PagerDutyException e) { | ||
} | ||
|
||
try { | ||
pagerDutyClient.resolveIncident("dedupKey"); | ||
fail("PagerDutyClient should throw exception for 400 bad request."); | ||
} catch (PagerDutyException e) { | ||
} | ||
|
||
verify(httpClient, times(2)) | ||
.send(Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class)); | ||
} | ||
|
||
@Test | ||
public void testFailsWithoutDedupKey() throws IOException, InterruptedException { | ||
when(httpResponse.statusCode()).thenReturn(200); | ||
when(httpClient.send( | ||
Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class))) | ||
.thenReturn(httpResponse); | ||
|
||
try { | ||
pagerDutyClient.triggerIncident("", samplePayload); | ||
fail("PagerDutyClient should throw exception for null deduplication key."); | ||
} catch (PagerDutyException e) { | ||
} | ||
|
||
try { | ||
pagerDutyClient.resolveIncident(null); | ||
fail("PagerDutyClient should throw exception for empty deduplication key."); | ||
} catch (PagerDutyException e) { | ||
} | ||
|
||
verify(httpClient, never()) | ||
.send(Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class)); | ||
} | ||
|
||
@Test | ||
public void testFailsWithoutIntegrationKey() throws IOException, InterruptedException { | ||
when(httpResponse.statusCode()).thenReturn(200); | ||
when(httpClient.send( | ||
Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class))) | ||
.thenReturn(httpResponse); | ||
|
||
pagerDutyClient = new PagerDutyClient(null, httpClient); | ||
|
||
try { | ||
pagerDutyClient.triggerIncident("dedupKey", samplePayload); | ||
fail("PagerDutyClient should throw exception for null integration key."); | ||
} catch (PagerDutyException e) { | ||
|
||
} | ||
|
||
pagerDutyClient = new PagerDutyClient("", httpClient); | ||
try { | ||
pagerDutyClient.resolveIncident(null); | ||
fail("PagerDutyClient should throw exception for empty integration key."); | ||
} catch (PagerDutyException e) { | ||
} | ||
|
||
verify(httpClient, never()) | ||
.send(Mockito.any(HttpRequest.class), Mockito.any(HttpResponse.BodyHandler.class)); | ||
} | ||
} |