ReloadTest.java
/*
* Copyright (c) 2015, 2022 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package org.glassfish.jersey.tests.integration.multimodule.ejb.reload.web1;
import javax.ws.rs.client.WebTarget;
import javax.ws.rs.core.Application;
import javax.ws.rs.core.Response;
import org.glassfish.jersey.client.ClientConfig;
import org.glassfish.jersey.logging.LoggingFeature;
import org.glassfish.jersey.test.JerseyTest;
import org.junit.jupiter.api.Test;
import static org.hamcrest.CoreMatchers.equalTo;
import static org.hamcrest.CoreMatchers.is;
import static org.hamcrest.MatcherAssert.assertThat;
/**
* Test reload functionality for two web app test case.
* Run with:
* <pre>
* mvn clean package
* $AS_HOME/bin/asadmin deploy ../ear/target/ejb-multimodule-reload-ear-*.ear
* mvn -DskipTests=false test</pre>
*
* @author Jakub Podlesak
*/
public class ReloadTest extends JerseyTest {
@Override
protected Application configure() {
return new FirstApp();
}
@Override
protected void configureClient(final ClientConfig config) {
config.register(LoggingFeature.class);
}
@Test
public void testReload() {
final WebTarget nanosTarget = target().path("ejb-multimodule-reload-war1/last-init-nano-time");
final long nanos1 = _readInitTimeNanos(nanosTarget);
final long nanos2 = _readInitTimeNanos(nanosTarget);
assertThat(nanos2, is(equalTo(nanos1)));
// J-592 reproducer:
// reload();
//
// final long nanos3 = _readInitTimeNanos(nanosTarget);
// final long nanos4 = _readInitTimeNanos(nanosTarget);
//
// assertThat(nanos4, is(equalTo(nanos3)));
// assertThat(nanos3, is(greaterThan(nanos2)));
//
// reload();
//
// final long nanos5 = _readInitTimeNanos(nanosTarget);
// final long nanos6 = _readInitTimeNanos(nanosTarget);
//
// assertThat(nanos6, is(equalTo(nanos5)));
// assertThat(nanos5, is(greaterThan(nanos4)));
// END: J-592 reproducer
}
private void reload() {
final WebTarget reloadTarget = target().path("ejb-multimodule-reload-war2/reload");
assertThat(reloadTarget.request().get().getStatus(), is(204));
}
private long _readInitTimeNanos(final WebTarget target) throws NumberFormatException {
final Response response = target.request().get();
assertThat(response.getStatus(), is(200));
return Long.parseLong(response.readEntity(String.class));
}
}