Java tutorial
/** * Copyright 2013 DuraSpace, 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.fcrepo.auth.oauth.integration.api; import static java.lang.Integer.MAX_VALUE; import static java.lang.Integer.parseInt; import static java.lang.System.getProperty; import static java.util.concurrent.TimeUnit.SECONDS; import static org.slf4j.LoggerFactory.getLogger; import java.io.IOException; import java.io.UnsupportedEncodingException; import org.apache.http.HttpResponse; import org.apache.http.client.ClientProtocolException; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpPost; import org.apache.http.client.methods.HttpPut; import org.apache.http.client.methods.HttpUriRequest; import org.apache.http.entity.StringEntity; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.impl.conn.PoolingClientConnectionManager; import org.apache.http.util.EntityUtils; import org.junit.Before; import org.junit.runner.RunWith; import org.slf4j.Logger; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; @RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration("/spring-test/test-container.xml") public abstract class AbstractOAuthResourceIT { protected final String authzEndpoint = "http://" + HOSTNAME + ":" + SERVER_PORT + "/authorization"; protected final String tokenEndpoint = "http://" + HOSTNAME + ":" + SERVER_PORT + "/token"; protected Logger logger; protected String OBJECT_PATH = "objects"; @Before public void setLogger() { logger = getLogger(this.getClass()); } protected static final int SERVER_PORT = parseInt(getProperty("test.port", "8080")); protected static final String HOSTNAME = "localhost"; protected static final String serverAddress = "http://" + HOSTNAME + ":" + SERVER_PORT + "/rest/"; protected final PoolingClientConnectionManager connectionManager = new PoolingClientConnectionManager(); protected static HttpClient client; public AbstractOAuthResourceIT() { connectionManager.setMaxTotal(MAX_VALUE); connectionManager.setDefaultMaxPerRoute(5); connectionManager.closeIdleConnections(3, SECONDS); client = new DefaultHttpClient(connectionManager); } protected static HttpPost postObjMethod(final String pid) { return new HttpPost(serverAddress + "objects/" + pid); } protected static HttpPost postObjMethod(final String pid, final String query) { if (query.equals("")) { return new HttpPost(serverAddress + "objects/" + pid); } else { return new HttpPost(serverAddress + "objects/" + pid + "?" + query); } } protected static HttpPost postDSMethod(final String pid, final String ds, final String content) throws UnsupportedEncodingException { final HttpPost post = new HttpPost(serverAddress + "objects/" + pid + "/" + ds + "/fcr:content"); post.setEntity(new StringEntity(content)); return post; } protected static HttpPut putDSMethod(final String pid, final String ds, final String content) throws UnsupportedEncodingException { final HttpPut put = new HttpPut(serverAddress + "objects/" + pid + "/" + ds + "/fcr:content"); put.setEntity(new StringEntity(content)); return put; } protected HttpResponse execute(final HttpUriRequest method) throws ClientProtocolException, IOException { logger.debug("Executing: " + method.getMethod() + " to " + method.getURI()); return client.execute(method); } protected int getStatus(final HttpUriRequest method) throws ClientProtocolException, IOException { final HttpResponse response = execute(method); final int result = response.getStatusLine().getStatusCode(); if (!(result > 199) || !(result < 400)) { logger.warn(EntityUtils.toString(response.getEntity())); } return result; } }