The latest version: $LATEST_VERSION. Please use Maven Central
link above to get the logger.
OkHttp3 Request/Response logger for Report Portal
The logger intercept and logs all Requests and Responses issued by OkHttp into Report Portal in Markdown format, including multipart requests. It recognizes payload types and attach them in corresponding manner: image types will be logged as images with thumbnails, binary types will be logged as entry attachments, text types will be formatted and logged in Markdown code blocks.
You need to add the logger as one of your dependencies in Maven or Gradle.
pom.xml
<project>
<!-- project declaration omitted -->
<dependencies>
<dependency>
<groupId>com.epam.reportportal</groupId>
<artifactId>logger-java-okhttp3</artifactId>
<version>$LATEST_VERSION</version>
</dependency>
</dependencies>
<!-- build config omitted -->
</project>
build.gradle
dependencies {
testCompile 'com.epam.reportportal:logger-java-okhttp3:$LATEST_VERSION'
}
To start getting Request and Response logging in Report Portal you need to add the logger as one of your OkHttp
interceptors. The best place for it is one before hook methods. E.G. @BeforeClass
method for TestNG or @BeforeAll
method for JUnit 5:
public class BaseTest {
private OkHttpClient client;
@BeforeClass
public void setupOkHttp3() {
client = new OkHttpClient.Builder().addInterceptor(new ReportPortalOkHttp3LoggingInterceptor(LogLevel.INFO))
.build();
}
}
To avoid logging sensitive data into Report Portal you can use corresponding converters:
- Cookie converter
- Header converter
- URI converter
- Content prettiers
Cookie, Header and URI converters are set in the logger constructor:
public class BaseTest {
private OkHttpClient client;
@BeforeClass
public void setupOkHttp3() {
client = new OkHttpClient.Builder().addInterceptor(new ReportPortalOkHttp3LoggingInterceptor(LogLevel.INFO,
SanitizingHttpHeaderConverter.INSTANCE,
DefaultHttpHeaderConverter.INSTANCE
))
.authenticator((route, response) -> {
String credential = "Bearer test_token";
return response.request().newBuilder().header("Authorization", credential).build();
})
.followRedirects(true)
.build();
}
}
You are free to implement any converter by yourself with java.util.function.Function
interface.
Content prettier are more complex, they parse data based on its content type and apply defined transformations. Default
prettiers just pretty-print JSON, HTML and XML data. To apply a custom content prettier call
ReportPortalOkHttp3LoggingInterceptor.setContentPrettiers
.
E.G.:
public class BaseTest {
private static final Map<String, Function<String, String>> MY_PRETTIERS = new HashMap<String, Function<String, String>>() {{
put(ContentType.APPLICATION_XML.getMimeType(), XmlPrettier.INSTANCE);
put(ContentType.APPLICATION_SOAP_XML.getMimeType(), XmlPrettier.INSTANCE);
put(ContentType.APPLICATION_ATOM_XML.getMimeType(), XmlPrettier.INSTANCE);
put(ContentType.APPLICATION_SVG_XML.getMimeType(), XmlPrettier.INSTANCE);
put(ContentType.APPLICATION_XHTML_XML.getMimeType(), XmlPrettier.INSTANCE);
put(ContentType.TEXT_XML.getMimeType(), XmlPrettier.INSTANCE);
put(ContentType.APPLICATION_JSON.getMimeType(), JsonPrettier.INSTANCE);
put("text/json", JsonPrettier.INSTANCE);
put(ContentType.TEXT_HTML.getMimeType(), HtmlPrettier.INSTANCE);
}};
private OkHttpClient client;
@BeforeClass
public void setupOkHttp3() {
client = new OkHttpClient.Builder().addInterceptor(new ReportPortalOkHttp3LoggingInterceptor(LogLevel.INFO).setContentPrettiers(
MY_PRETTIERS)).build();
}
}