/**
* Licensed to The Apereo Foundation under one or more contributor license
* agreements. See the NOTICE file distributed with this work for additional
* information regarding copyright ownership.
*
*
* The Apereo Foundation licenses this file to you under the Educational
* Community 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://opensource.org/licenses/ecl2.txt
*
* 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.opencastproject.adminui.endpoint;
import static com.jayway.restassured.RestAssured.given;
import static org.hamcrest.Matchers.equalTo;
import static org.opencastproject.rest.RestServiceTestEnv.localhostRandomPort;
import static org.opencastproject.rest.RestServiceTestEnv.testEnvForClasses;
import org.opencastproject.adminui.util.ServiceEndpointTestsUtil;
import org.opencastproject.rest.RestServiceTestEnv;
import com.jayway.restassured.http.ContentType;
import org.apache.commons.httpclient.HttpStatus;
import org.json.simple.JSONObject;
import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
/**
* Services Endpoint unit tests.
*/
public class ServicesEndpointTest {
/** Test data ressource json file. */
private static final String TEST_DATA_JSON = "/services.json";
/** REST endpoint test environment. */
private static final RestServiceTestEnv rt = testEnvForClasses(localhostRandomPort(), TestServicesEndpoint.class);
/** Json parser. */
private JSONParser parser;
@Before
public void setUp() {
parser = new JSONParser();
}
@BeforeClass
public static void oneTimeSetUp() {
rt.setUpServer();
}
@AfterClass
public static void oneTimeTearDown() {
rt.tearDownServer();
}
@Test
public void testSimpleRequest() throws ParseException, IOException {
InputStream stream = ServicesEndpointTest.class.getResourceAsStream(TEST_DATA_JSON);
InputStreamReader reader = new InputStreamReader(stream);
JSONObject expected = (JSONObject) new JSONParser().parse(reader);
JSONObject actual = (JSONObject) parser.parse(given().log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON).when().get(rt.host(TEST_DATA_JSON)).asString());
ServiceEndpointTestsUtil.testJSONObjectEquality(expected, actual);
}
@Test
public void testLimitAndOffset() {
given().param("limit", 10).param("offset", 2).log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("limit", equalTo(10))
.content("count", equalTo(4))
.content("total", equalTo(6))
.content("results[0].name", equalTo("service3"))
.content("results[3].name", equalTo("service6"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("limit", 2).param("offset", 3).log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("limit", equalTo(2))
.content("count", equalTo(2))
.content("total", equalTo(6))
.content("results[0].name", equalTo("service4"))
.content("results[1].name", equalTo("service5"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("limit", 0).param("offset", 10).log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("limit", equalTo(0))
.content("count", equalTo(0))
.content("total", equalTo(6))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testNameFilter() {
given().param("filter", "name:service2").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(1))
.content("total", equalTo(1))
.content("results[0].name", equalTo("service2"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("filter", "name:service").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(0))
.content("total", equalTo(0))
.when().get(rt.host(TEST_DATA_JSON));
given().param("filter", " name:service2 ").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(1))
.content("total", equalTo(1))
.content("results[0].name", equalTo("service2"))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testHostnameFilter() {
given().param("filter", "hostname:host1").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(2))
.content("total", equalTo(2))
.content("results[0].hostname", equalTo("host1"))
.content("results[1].hostname", equalTo("host1"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("filter", "hostname:host").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(0))
.content("total", equalTo(0))
.when().get(rt.host(TEST_DATA_JSON));
given().param("filter", " hostname:host1 ").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(2))
.content("total", equalTo(2))
.content("results[0].hostname", equalTo("host1"))
.content("results[1].hostname", equalTo("host1"))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testActionsFilter() {
given().param("filter", "actions:true").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(2))
.content("total", equalTo(2))
.content("results[0].hostname", equalTo("host1"))
.content("results[0].name", equalTo("service2"))
.content("results[1].hostname", equalTo("host3"))
.content("results[1].name", equalTo("service4"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("filter", "actions:false").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(4))
.content("total", equalTo(4))
.content("results[0].hostname", equalTo("host1"))
.content("results[0].name", equalTo("service1"))
.content("results[1].hostname", equalTo("host2"))
.content("results[1].name", equalTo("service3"))
.content("results[2].hostname", equalTo("host2"))
.content("results[2].name", equalTo("service5"))
.content("results[3].hostname", equalTo("host4"))
.content("results[3].name", equalTo("service6"))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testFreeTextFilter() {
given().param("filter", "textFilter:host1").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(2))
.content("total", equalTo(2))
.content("results[0].hostname", equalTo("host1"))
.content("results[1].hostname", equalTo("host1"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("filter", "textFilter:service4").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(1))
.content("total", equalTo(1))
.content("results[0].name", equalTo("service4"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("filter", "textFilter:2").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(3))
.content("total", equalTo(3))
.content("results[0].name", equalTo("service2"))
.content("results[1].hostname", equalTo("host2"))
.content("results[2].hostname", equalTo("host2"))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testHostSort() {
given().param("sort", "hostname:asc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[0].hostname", equalTo("host1"))
.content("results[1].hostname", equalTo("host1"))
.content("results[2].hostname", equalTo("host2"))
.content("results[3].hostname", equalTo("host2"))
.content("results[4].hostname", equalTo("host3"))
.content("results[5].hostname", equalTo("host4"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("sort", "hostname:desc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[5].hostname", equalTo("host1"))
.content("results[4].hostname", equalTo("host1"))
.content("results[3].hostname", equalTo("host2"))
.content("results[2].hostname", equalTo("host2"))
.content("results[1].hostname", equalTo("host3"))
.content("results[0].hostname", equalTo("host4"))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testNameSort() {
given().param("sort", "name:asc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[0].name", equalTo("service1"))
.content("results[1].name", equalTo("service2"))
.content("results[2].name", equalTo("service3"))
.content("results[3].name", equalTo("service4"))
.content("results[4].name", equalTo("service5"))
.content("results[5].name", equalTo("service6"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("sort", "name:desc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[5].name", equalTo("service1"))
.content("results[4].name", equalTo("service2"))
.content("results[3].name", equalTo("service3"))
.content("results[2].name", equalTo("service4"))
.content("results[1].name", equalTo("service5"))
.content("results[0].name", equalTo("service6"))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testRunningJobsSort() {
given().param("sort", "running:asc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[3].running", equalTo(0))
.content("results[4].running", equalTo(1))
.content("results[5].running", equalTo(2))
.when().get(rt.host(TEST_DATA_JSON));
given().param("sort", "running:desc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[0].running", equalTo(2))
.content("results[1].running", equalTo(1))
.content("results[2].running", equalTo(0))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testQueuedJobsSort() {
given().param("sort", "queued:asc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[1].queued", equalTo(0))
.content("results[2].queued", equalTo(1))
.content("results[3].queued", equalTo(1))
.content("results[4].queued", equalTo(3))
.content("results[5].queued", equalTo(5))
.when().get(rt.host(TEST_DATA_JSON));
given().param("sort", "queued:desc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[4].queued", equalTo(0))
.content("results[3].queued", equalTo(1))
.content("results[2].queued", equalTo(1))
.content("results[1].queued", equalTo(3))
.content("results[0].queued", equalTo(5))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testCompletedJobsSort() {
given().param("sort", "completed:asc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[2].completed", equalTo(0))
.content("results[3].completed", equalTo(5))
.content("results[4].completed", equalTo(10))
.content("results[5].completed", equalTo(20))
.when().get(rt.host(TEST_DATA_JSON));
given().param("sort", "completed:desc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[3].completed", equalTo(0))
.content("results[2].completed", equalTo(5))
.content("results[1].completed", equalTo(10))
.content("results[0].completed", equalTo(20))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testMeanRunTimeSort() {
given().param("sort", "meanRunTime:asc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[2].meanRunTime", equalTo(0))
.content("results[3].meanRunTime", equalTo(10))
.content("results[4].meanRunTime", equalTo(30))
.content("results[5].meanRunTime", equalTo(123))
.when().get(rt.host(TEST_DATA_JSON));
given().param("sort", "meanRunTime:desc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[3].meanRunTime", equalTo(0))
.content("results[2].meanRunTime", equalTo(10))
.content("results[1].meanRunTime", equalTo(30))
.content("results[0].meanRunTime", equalTo(123))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testMeanQueuedTimeSort() {
given().param("sort", "meanQueueTime:asc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[0].meanQueueTime", equalTo(0))
.content("results[1].meanQueueTime", equalTo(0))
.content("results[2].meanQueueTime", equalTo(10))
.content("results[3].meanQueueTime", equalTo(30))
.content("results[4].meanQueueTime", equalTo(60))
.content("results[5].meanQueueTime", equalTo(456))
.when().get(rt.host(TEST_DATA_JSON));
given().param("sort", "meanQueueTime:desc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[5].meanQueueTime", equalTo(0))
.content("results[4].meanQueueTime", equalTo(0))
.content("results[3].meanQueueTime", equalTo(10))
.content("results[2].meanQueueTime", equalTo(30))
.content("results[1].meanQueueTime", equalTo(60))
.content("results[0].meanQueueTime", equalTo(456))
.when().get(rt.host(TEST_DATA_JSON));
}
@Test
public void testStatusSort() {
given().param("sort", "status:asc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[0].status", equalTo("NORMAL"))
.content("results[1].status", equalTo("NORMAL"))
.content("results[4].status", equalTo("WARNING"))
.content("results[5].status", equalTo("ERROR"))
.when().get(rt.host(TEST_DATA_JSON));
given().param("sort", "status:desc").log().all().expect().statusCode(HttpStatus.SC_OK)
.contentType(ContentType.JSON)
.content("count", equalTo(6))
.content("total", equalTo(6))
.content("results[5].status", equalTo("NORMAL"))
.content("results[4].status", equalTo("NORMAL"))
.content("results[1].status", equalTo("WARNING"))
.content("results[0].status", equalTo("ERROR"))
.when().get(rt.host(TEST_DATA_JSON));
}
}