blob: 1cdcb48cd6579b23e9d457c54933dffcd8e56803 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.sling.testing.teleporter.client;
import static com.github.tomakehurst.wiremock.client.WireMock.aResponse;
import static com.github.tomakehurst.wiremock.client.WireMock.get;
import static com.github.tomakehurst.wiremock.client.WireMock.givenThat;
import static com.github.tomakehurst.wiremock.client.WireMock.urlEqualTo;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.fail;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.nio.charset.StandardCharsets;
import java.util.Timer;
import java.util.TimerTask;
import java.util.UUID;
import org.apache.commons.io.IOUtils;
import org.apache.sling.testing.clients.util.TimeoutsProvider;
import org.junit.Rule;
import org.junit.Test;
import com.github.tomakehurst.wiremock.junit.WireMockRule;
public class TeleporterHttpClientTest {
private static final int PORT = Integer.getInteger("http.port", 1234);
private static final String baseUrl = "http://127.0.0.1:" + PORT;
private static final String TEST_PATH = "/foo";
@Rule
public WireMockRule http = new WireMockRule(PORT);
private void activateLater(final String path, long delayMsec) {
TimerTask t = new TimerTask() {
public void run() {
givenThat(get(urlEqualTo(path)).willReturn(aResponse().withStatus(200)));
}
};
new Timer(true).schedule(t, delayMsec);
}
@Test
public void waitForStatusWithLongTimeout() throws MalformedURLException, IOException {
final TeleporterHttpClient client = new TeleporterHttpClient(baseUrl, TEST_PATH);
final String testUrl = baseUrl + TEST_PATH;
assertEquals(404, client.getHttpGetStatus(baseUrl + TEST_PATH).getStatus());
activateLater(TEST_PATH, 1000);
client.waitForStatus(testUrl, 200, TimeoutsProvider.getInstance().getTimeout(2000));
assertEquals(200, client.getHttpGetStatus(baseUrl + TEST_PATH).getStatus());
}
@Test
public void waitForStatusWithShortTimeout() throws MalformedURLException, IOException {
final TeleporterHttpClient client = new TeleporterHttpClient(baseUrl, TEST_PATH);
final String testUrl = baseUrl + TEST_PATH;
assertEquals(404, client.getHttpGetStatus(baseUrl + TEST_PATH).getStatus());
activateLater(TEST_PATH, 1000);
try {
client.waitForStatus(testUrl, 200, 100);
fail("Expected waitForStatus to timeout");
} catch(IOException expected) {
}
}
@Test
public void repeatedGetStatus() {
final String path = TEST_PATH + "/" + UUID.randomUUID();
givenThat(get(urlEqualTo(path)).willReturn(aResponse().withStatus(200)));
final TeleporterHttpClient client = new TeleporterHttpClient(baseUrl, path);
final String testUrl = baseUrl + path;
final int N = Integer.getInteger("sling.getstatus.test.count", 1000);
int status = 0;
for(int i=0; i < N; i++) {
try {
status = client.getHttpGetStatus(testUrl).getStatus();
} catch(Exception e) {
fail("Exception at index " + i + ":" + e);
}
assertEquals("Expecting status 200 at index " + i, 200, status);
}
}
@Test(expected=IllegalStateException.class)
public void testVerifyCorrectBundleStateForInactiveBundle() throws IOException {
final TeleporterHttpClient client = new TeleporterHttpClient(baseUrl, "invalid");
String bundleSymbolicName = "testBundle1";
// open resource
try (InputStream inputStream = this.getClass().getResourceAsStream("/bundle-not-active.json")) {
String body = IOUtils.toString(inputStream, StandardCharsets.UTF_8);
givenThat(get(urlEqualTo("/system/console/bundles/" + bundleSymbolicName + ".json")).willReturn(aResponse().withStatus(200).withBody(body)));
}
client.verifyCorrectBundleState(bundleSymbolicName, 1);
}
@Test
public void testVerifyCorrectBundleStateForActiveBundle() throws IOException {
final TeleporterHttpClient client = new TeleporterHttpClient(baseUrl, "invalid");
String bundleSymbolicName = "testBundle2";
// open resource
try (InputStream inputStream = this.getClass().getResourceAsStream("/bundle-active.json")) {
String body = IOUtils.toString(inputStream, StandardCharsets.UTF_8);
givenThat(get(urlEqualTo("/system/console/bundles/" + bundleSymbolicName + ".json")).willReturn(aResponse().withStatus(200).withBody(body)));
}
client.verifyCorrectBundleState(bundleSymbolicName, 1);
}
}