MetricsTest.java
/**
* The MIT License
*
* Copyright for portions of unirest-java are held by Kong Inc (c) 2013.
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
package BehaviorTests;
import kong.unirest.core.HttpRequestSummary;
import kong.unirest.core.Unirest;
import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Test;
import java.util.HashMap;
import java.util.function.Function;
import static BehaviorTests.MockServer.*;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
import static org.junit.jupiter.api.Assertions.*;
class MetricsTest extends BddTest {
@Test
void canSetAMetricObjectToInstramentUnirest() {
var metric = configureMetric();
Unirest.get(GET).asEmpty();
Unirest.get(GET).asEmpty();
Unirest.get(PASSED_PATH_PARAM)
.routeParam("params", "foo")
.queryString("fruit", "orange")
.asEmpty();
assertEquals(2, metric.routes.get(GET).size());
assertEquals(1, metric.routes.get("http://localhost:4567/get/foo/passed?fruit=orange").size());
}
@Test
void canGetParamedUrlInSummary() {
var metric = configureMetric(HttpRequestSummary::getRawPath);
Unirest.get(PASSED_PATH_PARAM)
.routeParam("params", "foo")
.queryString("fruit", "orange")
.asEmpty();
assertEquals(1, metric.routes.get("http://localhost:4567/get/{params}/passed").size());
}
@Test
void canGetToMethod() {
var metric = configureMetric(s -> s.getHttpMethod().name());
Unirest.get(GET).asEmpty();
Unirest.get(GET).asEmpty();
Unirest.post(POST).asEmpty();
Unirest.delete(DELETE).asEmpty();
assertEquals(2, metric.routes.get("GET").size());
assertEquals(1, metric.routes.get("DELETE").size());
}
@Test
void amountOfTimeBetweenRequestAndResponseDoesNotIncludeDeserialization() {
var metric = configureMetric();
Unirest.get(GET).asObject(r -> {
assertEquals(1, metric.routes.get(GET).size());
return null;
});
}
@Test
void canGetInformationOnStatus() {
var metric = configureMetric(HttpRequestSummary::getUrl);
Unirest.get(GET).asEmpty();
Unirest.get(REDIRECT).asEmpty();
Unirest.get(REDIRECT).asEmpty();
Unirest.get(ERROR_RESPONSE).asEmpty();
assertEquals(1L, metric.countResponses(200));
assertEquals(2L, metric.countResponses(301));
assertEquals(1L, metric.countResponses(400));
}
@Test
void metricsOnAsyncRequests() throws Exception {
var metric = configureMetric();
Unirest.get(GET).asEmptyAsync().get();
assertEquals(1L, metric.countResponses(200));
}
@Test
void metricsOnAsyncMethodsWithCallbacks() {
var metric = configureMetric();
Unirest.get(GET).asEmptyAsync(r -> asyncSuccess());
assertAsync();
assertEquals(1L, metric.countResponses(200));
}
@Test
void errorHandling() throws Exception {
var metric = new MyMetric(HttpRequestSummary::getUrl);
Unirest.config().reset().httpClient(TestUtil.getFailureClient()).instrumentWith(metric);
assertThatThrownBy(() -> Unirest.get(GET).asEmpty());
assertEquals("Something horrible happened", metric.routes.get(GET).get(0).e.getMessage());
}
@Test @Disabled
void errorHandling_async() throws Exception {
MyMetric metric = configureMetric();
try {
Unirest.get("http://localhost:0000").asEmptyAsync().get();
}catch (Exception e){
}
assertEquals("Connection refused", metric.routes.get("http://localhost:0000").get(0).e.getMessage());
assertEquals(1, metric.routes.get("http://localhost:0000").size());
}
long exTime;
@Test
void metricAsALambda() {
exTime = 0;
Unirest.config().instrumentWith((s) -> {
long startNanos = System.nanoTime();
return (r,e) -> exTime = System.nanoTime() - startNanos;
});
Unirest.get(GET).asEmpty();
assertTrue(exTime > 0L);
}
@Test
void showWhatJavalinDoes() {
var map = Unirest.get(JAVALIN)
.routeParam("spark", "joy")
.queryString("food", "hamberders")
.queryString("colour", "red")
.asObject(HashMap.class)
.getBody();
assertEquals("localhost:4567", map.get("host()"));
assertEquals("/sparkle/joy/yippy", map.get("uri()")); // this is different from what the Spark doc says.
assertEquals("http://localhost:4567/sparkle/joy/yippy", map.get("url()"));
assertEquals("", map.get("contextPath()"));
assertEquals("/sparkle/joy/yippy", map.get("pathInfo()"));
assertEquals("food=hamberders&colour=red", map.get("queryString()"));
}
private MyMetric configureMetric() {
return configureMetric(HttpRequestSummary::getUrl);
}
private MyMetric configureMetric(Function<HttpRequestSummary, String> keyFunction) {
var metric = new MyMetric(keyFunction);
Unirest.config().followRedirects(false).instrumentWith(metric);
return metric;
}
}