/*
* Copyright 2014 JBoss Inc
*
* Licensed 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.artificer.test;
import org.apache.http.HttpHost;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.AuthCache;
import org.apache.http.client.protocol.ClientContext;
import org.apache.http.impl.auth.BasicScheme;
import org.apache.http.impl.client.BasicAuthCache;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.protocol.BasicHttpContext;
import org.artificer.client.ArtificerAtomApiClient;
import org.artificer.client.ArtificerClientException;
import org.artificer.client.ClientRequest;
import org.artificer.client.ontology.OntologySummary;
import org.artificer.common.query.ArtifactSummary;
import org.artificer.client.query.QueryResultSet;
import org.artificer.common.error.ArtificerServerException;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.resteasy.client.core.executors.ApacheHttpClient4Executor;
import org.junit.After;
import org.junit.runner.RunWith;
import org.oasis_open.docs.s_ramp.ns.s_ramp_v1.StoredQuery;
import java.util.List;
import static org.junit.Assert.fail;
/**
* @author Brett Meyer
*/
@RunWith(Arquillian.class)
public abstract class AbstractIntegrationTest {
// Note: Running Arquillian in its as-client mode by leaving off the @Deployment.
private static final String HOST = System.getProperty("artificer.test.host", "localhost");
private static final int PORT = Integer.parseInt(System.getProperty("artificer.test.port", "8080"));
private static final String BASE_URL = "http://" + HOST + ":" + PORT + "/artificer-server";
protected static final String USERNAME = System.getProperty("artificer.test.username", "admin");
protected static final String PASSWORD = System.getProperty("artificer.test.password", "artificer1!");
@After
public void cleanup() {
// delete all artifacts
try {
ArtificerAtomApiClient client = client();
// Rather than mess with pagination, just set the count to something sufficiently large.
QueryResultSet results = client.query("/s-ramp", 0, 10000, "name", true);
for (ArtifactSummary summary : results) {
String uuid = summary.getUuid().replace("urn:uuid:", "");
if (!summary.isDerived() && !summary.isExpandedFromArchive()) {
client.deleteArtifact(uuid, summary.getArtifactType(), true);
}
}
} catch (Exception e) {
e.printStackTrace();
fail("Unable to cleanup test artifacts.");
}
// delete all stored queries
try {
ArtificerAtomApiClient client = client();
List<StoredQuery> storedQueries = client.getStoredQueries();
for (StoredQuery storedQuery : storedQueries) {
client.deleteStoredQuery(storedQuery.getQueryName());
}
} catch (Exception e) {
e.printStackTrace();
fail("Unable to cleanup test artifacts.");
}
// delete all ontologies
try {
ArtificerAtomApiClient client = client();
List<OntologySummary> ontologies = client.getOntologies();
for (OntologySummary ontology : ontologies) {
String uuid = ontology.getUuid().replace("urn:uuid:", "");
client.deleteOntology(uuid);
}
} catch (Exception e) {
e.printStackTrace();
fail("Unable to cleanup test artifacts.");
}
}
protected String getHost() {
return HOST;
}
protected int getPort() {
return PORT;
}
protected String getUsername() {
return USERNAME;
}
protected String getPassword() {
return PASSWORD;
}
protected ArtificerAtomApiClient client() throws ArtificerClientException, ArtificerServerException {
return new ArtificerAtomApiClient(BASE_URL, USERNAME, PASSWORD, true);
}
protected ClientRequest clientRequest(String endpoint) {
DefaultHttpClient client = new DefaultHttpClient();
UsernamePasswordCredentials credentials = new UsernamePasswordCredentials(USERNAME, PASSWORD);
client.getCredentialsProvider().setCredentials(new AuthScope(AuthScope.ANY), credentials);
AuthCache authCache = new BasicAuthCache();
BasicScheme basicAuth = new BasicScheme();
HttpHost targetHost = new HttpHost(HOST, PORT);
authCache.put(targetHost, basicAuth);
BasicHttpContext localContext = new BasicHttpContext();
localContext.setAttribute(ClientContext.AUTH_CACHE, authCache);
ApacheHttpClient4Executor executor = new ApacheHttpClient4Executor(client, localContext);
ClientRequest clientRequest = new ClientRequest(BASE_URL + endpoint, executor);
return clientRequest;
}
protected String generateURL(String endpoint) {
return BASE_URL + endpoint;
}
}