HADOOP-9613. [JDK8] Update jersey version to latest 1.x release.

This commit is contained in:
Tsuyoshi Ozawa 2016-02-16 01:02:09 +09:00
parent 8c1f81d4bf
commit 5d58858bb6
38 changed files with 692 additions and 663 deletions

View File

@ -115,6 +115,11 @@
<artifactId>jersey-core</artifactId> <artifactId>jersey-core</artifactId>
<scope>compile</scope> <scope>compile</scope>
</dependency> </dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-servlet</artifactId>
<scope>compile</scope>
</dependency>
<dependency> <dependency>
<!-- Used, even though 'mvn dependency:analyze' doesn't find it --> <!-- Used, even though 'mvn dependency:analyze' doesn't find it -->
<groupId>com.sun.jersey</groupId> <groupId>com.sun.jersey</groupId>

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.mapreduce.v2.app.webapp; package org.apache.hadoop.mapreduce.v2.app.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
@ -33,6 +34,7 @@ import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.mapreduce.v2.app.AppContext; import org.apache.hadoop.mapreduce.v2.app.AppContext;
import org.apache.hadoop.mapreduce.v2.app.MockAppContext; import org.apache.hadoop.mapreduce.v2.app.MockAppContext;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -46,8 +48,6 @@ import org.xml.sax.InputSource;
import com.google.common.collect.Sets; import com.google.common.collect.Sets;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -69,13 +69,13 @@ public class TestAMWebServices extends JerseyTest {
private static Configuration conf = new Configuration(); private static Configuration conf = new Configuration();
private static MockAppContext appContext; private static MockAppContext appContext;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockAppContext(0, 1, 1, 1); appContext = new MockAppContext(0, 1, 1, 1);
appContext.setBlacklistedNodes(Sets.newHashSet("badnode1", "badnode2")); appContext.setBlacklistedNodes(Sets.newHashSet("badnode1", "badnode2"));
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
bind(AMWebServices.class); bind(AMWebServices.class);
bind(GenericExceptionHandler.class); bind(GenericExceptionHandler.class);
@ -84,20 +84,19 @@ public class TestAMWebServices extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestAMWebServices() { public TestAMWebServices() {
@ -207,7 +206,7 @@ public class TestAMWebServices extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -223,7 +222,7 @@ public class TestAMWebServices extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -239,8 +238,8 @@ public class TestAMWebServices extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.INTERNAL_SERVER_ERROR, assertResponseStatusCode(Status.INTERNAL_SERVER_ERROR,
response.getClientResponseStatus()); response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }

View File

@ -44,8 +44,8 @@ import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.security.authentication.server.AuthenticationFilter; import org.apache.hadoop.security.authentication.server.AuthenticationFilter;
import org.apache.hadoop.security.authentication.server.PseudoAuthenticationHandler; import org.apache.hadoop.security.authentication.server.PseudoAuthenticationHandler;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONException;
import org.codehaus.jettison.json.JSONObject; import org.codehaus.jettison.json.JSONObject;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
@ -55,9 +55,7 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.Singleton; import com.google.inject.Singleton;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
@ -77,7 +75,8 @@ public class TestAMWebServicesAttempt extends JerseyTest {
private static AppContext appContext; private static AppContext appContext;
private String webserviceUserName = "testuser"; private String webserviceUserName = "testuser";
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockAppContext(0, 1, 2, 1); appContext = new MockAppContext(0, 1, 2, 1);
@ -90,7 +89,7 @@ public class TestAMWebServicesAttempt extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
filter("/*").through(TestRMCustomAuthFilter.class); filter("/*").through(TestRMCustomAuthFilter.class);
} }
}); };
@Singleton @Singleton
public static class TestRMCustomAuthFilter extends AuthenticationFilter { public static class TestRMCustomAuthFilter extends AuthenticationFilter {
@ -112,18 +111,17 @@ public class TestAMWebServicesAttempt extends JerseyTest {
} }
} }
static {
public class GuiceServletConfig extends GuiceServletContextListener { GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestAMWebServicesAttempt() { public TestAMWebServicesAttempt() {

View File

@ -19,6 +19,7 @@
package org.apache.hadoop.mapreduce.v2.app.webapp; package org.apache.hadoop.mapreduce.v2.app.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
@ -44,6 +45,7 @@ import org.apache.hadoop.mapreduce.v2.app.job.TaskAttempt;
import org.apache.hadoop.mapreduce.v2.util.MRApps; import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.yarn.util.ConverterUtils; import org.apache.hadoop.yarn.util.ConverterUtils;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -56,8 +58,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.UniformInterfaceException; import com.sun.jersey.api.client.UniformInterfaceException;
@ -80,10 +80,10 @@ public class TestAMWebServicesAttempts extends JerseyTest {
private static Configuration conf = new Configuration(); private static Configuration conf = new Configuration();
private static AppContext appContext; private static AppContext appContext;
private Injector injector = Guice.createInjector(new ServletModule() {
private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockAppContext(0, 1, 2, 1); appContext = new MockAppContext(0, 1, 2, 1);
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
bind(AMWebServices.class); bind(AMWebServices.class);
@ -93,21 +93,19 @@ public class TestAMWebServicesAttempts extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestAMWebServicesAttempts() { public TestAMWebServicesAttempts() {
@ -379,7 +377,7 @@ public class TestAMWebServicesAttempts extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");

View File

@ -40,16 +40,11 @@ import org.apache.hadoop.fs.Path;
import org.apache.hadoop.mapreduce.MRJobConfig; import org.apache.hadoop.mapreduce.MRJobConfig;
import org.apache.hadoop.mapreduce.v2.api.records.JobId; import org.apache.hadoop.mapreduce.v2.api.records.JobId;
import org.apache.hadoop.mapreduce.v2.app.AppContext; import org.apache.hadoop.mapreduce.v2.app.AppContext;
import org.apache.hadoop.mapreduce.v2.app.ClusterInfo;
import org.apache.hadoop.mapreduce.v2.app.MockAppContext; import org.apache.hadoop.mapreduce.v2.app.MockAppContext;
import org.apache.hadoop.mapreduce.v2.app.MockJobs;
import org.apache.hadoop.mapreduce.v2.app.job.Job; import org.apache.hadoop.mapreduce.v2.app.job.Job;
import org.apache.hadoop.mapreduce.v2.util.MRApps; import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.yarn.api.records.ApplicationAttemptId;
import org.apache.hadoop.yarn.api.records.ApplicationId;
import org.apache.hadoop.yarn.event.EventHandler;
import org.apache.hadoop.yarn.util.Clock;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -62,10 +57,7 @@ import org.w3c.dom.Element;
import org.w3c.dom.NodeList; import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.common.collect.Maps;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
@ -87,7 +79,8 @@ public class TestAMWebServicesJobConf extends JerseyTest {
private static File testConfDir = new File("target", private static File testConfDir = new File("target",
TestAMWebServicesJobConf.class.getSimpleName() + "confDir"); TestAMWebServicesJobConf.class.getSimpleName() + "confDir");
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
@ -124,14 +117,11 @@ public class TestAMWebServicesJobConf extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); };
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@ -139,7 +129,8 @@ public class TestAMWebServicesJobConf extends JerseyTest {
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
testConfDir.mkdir(); testConfDir.mkdir();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
@AfterClass @AfterClass

View File

@ -19,6 +19,7 @@
package org.apache.hadoop.mapreduce.v2.app.webapp; package org.apache.hadoop.mapreduce.v2.app.webapp;
import static org.apache.hadoop.yarn.util.StringHelper.ujoin; import static org.apache.hadoop.yarn.util.StringHelper.ujoin;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
@ -45,6 +46,7 @@ import org.apache.hadoop.security.authorize.AccessControlList;
import org.apache.hadoop.yarn.api.records.NodeId; import org.apache.hadoop.yarn.api.records.NodeId;
import org.apache.hadoop.yarn.util.Times; import org.apache.hadoop.yarn.util.Times;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -57,8 +59,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -82,10 +82,9 @@ public class TestAMWebServicesJobs extends JerseyTest {
private static Configuration conf = new Configuration(); private static Configuration conf = new Configuration();
private static AppContext appContext; private static AppContext appContext;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockAppContext(0, 1, 2, 1); appContext = new MockAppContext(0, 1, 2, 1);
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
bind(AMWebServices.class); bind(AMWebServices.class);
@ -95,21 +94,19 @@ public class TestAMWebServicesJobs extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestAMWebServicesJobs() { public TestAMWebServicesJobs() {
@ -256,7 +253,7 @@ public class TestAMWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -283,7 +280,7 @@ public class TestAMWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -306,7 +303,7 @@ public class TestAMWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -329,7 +326,7 @@ public class TestAMWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_XML_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_XML_TYPE, response.getType());
String msg = response.getEntity(String.class); String msg = response.getEntity(String.class);
System.out.println(msg); System.out.println(msg);
@ -368,7 +365,7 @@ public class TestAMWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.mapreduce.v2.app.webapp; package org.apache.hadoop.mapreduce.v2.app.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
@ -41,6 +42,7 @@ import org.apache.hadoop.mapreduce.v2.app.job.Job;
import org.apache.hadoop.mapreduce.v2.app.job.Task; import org.apache.hadoop.mapreduce.v2.app.job.Task;
import org.apache.hadoop.mapreduce.v2.util.MRApps; import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -53,8 +55,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -77,7 +77,7 @@ public class TestAMWebServicesTasks extends JerseyTest {
private static Configuration conf = new Configuration(); private static Configuration conf = new Configuration();
private static AppContext appContext; private static AppContext appContext;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
@ -90,21 +90,19 @@ public class TestAMWebServicesTasks extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestAMWebServicesTasks() { public TestAMWebServicesTasks() {
@ -254,7 +252,7 @@ public class TestAMWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -348,7 +346,7 @@ public class TestAMWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -382,7 +380,7 @@ public class TestAMWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -414,7 +412,7 @@ public class TestAMWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -448,7 +446,7 @@ public class TestAMWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -482,7 +480,7 @@ public class TestAMWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.mapreduce.v2.hs.webapp; package org.apache.hadoop.mapreduce.v2.hs.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
@ -35,6 +36,7 @@ import org.apache.hadoop.mapreduce.v2.hs.JobHistoryServer;
import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext; import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext;
import org.apache.hadoop.util.VersionInfo; import org.apache.hadoop.util.VersionInfo;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebApp; import org.apache.hadoop.yarn.webapp.WebApp;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -47,8 +49,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -70,10 +70,9 @@ public class TestHsWebServices extends JerseyTest {
private static HistoryContext appContext; private static HistoryContext appContext;
private static HsWebApp webApp; private static HsWebApp webApp;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockHistoryContext(0, 1, 1, 1); appContext = new MockHistoryContext(0, 1, 1, 1);
JobHistory jobHistoryService = new JobHistory(); JobHistory jobHistoryService = new JobHistory();
HistoryContext historyContext = (HistoryContext) jobHistoryService; HistoryContext historyContext = (HistoryContext) jobHistoryService;
@ -89,20 +88,19 @@ public class TestHsWebServices extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestHsWebServices() { public TestHsWebServices() {
@ -212,7 +210,7 @@ public class TestHsWebServices extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -228,7 +226,7 @@ public class TestHsWebServices extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -244,8 +242,8 @@ public class TestHsWebServices extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.INTERNAL_SERVER_ERROR, assertResponseStatusCode(Status.INTERNAL_SERVER_ERROR,
response.getClientResponseStatus()); response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.mapreduce.v2.hs.webapp; package org.apache.hadoop.mapreduce.v2.hs.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
@ -46,6 +47,7 @@ import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext;
import org.apache.hadoop.mapreduce.v2.util.MRApps; import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.yarn.util.ConverterUtils; import org.apache.hadoop.yarn.util.ConverterUtils;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebApp; import org.apache.hadoop.yarn.webapp.WebApp;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -59,8 +61,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -85,10 +85,9 @@ public class TestHsWebServicesAttempts extends JerseyTest {
private static HistoryContext appContext; private static HistoryContext appContext;
private static HsWebApp webApp; private static HsWebApp webApp;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockHistoryContext(0, 1, 2, 1); appContext = new MockHistoryContext(0, 1, 2, 1);
webApp = mock(HsWebApp.class); webApp = mock(HsWebApp.class);
when(webApp.name()).thenReturn("hsmockwebapp"); when(webApp.name()).thenReturn("hsmockwebapp");
@ -103,29 +102,27 @@ public class TestHsWebServicesAttempts extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestHsWebServicesAttempts() { public TestHsWebServicesAttempts() {
super(new WebAppDescriptor.Builder( super(
"org.apache.hadoop.mapreduce.v2.hs.webapp") new WebAppDescriptor.Builder("org.apache.hadoop.mapreduce.v2.hs.webapp")
.contextListenerClass(GuiceServletConfig.class) .contextListenerClass(GuiceServletConfig.class)
.filterClass(com.google.inject.servlet.GuiceFilter.class) .filterClass(com.google.inject.servlet.GuiceFilter.class)
.contextPath("jersey-guice-filter").servletPath("/").build()); .contextPath("jersey-guice-filter").servletPath("/").build());
} }
@Test @Test
@ -397,7 +394,7 @@ public class TestHsWebServicesAttempts extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");

View File

@ -47,6 +47,7 @@ import org.apache.hadoop.mapreduce.v2.hs.HistoryContext;
import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext; import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext;
import org.apache.hadoop.mapreduce.v2.util.MRApps; import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebApp; import org.apache.hadoop.yarn.webapp.WebApp;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -61,8 +62,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
@ -85,7 +84,8 @@ public class TestHsWebServicesJobConf extends JerseyTest {
private static File testConfDir = new File("target", private static File testConfDir = new File("target",
TestHsWebServicesJobConf.class.getSimpleName() + "confDir"); TestHsWebServicesJobConf.class.getSimpleName() + "confDir");
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
@ -127,14 +127,11 @@ public class TestHsWebServicesJobConf extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); };
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@ -142,7 +139,8 @@ public class TestHsWebServicesJobConf extends JerseyTest {
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
testConfDir.mkdir(); testConfDir.mkdir();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
@AfterClass @AfterClass

View File

@ -20,6 +20,7 @@ package org.apache.hadoop.mapreduce.v2.hs.webapp;
import static org.apache.hadoop.yarn.util.StringHelper.join; import static org.apache.hadoop.yarn.util.StringHelper.join;
import static org.apache.hadoop.yarn.util.StringHelper.ujoin; import static org.apache.hadoop.yarn.util.StringHelper.ujoin;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
@ -44,6 +45,7 @@ import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext;
import org.apache.hadoop.mapreduce.v2.util.MRApps; import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.yarn.api.records.NodeId; import org.apache.hadoop.yarn.api.records.NodeId;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebApp; import org.apache.hadoop.yarn.webapp.WebApp;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -57,8 +59,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -82,10 +82,9 @@ public class TestHsWebServicesJobs extends JerseyTest {
private static MockHistoryContext appContext; private static MockHistoryContext appContext;
private static HsWebApp webApp; private static HsWebApp webApp;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockHistoryContext(0, 1, 2, 1, false); appContext = new MockHistoryContext(0, 1, 2, 1, false);
webApp = mock(HsWebApp.class); webApp = mock(HsWebApp.class);
when(webApp.name()).thenReturn("hsmockwebapp"); when(webApp.name()).thenReturn("hsmockwebapp");
@ -100,21 +99,19 @@ public class TestHsWebServicesJobs extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestHsWebServicesJobs() { public TestHsWebServicesJobs() {
@ -331,7 +328,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -359,7 +356,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -383,7 +380,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -407,7 +404,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_XML_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_XML_TYPE, response.getType());
String msg = response.getEntity(String.class); String msg = response.getEntity(String.class);
System.out.println(msg); System.out.println(msg);
@ -446,7 +443,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -527,7 +524,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
public void testJobCountersForKilledJob() throws Exception { public void testJobCountersForKilledJob() throws Exception {
WebResource r = resource(); WebResource r = resource();
appContext = new MockHistoryContext(0, 1, 1, 1, true); appContext = new MockHistoryContext(0, 1, 1, 1, true);
injector = Guice.createInjector(new ServletModule() { GuiceServletConfig.setInjector(Guice.createInjector(new ServletModule() {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
@ -544,7 +541,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }));
Map<JobId, Job> jobsMap = appContext.getAllJobs(); Map<JobId, Job> jobsMap = appContext.getAllJobs();
for (JobId id : jobsMap.keySet()) { for (JobId id : jobsMap.keySet()) {

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.mapreduce.v2.hs.webapp; package org.apache.hadoop.mapreduce.v2.hs.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
@ -39,6 +40,7 @@ import org.apache.hadoop.mapreduce.v2.hs.HistoryContext;
import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext; import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext;
import org.apache.hadoop.mapreduce.v2.util.MRApps; import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebApp; import org.apache.hadoop.yarn.webapp.WebApp;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -48,8 +50,6 @@ import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -70,10 +70,9 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
private static MockHistoryContext appContext; private static MockHistoryContext appContext;
private static HsWebApp webApp; private static HsWebApp webApp;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockHistoryContext(3, 2, 1); appContext = new MockHistoryContext(3, 2, 1);
webApp = mock(HsWebApp.class); webApp = mock(HsWebApp.class);
when(webApp.name()).thenReturn("hsmockwebapp"); when(webApp.name()).thenReturn("hsmockwebapp");
@ -88,21 +87,19 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestHsWebServicesJobsQuery() { public TestHsWebServicesJobsQuery() {
@ -136,7 +133,8 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("jobs is not null", JSONObject.NULL, json.get("jobs")); assertEquals("jobs is not empty",
new JSONObject().toString(), json.get("jobs").toString());
} }
@Test @Test
@ -173,7 +171,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
.path("mapreduce").path("jobs").queryParam("state", "InvalidState") .path("mapreduce").path("jobs").queryParam("state", "InvalidState")
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -202,7 +200,8 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("jobs is not null", JSONObject.NULL, json.get("jobs")); assertEquals("jobs is not empty",
new JSONObject().toString(), json.get("jobs").toString());
} }
@Test @Test
@ -248,7 +247,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
.path("mapreduce").path("jobs").queryParam("limit", "-1") .path("mapreduce").path("jobs").queryParam("limit", "-1")
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -287,7 +286,8 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("jobs is not null", JSONObject.NULL, json.get("jobs")); assertEquals("jobs is not empty",
new JSONObject().toString(), json.get("jobs").toString());
} }
@Test @Test
@ -319,7 +319,8 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("jobs is not null", JSONObject.NULL, json.get("jobs")); assertEquals("jobs is not empty",
new JSONObject().toString(), json.get("jobs").toString());
} }
@Test @Test
@ -360,7 +361,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
.queryParam("startedTimeBegin", String.valueOf(now)) .queryParam("startedTimeBegin", String.valueOf(now))
.queryParam("startedTimeEnd", String.valueOf(40000)) .queryParam("startedTimeEnd", String.valueOf(40000))
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -386,7 +387,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
ClientResponse response = r.path("ws").path("v1").path("history") ClientResponse response = r.path("ws").path("v1").path("history")
.path("mapreduce").path("jobs").queryParam("startedTimeBegin", "efsd") .path("mapreduce").path("jobs").queryParam("startedTimeBegin", "efsd")
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -412,7 +413,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
ClientResponse response = r.path("ws").path("v1").path("history") ClientResponse response = r.path("ws").path("v1").path("history")
.path("mapreduce").path("jobs").queryParam("startedTimeEnd", "efsd") .path("mapreduce").path("jobs").queryParam("startedTimeEnd", "efsd")
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -438,7 +439,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
.path("mapreduce").path("jobs") .path("mapreduce").path("jobs")
.queryParam("startedTimeBegin", String.valueOf(-1000)) .queryParam("startedTimeBegin", String.valueOf(-1000))
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -464,7 +465,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
.path("mapreduce").path("jobs") .path("mapreduce").path("jobs")
.queryParam("startedTimeEnd", String.valueOf(-1000)) .queryParam("startedTimeEnd", String.valueOf(-1000))
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -488,7 +489,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
.path("mapreduce").path("jobs") .path("mapreduce").path("jobs")
.queryParam("finishedTimeEnd", String.valueOf(-1000)) .queryParam("finishedTimeEnd", String.valueOf(-1000))
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -512,7 +513,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
.path("mapreduce").path("jobs") .path("mapreduce").path("jobs")
.queryParam("finishedTimeBegin", String.valueOf(-1000)) .queryParam("finishedTimeBegin", String.valueOf(-1000))
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -539,7 +540,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
.queryParam("finishedTimeBegin", String.valueOf(now)) .queryParam("finishedTimeBegin", String.valueOf(now))
.queryParam("finishedTimeEnd", String.valueOf(40000)) .queryParam("finishedTimeEnd", String.valueOf(40000))
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -565,7 +566,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
ClientResponse response = r.path("ws").path("v1").path("history") ClientResponse response = r.path("ws").path("v1").path("history")
.path("mapreduce").path("jobs").queryParam("finishedTimeBegin", "efsd") .path("mapreduce").path("jobs").queryParam("finishedTimeBegin", "efsd")
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -591,7 +592,7 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
ClientResponse response = r.path("ws").path("v1").path("history") ClientResponse response = r.path("ws").path("v1").path("history")
.path("mapreduce").path("jobs").queryParam("finishedTimeEnd", "efsd") .path("mapreduce").path("jobs").queryParam("finishedTimeEnd", "efsd")
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -639,7 +640,8 @@ public class TestHsWebServicesJobsQuery extends JerseyTest {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("jobs is not null", JSONObject.NULL, json.get("jobs")); assertEquals("jobs is not empty",
new JSONObject().toString(), json.get("jobs").toString());
} }
@Test @Test

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.mapreduce.v2.hs.webapp; package org.apache.hadoop.mapreduce.v2.hs.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
@ -44,6 +45,7 @@ import org.apache.hadoop.mapreduce.v2.hs.HistoryContext;
import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext; import org.apache.hadoop.mapreduce.v2.hs.MockHistoryContext;
import org.apache.hadoop.mapreduce.v2.util.MRApps; import org.apache.hadoop.mapreduce.v2.util.MRApps;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.WebApp; import org.apache.hadoop.yarn.webapp.WebApp;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -57,8 +59,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -82,10 +82,9 @@ public class TestHsWebServicesTasks extends JerseyTest {
private static MockHistoryContext appContext; private static MockHistoryContext appContext;
private static HsWebApp webApp; private static HsWebApp webApp;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
appContext = new MockHistoryContext(0, 1, 2, 1); appContext = new MockHistoryContext(0, 1, 2, 1);
webApp = mock(HsWebApp.class); webApp = mock(HsWebApp.class);
when(webApp.name()).thenReturn("hsmockwebapp"); when(webApp.name()).thenReturn("hsmockwebapp");
@ -100,20 +99,19 @@ public class TestHsWebServicesTasks extends JerseyTest {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestHsWebServicesTasks() { public TestHsWebServicesTasks() {
@ -266,7 +264,7 @@ public class TestHsWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -361,7 +359,7 @@ public class TestHsWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -395,7 +393,7 @@ public class TestHsWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -427,7 +425,7 @@ public class TestHsWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -461,7 +459,7 @@ public class TestHsWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -495,7 +493,7 @@ public class TestHsWebServicesTasks extends JerseyTest {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");

View File

@ -65,7 +65,7 @@
<avro.version>1.7.4</avro.version> <avro.version>1.7.4</avro.version>
<!-- jersey version --> <!-- jersey version -->
<jersey.version>1.9</jersey.version> <jersey.version>1.19</jersey.version>
<!-- jackson versions --> <!-- jackson versions -->
<jackson.version>1.9.13</jackson.version> <jackson.version>1.9.13</jackson.version>
@ -546,6 +546,11 @@
<artifactId>jersey-core</artifactId> <artifactId>jersey-core</artifactId>
<version>${jersey.version}</version> <version>${jersey.version}</version>
</dependency> </dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-servlet</artifactId>
<version>${jersey.version}</version>
</dependency>
<dependency> <dependency>
<groupId>com.sun.jersey</groupId> <groupId>com.sun.jersey</groupId>
<artifactId>jersey-json</artifactId> <artifactId>jersey-json</artifactId>
@ -946,7 +951,17 @@
<dependency> <dependency>
<groupId>org.glassfish.grizzly</groupId> <groupId>org.glassfish.grizzly</groupId>
<artifactId>grizzly-http-servlet</artifactId> <artifactId>grizzly-http-servlet</artifactId>
<version>2.1.2</version> <version>2.2.21</version>
</dependency>
<dependency>
<groupId>org.glassfish.grizzly</groupId>
<artifactId>grizzly-http</artifactId>
<version>2.2.21</version>
</dependency>
<dependency>
<groupId>org.glassfish.grizzly</groupId>
<artifactId>grizzly-http-server</artifactId>
<version>2.2.21</version>
</dependency> </dependency>
<dependency> <dependency>

View File

@ -342,7 +342,8 @@ public class LogsCLI extends Configured implements Tool {
webResource.path("ws").path("v1").path("node").path("containers") webResource.path("ws").path("v1").path("node").path("containers")
.path(containerIdStr).accept(MediaType.APPLICATION_XML) .path(containerIdStr).accept(MediaType.APPLICATION_XML)
.get(ClientResponse.class); .get(ClientResponse.class);
if (response.getClientResponseStatus().equals(ClientResponse.Status.OK)) { if (response.getStatusInfo().getStatusCode() ==
ClientResponse.Status.OK.getStatusCode()) {
try { try {
String xml = response.getEntity(String.class); String xml = response.getEntity(String.class);
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

View File

@ -42,12 +42,18 @@
<scope>provided</scope> <scope>provided</scope>
</dependency> </dependency>
<!-- 'mvn dependency:analyze' fails to detect use of this dependency --> <!-- 'mvn dependency:analyze' fails to detect use of this dependency -->
<dependency> <dependency>
<groupId>org.apache.hadoop</groupId> <groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-yarn-api</artifactId> <artifactId>hadoop-yarn-api</artifactId>
</dependency> </dependency>
<dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-auth</artifactId>
</dependency>
<dependency> <dependency>
<groupId>javax.xml.bind</groupId> <groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId> <artifactId>jaxb-api</artifactId>

View File

@ -126,7 +126,8 @@ public abstract class TimelineWriter implements Flushable {
throw (IOException)new InterruptedIOException().initCause(ie); throw (IOException)new InterruptedIOException().initCause(ie);
} }
if (resp == null || if (resp == null ||
resp.getClientResponseStatus() != ClientResponse.Status.OK) { resp.getStatusInfo().getStatusCode()
!= ClientResponse.Status.OK.getStatusCode()) {
String msg = String msg =
"Failed to get the response from the timeline server."; "Failed to get the response from the timeline server.";
LOG.error(msg); LOG.error(msg);

View File

@ -330,7 +330,7 @@ public class TestTimelineClient {
} }
doReturn(response).when(spyTimelineWriter) doReturn(response).when(spyTimelineWriter)
.doPostingObject(any(TimelineEntities.class), any(String.class)); .doPostingObject(any(TimelineEntities.class), any(String.class));
when(response.getClientResponseStatus()).thenReturn(status); when(response.getStatusInfo()).thenReturn(status);
TimelinePutResponse.TimelinePutError error = TimelinePutResponse.TimelinePutError error =
new TimelinePutResponse.TimelinePutError(); new TimelinePutResponse.TimelinePutError();
error.setEntityId("test entity id"); error.setEntityId("test entity id");
@ -356,7 +356,7 @@ public class TestTimelineClient {
} }
doReturn(response).when(spyTimelineWriter) doReturn(response).when(spyTimelineWriter)
.doPostingObject(any(TimelineDomain.class), any(String.class)); .doPostingObject(any(TimelineDomain.class), any(String.class));
when(response.getClientResponseStatus()).thenReturn(status); when(response.getStatusInfo()).thenReturn(status);
return response; return response;
} }

View File

@ -208,8 +208,8 @@ public class TestTimelineClientForATS1_5 {
new FileSystemTimelineWriter(conf, authUgi, client, resURI) { new FileSystemTimelineWriter(conf, authUgi, client, resURI) {
public ClientResponse doPostingObject(Object object, String path) { public ClientResponse doPostingObject(Object object, String path) {
ClientResponse response = mock(ClientResponse.class); ClientResponse response = mock(ClientResponse.class);
when(response.getClientResponseStatus()).thenReturn( when(response.getStatusInfo()).thenReturn(
ClientResponse.Status.OK); ClientResponse.Status.OK);
return response; return response;
} }
}; };

View File

@ -0,0 +1,43 @@
/**
* 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.hadoop.yarn.webapp;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
/**
* GuiceServletConfig is a wrapper class to have a static Injector instance
* instead of having the instance inside test classes. This allow us to use
* Jersey test framework after 1.13.
* Please check test cases to know how to use this class:
* e.g. TestRMWithCSRFFilter.java
*/
public class GuiceServletConfig extends GuiceServletContextListener {
private static Injector internalInjector = null;
@Override
protected Injector getInjector() {
return internalInjector;
}
public static Injector setInjector(Injector in) {
internalInjector = in;
return internalInjector;
}
}

View File

@ -18,10 +18,12 @@
package org.apache.hadoop.yarn.webapp; package org.apache.hadoop.yarn.webapp;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import javax.ws.rs.core.Response.StatusType;
import org.w3c.dom.Attr; import org.w3c.dom.Attr;
import org.w3c.dom.Element; import org.w3c.dom.Element;
@ -119,4 +121,13 @@ public class WebServicesTestUtils {
got.equals(expected)); got.equals(expected));
} }
public static void assertResponseStatusCode(StatusType expected,
StatusType actual) {
assertResponseStatusCode(null, expected, actual);
}
public static void assertResponseStatusCode(String errmsg,
StatusType expected, StatusType actual) {
assertEquals(errmsg, expected.getStatusCode(), actual.getStatusCode());
}
} }

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.applicationhistoryservice.webapp; package org.apache.hadoop.yarn.server.applicationhistoryservice.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
@ -67,6 +68,7 @@ import org.apache.hadoop.yarn.server.timeline.security.TimelineACLsManager;
import org.apache.hadoop.yarn.api.records.timeline.TimelineAbout; import org.apache.hadoop.yarn.api.records.timeline.TimelineAbout;
import org.apache.hadoop.yarn.util.timeline.TimelineUtils; import org.apache.hadoop.yarn.util.timeline.TimelineUtils;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.apache.hadoop.yarn.webapp.util.WebAppUtils; import org.apache.hadoop.yarn.webapp.util.WebAppUtils;
@ -75,15 +77,14 @@ import org.codehaus.jettison.json.JSONException;
import org.codehaus.jettison.json.JSONObject; import org.codehaus.jettison.json.JSONObject;
import org.junit.AfterClass; import org.junit.AfterClass;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before;
import org.junit.BeforeClass; import org.junit.BeforeClass;
import org.junit.Test; import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.junit.runners.Parameterized; import org.junit.runners.Parameterized;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.Singleton; import com.google.inject.Singleton;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -132,6 +133,8 @@ public class TestAHSWebServices extends JerseyTestBase {
historyClientService.start(); historyClientService.start();
ahsWebservice = new AHSWebServices(historyClientService, conf); ahsWebservice = new AHSWebServices(historyClientService, conf);
fs = FileSystem.get(conf); fs = FileSystem.get(conf);
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
@AfterClass @AfterClass
@ -148,8 +151,7 @@ public class TestAHSWebServices extends JerseyTestBase {
return Arrays.asList(new Object[][] { { 0 }, { 1 } }); return Arrays.asList(new Object[][] { { 0 }, { 1 } });
} }
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -159,7 +161,14 @@ public class TestAHSWebServices extends JerseyTestBase {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
filter("/*").through(TestSimpleAuthFilter.class); filter("/*").through(TestSimpleAuthFilter.class);
} }
}); }
@Before
public void setUp() throws Exception {
super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
}
@Singleton @Singleton
public static class TestSimpleAuthFilter extends AuthenticationFilter { public static class TestSimpleAuthFilter extends AuthenticationFilter {
@ -174,14 +183,6 @@ public class TestAHSWebServices extends JerseyTestBase {
} }
} }
public class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return injector;
}
}
private int round; private int round;
public TestAHSWebServices(int round) { public TestAHSWebServices(int round) {
@ -203,8 +204,8 @@ public class TestAHSWebServices extends JerseyTestBase {
.queryParam("user.name", USERS[round]) .queryParam("user.name", USERS[round])
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.get(ClientResponse.class); .get(ClientResponse.class);
assertEquals("404 not found expected", Status.NOT_FOUND, assertResponseStatusCode("404 not found expected",
response.getClientResponseStatus()); Status.NOT_FOUND, response.getStatusInfo());
} }
@Test @Test
@ -221,11 +222,11 @@ public class TestAHSWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.get(ClientResponse.class); .get(ClientResponse.class);
if (round == 1) { if (round == 1) {
assertEquals(Status.FORBIDDEN, response.getClientResponseStatus()); assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
return; return;
} }
assertEquals("404 not found expected", Status.NOT_FOUND, assertResponseStatusCode("404 not found expected",
response.getClientResponseStatus()); Status.NOT_FOUND, response.getStatusInfo());
} }
@Test @Test
@ -245,12 +246,11 @@ public class TestAHSWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.get(ClientResponse.class); .get(ClientResponse.class);
if (round == 1) { if (round == 1) {
assertEquals( assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
Status.FORBIDDEN, response.getClientResponseStatus());
return; return;
} }
assertEquals("404 not found expected", Status.NOT_FOUND, assertResponseStatusCode("404 not found expected",
response.getClientResponseStatus()); Status.NOT_FOUND, response.getStatusInfo());
} }
@Test @Test
@ -265,7 +265,7 @@ public class TestAHSWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
@ -282,7 +282,7 @@ public class TestAHSWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -300,8 +300,8 @@ public class TestAHSWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.INTERNAL_SERVER_ERROR, assertResponseStatusCode(Status.INTERNAL_SERVER_ERROR,
response.getClientResponseStatus()); response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -388,8 +388,7 @@ public class TestAHSWebServices extends JerseyTestBase {
.queryParam("user.name", USERS[round]) .queryParam("user.name", USERS[round])
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
if (round == 1) { if (round == 1) {
assertEquals( assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
Status.FORBIDDEN, response.getClientResponseStatus());
return; return;
} }
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
@ -415,8 +414,7 @@ public class TestAHSWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.get(ClientResponse.class); .get(ClientResponse.class);
if (round == 1) { if (round == 1) {
assertEquals( assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
Status.FORBIDDEN, response.getClientResponseStatus());
return; return;
} }
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
@ -445,8 +443,7 @@ public class TestAHSWebServices extends JerseyTestBase {
.queryParam("user.name", USERS[round]) .queryParam("user.name", USERS[round])
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
if (round == 1) { if (round == 1) {
assertEquals( assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
Status.FORBIDDEN, response.getClientResponseStatus());
return; return;
} }
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
@ -474,8 +471,7 @@ public class TestAHSWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.get(ClientResponse.class); .get(ClientResponse.class);
if (round == 1) { if (round == 1) {
assertEquals( assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
Status.FORBIDDEN, response.getClientResponseStatus());
return; return;
} }
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.timeline.webapp; package org.apache.hadoop.yarn.server.timeline.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.mockito.Matchers.any; import static org.mockito.Matchers.any;
import static org.mockito.Mockito.doNothing; import static org.mockito.Mockito.doNothing;
@ -61,14 +62,14 @@ import org.apache.hadoop.yarn.server.timeline.security.TimelineAuthenticationFil
import org.apache.hadoop.yarn.api.records.timeline.TimelineAbout; import org.apache.hadoop.yarn.api.records.timeline.TimelineAbout;
import org.apache.hadoop.yarn.util.timeline.TimelineUtils; import org.apache.hadoop.yarn.util.timeline.TimelineUtils;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.YarnJacksonJaxbJsonProvider; import org.apache.hadoop.yarn.webapp.YarnJacksonJaxbJsonProvider;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
@ -81,10 +82,9 @@ public class TestTimelineWebServices extends JerseyTestBase {
private static TimelineStore store; private static TimelineStore store;
private static TimelineACLsManager timelineACLsManager; private static TimelineACLsManager timelineACLsManager;
private static AdminACLsManager adminACLsManager; private static AdminACLsManager adminACLsManager;
private long beforeTime; private static long beforeTime;
private Injector injector = Guice.createInjector(new ServletModule() {
private static class WebServletModule extends ServletModule {
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
@Override @Override
protected void configureServlets() { protected void configureServlets() {
@ -129,7 +129,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
when(filterConfig.getInitParameterNames()).thenReturn(names); when(filterConfig.getInitParameterNames()).thenReturn(names);
when(filterConfig.getInitParameter( when(filterConfig.getInitParameter(
DelegationTokenAuthenticationHandler.TOKEN_KIND)).thenReturn( DelegationTokenAuthenticationHandler.TOKEN_KIND)).thenReturn(
TimelineDelegationTokenIdentifier.KIND_NAME.toString()); TimelineDelegationTokenIdentifier.KIND_NAME.toString());
try { try {
taFilter.init(filterConfig); taFilter.init(filterConfig);
} catch (ServletException e) { } catch (ServletException e) {
@ -146,18 +146,21 @@ public class TestTimelineWebServices extends JerseyTestBase {
} }
filter("/*").through(taFilter); filter("/*").through(taFilter);
} }
});
public class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return injector;
}
} }
private TimelineStore mockTimelineStore() static {
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
}
@Before
public void setUp() throws Exception {
super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
}
private static TimelineStore mockTimelineStore()
throws Exception { throws Exception {
beforeTime = System.currentTimeMillis() - 1; beforeTime = System.currentTimeMillis() - 1;
TestMemoryTimelineStore store = TestMemoryTimelineStore store =
@ -477,8 +480,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
.type(MediaType.APPLICATION_JSON) .type(MediaType.APPLICATION_JSON)
.post(ClientResponse.class, entities); .post(ClientResponse.class, entities);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
assertEquals(ClientResponse.Status.FORBIDDEN, assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
response.getClientResponseStatus());
response = r.path("ws").path("v1").path("timeline") response = r.path("ws").path("v1").path("timeline")
.queryParam("user.name", "tester") .queryParam("user.name", "tester")
@ -519,8 +521,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
.queryParam("user.name", "tester").accept(MediaType.APPLICATION_JSON) .queryParam("user.name", "tester").accept(MediaType.APPLICATION_JSON)
.type(MediaType.APPLICATION_JSON).post(ClientResponse.class, entities); .type(MediaType.APPLICATION_JSON).post(ClientResponse.class, entities);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
assertEquals(ClientResponse.Status.BAD_REQUEST, assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
response.getClientResponseStatus());
} }
@Test @Test
@ -703,8 +704,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.get(ClientResponse.class); .get(ClientResponse.class);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
assertEquals(ClientResponse.Status.NOT_FOUND, assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
response.getClientResponseStatus());
} finally { } finally {
timelineACLsManager.setAdminACLsManager(oldAdminACLsManager); timelineACLsManager.setAdminACLsManager(oldAdminACLsManager);
} }
@ -869,8 +869,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.get(ClientResponse.class); .get(ClientResponse.class);
Assert.assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); Assert.assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
Assert.assertEquals(ClientResponse.Status.NOT_FOUND, assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
response.getClientResponseStatus());
} finally { } finally {
timelineACLsManager.setAdminACLsManager(oldAdminACLsManager); timelineACLsManager.setAdminACLsManager(oldAdminACLsManager);
} }
@ -938,8 +937,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
.type(MediaType.APPLICATION_JSON) .type(MediaType.APPLICATION_JSON)
.put(ClientResponse.class, domain); .put(ClientResponse.class, domain);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
assertEquals(ClientResponse.Status.FORBIDDEN, assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
response.getClientResponseStatus());
response = r.path("ws").path("v1") response = r.path("ws").path("v1")
.path("timeline").path("domain") .path("timeline").path("domain")
@ -947,8 +945,8 @@ public class TestTimelineWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.type(MediaType.APPLICATION_JSON) .type(MediaType.APPLICATION_JSON)
.put(ClientResponse.class, domain); .put(ClientResponse.class, domain);
assertEquals(Status.OK.getStatusCode(), response.getStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
// Verify the domain exists // Verify the domain exists
response = r.path("ws").path("v1").path("timeline") response = r.path("ws").path("v1").path("timeline")
.path("domain").path("test_domain_id") .path("domain").path("test_domain_id")
@ -969,7 +967,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.type(MediaType.APPLICATION_JSON) .type(MediaType.APPLICATION_JSON)
.put(ClientResponse.class, domain); .put(ClientResponse.class, domain);
assertEquals(Status.OK.getStatusCode(), response.getStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
// Verify the domain is updated // Verify the domain is updated
response = r.path("ws").path("v1").path("timeline") response = r.path("ws").path("v1").path("timeline")
@ -997,7 +995,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.type(MediaType.APPLICATION_JSON) .type(MediaType.APPLICATION_JSON)
.put(ClientResponse.class, domain); .put(ClientResponse.class, domain);
assertEquals(Status.OK.getStatusCode(), response.getStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
// Update the domain by another user // Update the domain by another user
response = r.path("ws").path("v1") response = r.path("ws").path("v1")
@ -1006,7 +1004,7 @@ public class TestTimelineWebServices extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON) .accept(MediaType.APPLICATION_JSON)
.type(MediaType.APPLICATION_JSON) .type(MediaType.APPLICATION_JSON)
.put(ClientResponse.class, domain); .put(ClientResponse.class, domain);
assertEquals(Status.FORBIDDEN.getStatusCode(), response.getStatus()); assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
} finally { } finally {
timelineACLsManager.setAdminACLsManager(oldAdminACLsManager); timelineACLsManager.setAdminACLsManager(oldAdminACLsManager);
} }

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.nodemanager.webapp; package org.apache.hadoop.yarn.server.nodemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
@ -30,6 +31,7 @@ import javax.ws.rs.core.MediaType;
import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.junit.Assert; import org.junit.Assert;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileUtil; import org.apache.hadoop.fs.FileUtil;
@ -69,8 +71,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -95,7 +95,7 @@ public class TestNMWebServices extends JerseyTestBase {
private static File testLogDir = new File("target", private static File testLogDir = new File("target",
TestNMWebServices.class.getSimpleName() + "LogDir"); TestNMWebServices.class.getSimpleName() + "LogDir");
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
@ -148,14 +148,11 @@ public class TestNMWebServices extends JerseyTestBase {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); };
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@ -164,6 +161,8 @@ public class TestNMWebServices extends JerseyTestBase {
super.setUp(); super.setUp();
testRootDir.mkdirs(); testRootDir.mkdirs();
testLogDir.mkdir(); testLogDir.mkdir();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
@AfterClass @AfterClass
@ -190,7 +189,7 @@ public class TestNMWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -206,8 +205,8 @@ public class TestNMWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.INTERNAL_SERVER_ERROR, assertResponseStatusCode(Status.INTERNAL_SERVER_ERROR,
response.getClientResponseStatus()); response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -222,7 +221,7 @@ public class TestNMWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -418,7 +417,7 @@ public class TestNMWebServices extends JerseyTestBase {
response = r.path("ws").path("v1").path("node") response = r.path("ws").path("v1").path("node")
.path("containerlogs").path(containerIdStr).path("uhhh") .path("containerlogs").path(containerIdStr).path("uhhh")
.accept(MediaType.TEXT_PLAIN).get(ClientResponse.class); .accept(MediaType.TEXT_PLAIN).get(ClientResponse.class);
Assert.assertEquals(Status.NOT_FOUND.getStatusCode(), response.getStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
responseText = response.getEntity(String.class); responseText = response.getEntity(String.class);
assertTrue(responseText.contains("Cannot find this log on the local disk.")); assertTrue(responseText.contains("Cannot find this log on the local disk."));

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.nodemanager.webapp; package org.apache.hadoop.yarn.server.nodemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
@ -33,7 +34,6 @@ import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileUtil; import org.apache.hadoop.fs.FileUtil;
import org.apache.hadoop.util.NodeHealthScriptRunner;
import org.apache.hadoop.yarn.api.records.ApplicationAttemptId; import org.apache.hadoop.yarn.api.records.ApplicationAttemptId;
import org.apache.hadoop.yarn.api.records.NodeId; import org.apache.hadoop.yarn.api.records.NodeId;
import org.apache.hadoop.yarn.conf.YarnConfiguration; import org.apache.hadoop.yarn.conf.YarnConfiguration;
@ -51,6 +51,7 @@ import org.apache.hadoop.yarn.server.nodemanager.webapp.WebServer.NMWebApp;
import org.apache.hadoop.yarn.server.security.ApplicationACLsManager; import org.apache.hadoop.yarn.server.security.ApplicationACLsManager;
import org.apache.hadoop.yarn.server.utils.BuilderUtils; import org.apache.hadoop.yarn.server.utils.BuilderUtils;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebApp; import org.apache.hadoop.yarn.webapp.WebApp;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
@ -67,8 +68,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -91,8 +90,7 @@ public class TestNMWebServicesApps extends JerseyTestBase {
private static File testLogDir = new File("target", private static File testLogDir = new File("target",
TestNMWebServicesApps.class.getSimpleName() + "LogDir"); TestNMWebServicesApps.class.getSimpleName() + "LogDir");
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
conf.set(YarnConfiguration.NM_LOCAL_DIRS, testRootDir.getAbsolutePath()); conf.set(YarnConfiguration.NM_LOCAL_DIRS, testRootDir.getAbsolutePath());
@ -148,20 +146,19 @@ public class TestNMWebServicesApps extends JerseyTestBase {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
testRootDir.mkdirs(); testRootDir.mkdirs();
testLogDir.mkdir(); testLogDir.mkdir();
} }
@ -187,7 +184,8 @@ public class TestNMWebServicesApps extends JerseyTestBase {
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("apps isn't NULL", JSONObject.NULL, json.get("apps")); assertEquals("apps isn't empty",
new JSONObject().toString(), json.get("apps").toString());
} }
private HashMap<String, String> addAppContainers(Application app) private HashMap<String, String> addAppContainers(Application app)
@ -297,7 +295,8 @@ public class TestNMWebServicesApps extends JerseyTestBase {
.get(ClientResponse.class); .get(ClientResponse.class);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("apps is not null", JSONObject.NULL, json.get("apps")); assertEquals("apps is not empty",
new JSONObject().toString(), json.get("apps").toString());
} }
@Test @Test
@ -317,7 +316,7 @@ public class TestNMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -379,7 +378,8 @@ public class TestNMWebServicesApps extends JerseyTestBase {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("apps is not null", JSONObject.NULL, json.get("apps")); assertEquals("apps is not empty",
new JSONObject().toString(), json.get("apps").toString());
} }
@Test @Test
@ -400,7 +400,7 @@ public class TestNMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -430,7 +430,7 @@ public class TestNMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -461,7 +461,7 @@ public class TestNMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_XML_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_XML_TYPE, response.getType());
String msg = response.getEntity(String.class); String msg = response.getEntity(String.class);
@ -556,7 +556,7 @@ public class TestNMWebServicesApps extends JerseyTestBase {
fail("should have thrown exception on invalid user query"); fail("should have thrown exception on invalid user query");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -593,7 +593,7 @@ public class TestNMWebServicesApps extends JerseyTestBase {
fail("should have thrown exception on invalid user query"); fail("should have thrown exception on invalid user query");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.nodemanager.webapp; package org.apache.hadoop.yarn.server.nodemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.apache.hadoop.yarn.util.StringHelper.ujoin; import static org.apache.hadoop.yarn.util.StringHelper.ujoin;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertFalse;
@ -38,7 +39,6 @@ import javax.xml.parsers.DocumentBuilderFactory;
import com.sun.jersey.api.client.filter.LoggingFilter; import com.sun.jersey.api.client.filter.LoggingFilter;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileUtil; import org.apache.hadoop.fs.FileUtil;
import org.apache.hadoop.util.NodeHealthScriptRunner;
import org.apache.hadoop.yarn.api.records.ApplicationAttemptId; import org.apache.hadoop.yarn.api.records.ApplicationAttemptId;
import org.apache.hadoop.yarn.api.records.ContainerId; import org.apache.hadoop.yarn.api.records.ContainerId;
import org.apache.hadoop.yarn.api.records.NodeId; import org.apache.hadoop.yarn.api.records.NodeId;
@ -58,6 +58,7 @@ import org.apache.hadoop.yarn.server.security.ApplicationACLsManager;
import org.apache.hadoop.yarn.server.utils.BuilderUtils; import org.apache.hadoop.yarn.server.utils.BuilderUtils;
import org.apache.hadoop.yarn.util.ConverterUtils; import org.apache.hadoop.yarn.util.ConverterUtils;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebApp; import org.apache.hadoop.yarn.webapp.WebApp;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
@ -73,8 +74,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -97,7 +96,7 @@ public class TestNMWebServicesContainers extends JerseyTestBase {
private static File testLogDir = new File("target", private static File testLogDir = new File("target",
TestNMWebServicesContainers.class.getSimpleName() + "LogDir"); TestNMWebServicesContainers.class.getSimpleName() + "LogDir");
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
resourceView = new ResourceView() { resourceView = new ResourceView() {
@ -158,20 +157,19 @@ public class TestNMWebServicesContainers extends JerseyTestBase {
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
testRootDir.mkdirs(); testRootDir.mkdirs();
testLogDir.mkdir(); testLogDir.mkdir();
} }
@ -198,7 +196,8 @@ public class TestNMWebServicesContainers extends JerseyTestBase {
.get(ClientResponse.class); .get(ClientResponse.class);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("apps isn't NULL", JSONObject.NULL, json.get("containers")); assertEquals("apps isn't empty",
new JSONObject().toString(), json.get("containers").toString());
} }
private HashMap<String, String> addAppContainers(Application app) private HashMap<String, String> addAppContainers(Application app)
@ -337,7 +336,7 @@ public class TestNMWebServicesContainers extends JerseyTestBase {
fail("should have thrown exception on invalid user query"); fail("should have thrown exception on invalid user query");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -371,7 +370,7 @@ public class TestNMWebServicesContainers extends JerseyTestBase {
fail("should have thrown exception on invalid user query"); fail("should have thrown exception on invalid user query");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -405,7 +404,7 @@ public class TestNMWebServicesContainers extends JerseyTestBase {
fail("should have thrown exception on invalid user query"); fail("should have thrown exception on invalid user query");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.resourcemanager.webapp; package org.apache.hadoop.yarn.server.resourcemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
@ -41,9 +42,7 @@ import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.commons.io.FileUtils; import org.apache.commons.io.FileUtils;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.io.TwoDArrayWritable;
import org.apache.hadoop.service.Service.STATE; import org.apache.hadoop.service.Service.STATE;
import org.apache.hadoop.test.GenericTestUtils.SleepAnswer;
import org.apache.hadoop.util.VersionInfo; import org.apache.hadoop.util.VersionInfo;
import org.apache.hadoop.yarn.api.protocolrecords.GetApplicationsRequest; import org.apache.hadoop.yarn.api.protocolrecords.GetApplicationsRequest;
import org.apache.hadoop.yarn.api.protocolrecords.GetApplicationsResponse; import org.apache.hadoop.yarn.api.protocolrecords.GetApplicationsResponse;
@ -68,6 +67,7 @@ import org.apache.hadoop.yarn.util.AdHocLogDumper;
import org.apache.hadoop.yarn.util.YarnVersionInfo; import org.apache.hadoop.yarn.util.YarnVersionInfo;
import org.apache.hadoop.yarn.webapp.ForbiddenException; import org.apache.hadoop.yarn.webapp.ForbiddenException;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -81,8 +81,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -95,7 +93,7 @@ public class TestRMWebServices extends JerseyTestBase {
private static MockRM rm; private static MockRM rm;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -108,20 +106,19 @@ public class TestRMWebServices extends JerseyTestBase {
bind(ResourceManager.class).toInstance(rm); bind(ResourceManager.class).toInstance(rm);
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestRMWebServices() { public TestRMWebServices() {
@ -162,7 +159,7 @@ public class TestRMWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
@ -178,7 +175,7 @@ public class TestRMWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }
@ -194,8 +191,8 @@ public class TestRMWebServices extends JerseyTestBase {
fail("should have thrown exception on invalid uri"); fail("should have thrown exception on invalid uri");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.INTERNAL_SERVER_ERROR, assertResponseStatusCode(Status.INTERNAL_SERVER_ERROR,
response.getClientResponseStatus()); response.getStatusInfo());
WebServicesTestUtils.checkStringMatch( WebServicesTestUtils.checkStringMatch(
"error string exists and shouldn't", "", responseStr); "error string exists and shouldn't", "", responseStr);
} }

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.resourcemanager.webapp; package org.apache.hadoop.yarn.server.resourcemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
@ -46,6 +47,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.rmapp.attempt.RMAppAttemptS
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fifo.FifoScheduler; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fifo.FifoScheduler;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -59,8 +61,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -76,7 +76,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
private static final int CONTAINER_MB = 1024; private static final int CONTAINER_MB = 1024;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -91,20 +91,19 @@ public class TestRMWebServicesApps extends JerseyTestBase {
bind(ResourceManager.class).toInstance(rm); bind(ResourceManager.class).toInstance(rm);
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestRMWebServicesApps() { public TestRMWebServicesApps() {
@ -350,7 +349,8 @@ public class TestRMWebServicesApps extends JerseyTestBase {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("apps is not null", JSONObject.NULL, json.get("apps")); assertEquals("apps is not empty",
new JSONObject().toString(), json.get("apps").toString());
rm.stop(); rm.stop();
} }
@ -369,7 +369,8 @@ public class TestRMWebServicesApps extends JerseyTestBase {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("apps is not null", JSONObject.NULL, json.get("apps")); assertEquals("apps is not empty",
new JSONObject().toString(), json.get("apps").toString());
rm.stop(); rm.stop();
} }
@ -388,7 +389,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
fail("should have thrown exception on invalid state query"); fail("should have thrown exception on invalid state query");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -425,7 +426,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
fail("should have thrown exception on invalid state query"); fail("should have thrown exception on invalid state query");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -484,7 +485,8 @@ public class TestRMWebServicesApps extends JerseyTestBase {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("apps is not null", JSONObject.NULL, json.get("apps")); assertEquals("apps is not null",
new JSONObject().toString(), json.get("apps").toString());
rm.stop(); rm.stop();
} }
@ -503,7 +505,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
fail("should have thrown exception on invalid state query"); fail("should have thrown exception on invalid state query");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -660,7 +662,8 @@ public class TestRMWebServicesApps extends JerseyTestBase {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("apps is not null", JSONObject.NULL, json.get("apps")); assertEquals("apps is not empty",
new JSONObject().toString(), json.get("apps").toString());
rm.stop(); rm.stop();
} }
@ -1070,7 +1073,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
.path("appstatistics") .path("appstatistics")
.queryParam("applicationTypes", "MAPREDUCE,OTHER") .queryParam("applicationTypes", "MAPREDUCE,OTHER")
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
json = response.getEntity(JSONObject.class); json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
@ -1117,7 +1120,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
response = r.path("ws").path("v1").path("cluster") response = r.path("ws").path("v1").path("cluster")
.path("appstatistics").queryParam("states", "wrong_state") .path("appstatistics").queryParam("states", "wrong_state")
.accept(MediaType.APPLICATION_JSON).get(ClientResponse.class); .accept(MediaType.APPLICATION_JSON).get(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
json = response.getEntity(JSONObject.class); json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
@ -1185,7 +1188,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -1223,7 +1226,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
@ -1515,7 +1518,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -1554,7 +1557,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -1592,7 +1595,7 @@ public class TestRMWebServicesApps extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.resourcemanager.webapp; package org.apache.hadoop.yarn.server.resourcemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assume.assumeTrue; import static org.junit.Assume.assumeTrue;
@ -87,6 +88,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.LocalResourceInf
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.LogAggregationContextInfo; import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.LogAggregationContextInfo;
import org.apache.hadoop.yarn.util.ConverterUtils; import org.apache.hadoop.yarn.util.ConverterUtils;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -107,7 +109,6 @@ import org.xml.sax.SAXException;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector; import com.google.inject.Injector;
import com.google.inject.Singleton; import com.google.inject.Singleton;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.Client; import com.sun.jersey.api.client.Client;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
@ -126,7 +127,6 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
private static final int CONTAINER_MB = 1024; private static final int CONTAINER_MB = 1024;
private static Injector injector;
private String webserviceUserName = "testuser"; private String webserviceUserName = "testuser";
private boolean setAuthFilter = false; private boolean setAuthFilter = false;
@ -136,14 +136,6 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
private static final String FS_ALLOC_FILE = new File(TEST_DIR, private static final String FS_ALLOC_FILE = new File(TEST_DIR,
"test-fs-queues.xml").getAbsolutePath(); "test-fs-queues.xml").getAbsolutePath();
public static class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return injector;
}
}
/* /*
* Helper class to allow testing of RM web services which require * Helper class to allow testing of RM web services which require
* authorization Add this class as a filter in the Guice injector for the * authorization Add this class as a filter in the Guice injector for the
@ -298,19 +290,19 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
case 0: case 0:
default: default:
// No Auth Capacity Scheduler // No Auth Capacity Scheduler
injector = getNoAuthInjectorCap(); GuiceServletConfig.setInjector(getNoAuthInjectorCap());
break; break;
case 1: case 1:
// Simple Auth Capacity Scheduler // Simple Auth Capacity Scheduler
injector = getSimpleAuthInjectorCap(); GuiceServletConfig.setInjector(getSimpleAuthInjectorCap());
break; break;
case 2: case 2:
// No Auth Fair Scheduler // No Auth Fair Scheduler
injector = getNoAuthInjectorFair(); GuiceServletConfig.setInjector(getNoAuthInjectorFair());
break; break;
case 3: case 3:
// Simple Auth Fair Scheduler // Simple Auth Fair Scheduler
injector = getSimpleAuthInjectorFair(); GuiceServletConfig.setInjector(getSimpleAuthInjectorFair());
break; break;
} }
} }
@ -349,7 +341,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
this this
.constructWebResource("apps", app.getApplicationId().toString(), .constructWebResource("apps", app.getApplicationId().toString(),
"state").accept(mediaType).get(ClientResponse.class); "state").accept(mediaType).get(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
if (mediaType.equals(MediaType.APPLICATION_JSON)) { if (mediaType.equals(MediaType.APPLICATION_JSON)) {
verifyAppStateJson(response, RMAppState.ACCEPTED); verifyAppStateJson(response, RMAppState.ACCEPTED);
} else if (mediaType.equals(MediaType.APPLICATION_XML)) { } else if (mediaType.equals(MediaType.APPLICATION_XML)) {
@ -388,10 +380,11 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.put(ClientResponse.class); .put(ClientResponse.class);
if (!isAuthenticationEnabled()) { if (!isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED,
response.getStatusInfo());
continue; continue;
} }
assertEquals(Status.ACCEPTED, response.getClientResponseStatus()); assertResponseStatusCode(Status.ACCEPTED, response.getStatusInfo());
if (mediaType.equals(MediaType.APPLICATION_JSON)) { if (mediaType.equals(MediaType.APPLICATION_JSON)) {
verifyAppStateJson(response, RMAppState.FINAL_SAVING, verifyAppStateJson(response, RMAppState.FINAL_SAVING,
RMAppState.KILLED, RMAppState.KILLING, RMAppState.ACCEPTED); RMAppState.KILLED, RMAppState.KILLING, RMAppState.ACCEPTED);
@ -408,7 +401,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
tmp = tmp.queryParam("user.name", webserviceUserName); tmp = tmp.queryParam("user.name", webserviceUserName);
} }
response = tmp.get(ClientResponse.class); response = tmp.get(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
assertTrue(locationHeaderValue.endsWith("/ws/v1/cluster/apps/" assertTrue(locationHeaderValue.endsWith("/ws/v1/cluster/apps/"
+ app.getApplicationId().toString() + "/state")); + app.getApplicationId().toString() + "/state"));
@ -419,9 +412,13 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.constructWebResource("apps", .constructWebResource("apps",
app.getApplicationId().toString(), "state").accept(mediaType) app.getApplicationId().toString(), "state").accept(mediaType)
.entity(entity, contentType).put(ClientResponse.class); .entity(entity, contentType).put(ClientResponse.class);
assertTrue((response.getClientResponseStatus() == Status.ACCEPTED) assertTrue(
|| (response.getClientResponseStatus() == Status.OK)); (response.getStatusInfo().getStatusCode()
if (response.getClientResponseStatus() == Status.OK) { == Status.ACCEPTED.getStatusCode())
|| (response.getStatusInfo().getStatusCode()
== Status.OK.getStatusCode()));
if (response.getStatusInfo().getStatusCode()
== Status.OK.getStatusCode()) {
assertEquals(RMAppState.KILLED, app.getState()); assertEquals(RMAppState.KILLED, app.getState());
if (mediaType.equals(MediaType.APPLICATION_JSON)) { if (mediaType.equals(MediaType.APPLICATION_JSON)) {
verifyAppStateJson(response, RMAppState.KILLED); verifyAppStateJson(response, RMAppState.KILLED);
@ -470,11 +467,12 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.put(ClientResponse.class); .put(ClientResponse.class);
if (!isAuthenticationEnabled()) { if (!isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, assertResponseStatusCode(Status.UNAUTHORIZED,
response.getClientResponseStatus()); response.getStatusInfo());
continue; continue;
} }
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST,
response.getStatusInfo());
} }
} }
} }
@ -588,13 +586,16 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.accept(MediaType.APPLICATION_XML) .accept(MediaType.APPLICATION_XML)
.entity(info, MediaType.APPLICATION_XML).put(ClientResponse.class); .entity(info, MediaType.APPLICATION_XML).put(ClientResponse.class);
if (!isAuthenticationEnabled()) { if (!isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED,
response.getStatusInfo());
continue; continue;
} }
if (i == 0) { if (i == 0) {
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND,
response.getStatusInfo());
} else { } else {
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST,
response.getStatusInfo());
} }
} }
rm.stop(); rm.stop();
@ -641,9 +642,11 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
public void validateResponseStatus(ClientResponse response, public void validateResponseStatus(ClientResponse response,
Status expectedUnauthorizedMode, Status expectedAuthorizedMode) { Status expectedUnauthorizedMode, Status expectedAuthorizedMode) {
if (!isAuthenticationEnabled()) { if (!isAuthenticationEnabled()) {
assertEquals(expectedUnauthorizedMode, response.getClientResponseStatus()); assertResponseStatusCode(expectedUnauthorizedMode,
response.getStatusInfo());
} else { } else {
assertEquals(expectedAuthorizedMode, response.getClientResponseStatus()); assertResponseStatusCode(expectedAuthorizedMode,
response.getStatusInfo());
} }
} }
@ -845,10 +848,10 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.entity(appInfo, contentMedia).post(ClientResponse.class); .entity(appInfo, contentMedia).post(ClientResponse.class);
if (!this.isAuthenticationEnabled()) { if (!this.isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED, response.getStatusInfo());
return; return;
} }
assertEquals(Status.ACCEPTED, response.getClientResponseStatus()); assertResponseStatusCode(Status.ACCEPTED, response.getStatusInfo());
assertTrue(!response.getHeaders().getFirst(HttpHeaders.LOCATION).isEmpty()); assertTrue(!response.getHeaders().getFirst(HttpHeaders.LOCATION).isEmpty());
String locURL = response.getHeaders().getFirst(HttpHeaders.LOCATION); String locURL = response.getHeaders().getFirst(HttpHeaders.LOCATION);
assertTrue(locURL.contains("/apps/application")); assertTrue(locURL.contains("/apps/application"));
@ -857,7 +860,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
WebResource res = resource().uri(new URI(locURL)); WebResource res = resource().uri(new URI(locURL));
res = res.queryParam("user.name", webserviceUserName); res = res.queryParam("user.name", webserviceUserName);
response = res.get(ClientResponse.class); response = res.get(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
RMApp app = RMApp app =
rm.getRMContext().getRMApps() rm.getRMContext().getRMApps()
@ -916,7 +919,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
response = response =
this.constructWebResource("apps", appId).accept(acceptMedia) this.constructWebResource("apps", appId).accept(acceptMedia)
.get(ClientResponse.class); .get(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
} }
public void testAppSubmitErrors(String acceptMedia, String contentMedia) public void testAppSubmitErrors(String acceptMedia, String contentMedia)
@ -1004,7 +1007,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
ClientResponse response = ClientResponse response =
this.constructWebResource(urlPath).accept(MediaType.APPLICATION_XML) this.constructWebResource(urlPath).accept(MediaType.APPLICATION_XML)
.entity(body, MediaType.APPLICATION_XML).post(ClientResponse.class); .entity(body, MediaType.APPLICATION_XML).post(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
body = "{\"a\" : \"b\"}"; body = "{\"a\" : \"b\"}";
response = response =
this.constructWebResource(urlPath).accept(MediaType.APPLICATION_XML) this.constructWebResource(urlPath).accept(MediaType.APPLICATION_XML)
@ -1029,7 +1032,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
this this
.constructWebResource("apps", app.getApplicationId().toString(), .constructWebResource("apps", app.getApplicationId().toString(),
"queue").accept(contentType).get(ClientResponse.class); "queue").accept(contentType).get(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
String expectedQueue = "default"; String expectedQueue = "default";
if(!isCapacityScheduler) { if(!isCapacityScheduler) {
expectedQueue = "root." + webserviceUserName; expectedQueue = "root." + webserviceUserName;
@ -1094,10 +1097,11 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.put(ClientResponse.class); .put(ClientResponse.class);
if (!isAuthenticationEnabled()) { if (!isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED,
response.getStatusInfo());
continue; continue;
} }
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
if (mediaType.equals(MediaType.APPLICATION_JSON)) { if (mediaType.equals(MediaType.APPLICATION_JSON)) {
verifyAppPriorityJson(response, modifiedPriority); verifyAppPriorityJson(response, modifiedPriority);
} else { } else {
@ -1108,7 +1112,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.constructWebResource("apps", app.getApplicationId().toString(), .constructWebResource("apps", app.getApplicationId().toString(),
"priority") "priority")
.accept(mediaType).get(ClientResponse.class); .accept(mediaType).get(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
if (mediaType.equals(MediaType.APPLICATION_JSON)) { if (mediaType.equals(MediaType.APPLICATION_JSON)) {
verifyAppPriorityJson(response, modifiedPriority); verifyAppPriorityJson(response, modifiedPriority);
} else { } else {
@ -1123,7 +1127,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
"priority") "priority")
.entity(entity, contentType).accept(mediaType) .entity(entity, contentType).accept(mediaType)
.put(ClientResponse.class); .put(ClientResponse.class);
assertEquals(Status.FORBIDDEN, response.getClientResponseStatus()); assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
} }
} }
rm.stop(); rm.stop();
@ -1173,10 +1177,11 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.put(ClientResponse.class); .put(ClientResponse.class);
if (!isAuthenticationEnabled()) { if (!isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED,
response.getStatusInfo());
continue; continue;
} }
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
String expectedQueue = "test"; String expectedQueue = "test";
if(!isCapacityScheduler) { if(!isCapacityScheduler) {
expectedQueue = "root.test"; expectedQueue = "root.test";
@ -1196,7 +1201,7 @@ public class TestRMWebServicesAppsModification extends JerseyTestBase {
.constructWebResource("apps", app.getApplicationId().toString(), .constructWebResource("apps", app.getApplicationId().toString(),
"queue").entity(entity, contentType).accept(mediaType) "queue").entity(entity, contentType).accept(mediaType)
.put(ClientResponse.class); .put(ClientResponse.class);
assertEquals(Status.FORBIDDEN, response.getClientResponseStatus()); assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
if(isCapacityScheduler) { if(isCapacityScheduler) {
Assert.assertEquals("default", app.getQueue()); Assert.assertEquals("default", app.getQueue());
} }

View File

@ -38,6 +38,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.Capacity
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration;
import org.apache.hadoop.yarn.util.resource.Resources; import org.apache.hadoop.yarn.util.resource.Resources;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -53,8 +54,6 @@ import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
@ -64,8 +63,8 @@ import com.sun.jersey.test.framework.WebAppDescriptor;
public class TestRMWebServicesCapacitySched extends JerseyTestBase { public class TestRMWebServicesCapacitySched extends JerseyTestBase {
private static MockRM rm; private static MockRM rm;
private CapacitySchedulerConfiguration csConf; private static CapacitySchedulerConfiguration csConf;
private YarnConfiguration conf; private static YarnConfiguration conf;
private class QueueInfo { private class QueueInfo {
float capacity; float capacity;
@ -89,7 +88,7 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
float userLimitFactor; float userLimitFactor;
} }
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -104,62 +103,62 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
bind(ResourceManager.class).toInstance(rm); bind(ResourceManager.class).toInstance(rm);
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
private static void setupQueueConfiguration( private static void setupQueueConfiguration(
CapacitySchedulerConfiguration conf) { CapacitySchedulerConfiguration config) {
// Define top-level queues // Define top-level queues
conf.setQueues(CapacitySchedulerConfiguration.ROOT, new String[] { "a", "b" }); config.setQueues(CapacitySchedulerConfiguration.ROOT,
new String[] {"a", "b"});
final String A = CapacitySchedulerConfiguration.ROOT + ".a"; final String A = CapacitySchedulerConfiguration.ROOT + ".a";
conf.setCapacity(A, 10.5f); config.setCapacity(A, 10.5f);
conf.setMaximumCapacity(A, 50); config.setMaximumCapacity(A, 50);
final String B = CapacitySchedulerConfiguration.ROOT + ".b"; final String B = CapacitySchedulerConfiguration.ROOT + ".b";
conf.setCapacity(B, 89.5f); config.setCapacity(B, 89.5f);
// Define 2nd-level queues // Define 2nd-level queues
final String A1 = A + ".a1"; final String A1 = A + ".a1";
final String A2 = A + ".a2"; final String A2 = A + ".a2";
conf.setQueues(A, new String[] { "a1", "a2" }); config.setQueues(A, new String[] {"a1", "a2"});
conf.setCapacity(A1, 30); config.setCapacity(A1, 30);
conf.setMaximumCapacity(A1, 50); config.setMaximumCapacity(A1, 50);
conf.setUserLimitFactor(A1, 100.0f); config.setUserLimitFactor(A1, 100.0f);
conf.setCapacity(A2, 70); config.setCapacity(A2, 70);
conf.setUserLimitFactor(A2, 100.0f); config.setUserLimitFactor(A2, 100.0f);
final String B1 = B + ".b1"; final String B1 = B + ".b1";
final String B2 = B + ".b2"; final String B2 = B + ".b2";
final String B3 = B + ".b3"; final String B3 = B + ".b3";
conf.setQueues(B, new String[] { "b1", "b2", "b3" }); config.setQueues(B, new String[] {"b1", "b2", "b3"});
conf.setCapacity(B1, 60); config.setCapacity(B1, 60);
conf.setUserLimitFactor(B1, 100.0f); config.setUserLimitFactor(B1, 100.0f);
conf.setCapacity(B2, 39.5f); config.setCapacity(B2, 39.5f);
conf.setUserLimitFactor(B2, 100.0f); config.setUserLimitFactor(B2, 100.0f);
conf.setCapacity(B3, 0.5f); config.setCapacity(B3, 0.5f);
conf.setUserLimitFactor(B3, 100.0f); config.setUserLimitFactor(B3, 100.0f);
conf.setQueues(A1, new String[] {"a1a", "a1b"}); config.setQueues(A1, new String[] {"a1a", "a1b"});
final String A1A = A1 + ".a1a"; final String A1A = A1 + ".a1a";
conf.setCapacity(A1A, 85); config.setCapacity(A1A, 85);
final String A1B = A1 + ".a1b"; final String A1B = A1 + ".a1b";
conf.setCapacity(A1B, 15); config.setCapacity(A1B, 15);
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestRMWebServicesCapacitySched() { public TestRMWebServicesCapacitySched() {

View File

@ -18,6 +18,8 @@
package org.apache.hadoop.yarn.server.resourcemanager.webapp; package org.apache.hadoop.yarn.server.resourcemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.StringReader; import java.io.StringReader;
@ -54,6 +56,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fifo.FifoScheduler; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fifo.FifoScheduler;
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.DelegationToken; import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.DelegationToken;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -79,7 +82,6 @@ import static org.junit.Assert.assertFalse;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector; import com.google.inject.Injector;
import com.google.inject.Singleton; import com.google.inject.Singleton;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -97,7 +99,6 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.getServerPrincipal(); .getServerPrincipal();
private static MiniKdc testMiniKDC; private static MiniKdc testMiniKDC;
private static MockRM rm; private static MockRM rm;
private Injector injector;
private boolean isKerberosAuth = false; private boolean isKerberosAuth = false;
// Make sure the test uses the published header string // Make sure the test uses the published header string
@ -200,14 +201,6 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
}); });
} }
public class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return injector;
}
}
@Parameters @Parameters
public static Collection<Object[]> guiceConfigs() { public static Collection<Object[]> guiceConfigs() {
return Arrays.asList(new Object[][] { { 0 }, { 1 } }); return Arrays.asList(new Object[][] { { 0 }, { 1 } });
@ -222,10 +215,10 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
switch (run) { switch (run) {
case 0: case 0:
default: default:
injector = getKerberosAuthInjector(); GuiceServletConfig.setInjector(getKerberosAuthInjector());
break; break;
case 1: case 1:
injector = getSimpleAuthInjector(); GuiceServletConfig.setInjector(getSimpleAuthInjector());
break; break;
} }
} }
@ -305,7 +298,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.path("delegation-token").queryParam("user.name", "testuser") .path("delegation-token").queryParam("user.name", "testuser")
.accept(contentType).entity(body, mediaType) .accept(contentType).entity(body, mediaType)
.post(ClientResponse.class); .post(ClientResponse.class);
assertEquals(Status.FORBIDDEN, response.getClientResponseStatus()); assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
} }
private void verifyKerberosAuthCreate(String mType, String cType, private void verifyKerberosAuthCreate(String mType, String cType,
@ -321,7 +314,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token").accept(contentType) .path("delegation-token").accept(contentType)
.entity(body, mediaType).post(ClientResponse.class); .entity(body, mediaType).post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
DelegationToken tok = getDelegationTokenFromResponse(response); DelegationToken tok = getDelegationTokenFromResponse(response);
assertFalse(tok.getToken().isEmpty()); assertFalse(tok.getToken().isEmpty());
Token<RMDelegationTokenIdentifier> token = Token<RMDelegationTokenIdentifier> token =
@ -334,7 +327,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token").accept(contentType) .path("delegation-token").accept(contentType)
.entity(dtoken, mediaType).post(ClientResponse.class); .entity(dtoken, mediaType).post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
tok = getDelegationTokenFromResponse(response); tok = getDelegationTokenFromResponse(response);
assertFalse(tok.getToken().isEmpty()); assertFalse(tok.getToken().isEmpty());
token = new Token<RMDelegationTokenIdentifier>(); token = new Token<RMDelegationTokenIdentifier>();
@ -375,7 +368,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token").accept(contentType) .path("delegation-token").accept(contentType)
.entity(dummyToken, mediaType).post(ClientResponse.class); .entity(dummyToken, mediaType).post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
DelegationToken tok = getDelegationTokenFromResponse(response); DelegationToken tok = getDelegationTokenFromResponse(response);
assertFalse(tok.getToken().isEmpty()); assertFalse(tok.getToken().isEmpty());
String body = generateRenewTokenBody(mediaType, tok.getToken()); String body = generateRenewTokenBody(mediaType, tok.getToken());
@ -385,8 +378,8 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.header(yarnTokenHeader, tok.getToken()) .header(yarnTokenHeader, tok.getToken())
.accept(contentType).entity(body, mediaType) .accept(contentType).entity(body, mediaType)
.post(ClientResponse.class); .post(ClientResponse.class);
assertEquals(Status.FORBIDDEN, assertResponseStatusCode(Status.FORBIDDEN,
response.getClientResponseStatus()); response.getStatusInfo());
return tok; return tok;
} }
}); });
@ -406,7 +399,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.header(yarnTokenHeader, responseToken.getToken()) .header(yarnTokenHeader, responseToken.getToken())
.accept(contentType).entity(body, mediaType) .accept(contentType).entity(body, mediaType)
.post(ClientResponse.class); .post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
DelegationToken tok = getDelegationTokenFromResponse(response); DelegationToken tok = getDelegationTokenFromResponse(response);
String message = String message =
"Expiration time not as expected: old = " + oldExpirationTime "Expiration time not as expected: old = " + oldExpirationTime
@ -421,7 +414,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.header(yarnTokenHeader, responseToken.getToken()) .header(yarnTokenHeader, responseToken.getToken())
.accept(contentType).entity(body, mediaType) .accept(contentType).entity(body, mediaType)
.post(ClientResponse.class); .post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
tok = getDelegationTokenFromResponse(response); tok = getDelegationTokenFromResponse(response);
message = message =
"Expiration time not as expected: old = " + oldExpirationTime "Expiration time not as expected: old = " + oldExpirationTime
@ -443,7 +436,8 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.header(yarnTokenHeader, responseToken.getToken()) .header(yarnTokenHeader, responseToken.getToken())
.accept(contentType).entity(body, mediaType) .accept(contentType).entity(body, mediaType)
.post(ClientResponse.class); .post(ClientResponse.class);
assertEquals(Status.FORBIDDEN, response.getClientResponseStatus()); assertResponseStatusCode(Status.FORBIDDEN,
response.getStatusInfo());
return null; return null;
} }
}); });
@ -469,7 +463,8 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.path("delegation-token").path("expiration") .path("delegation-token").path("expiration")
.accept(contentType).entity(body, mediaType) .accept(contentType).entity(body, mediaType)
.post(ClientResponse.class); .post(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST,
response.getStatusInfo());
return null; return null;
} }
}); });
@ -498,7 +493,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.path("delegation-token").queryParam("user.name", "testuser") .path("delegation-token").queryParam("user.name", "testuser")
.accept(contentType).entity(body, mediaType) .accept(contentType).entity(body, mediaType)
.post(ClientResponse.class); .post(ClientResponse.class);
assertEquals(Status.FORBIDDEN, response.getClientResponseStatus()); assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
} }
// Test to verify cancel functionality - create a token and then try to cancel // Test to verify cancel functionality - create a token and then try to cancel
@ -528,14 +523,14 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token").accept(contentType) .path("delegation-token").accept(contentType)
.entity(dtoken, mediaType).post(ClientResponse.class); .entity(dtoken, mediaType).post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
DelegationToken tok = getDelegationTokenFromResponse(response); DelegationToken tok = getDelegationTokenFromResponse(response);
response = response =
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token") .path("delegation-token")
.header(yarnTokenHeader, tok.getToken()).accept(contentType) .header(yarnTokenHeader, tok.getToken()).accept(contentType)
.delete(ClientResponse.class); .delete(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
assertTokenCancelled(tok.getToken()); assertTokenCancelled(tok.getToken());
return null; return null;
} }
@ -550,7 +545,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token").accept(contentType) .path("delegation-token").accept(contentType)
.entity(dtoken, mediaType).post(ClientResponse.class); .entity(dtoken, mediaType).post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
DelegationToken tok = getDelegationTokenFromResponse(response); DelegationToken tok = getDelegationTokenFromResponse(response);
return tok; return tok;
} }
@ -564,7 +559,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.path("delegation-token") .path("delegation-token")
.header(yarnTokenHeader, tmpToken.getToken()) .header(yarnTokenHeader, tmpToken.getToken())
.accept(contentType).delete(ClientResponse.class); .accept(contentType).delete(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
assertTokenCancelled(tmpToken.getToken()); assertTokenCancelled(tmpToken.getToken());
return null; return null;
} }
@ -579,7 +574,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token").accept(contentType) .path("delegation-token").accept(contentType)
.entity(dtoken, mediaType).post(ClientResponse.class); .entity(dtoken, mediaType).post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
DelegationToken tok = getDelegationTokenFromResponse(response); DelegationToken tok = getDelegationTokenFromResponse(response);
return tok; return tok;
} }
@ -593,7 +588,8 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.path("delegation-token") .path("delegation-token")
.header(yarnTokenHeader, tmpToken2.getToken()) .header(yarnTokenHeader, tmpToken2.getToken())
.accept(contentType).delete(ClientResponse.class); .accept(contentType).delete(ClientResponse.class);
assertEquals(Status.FORBIDDEN, response.getClientResponseStatus()); assertResponseStatusCode(Status.FORBIDDEN,
response.getStatusInfo());
assertValidRMToken(tmpToken2.getToken()); assertValidRMToken(tmpToken2.getToken());
return null; return null;
} }
@ -625,7 +621,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.path("delegation-token") .path("delegation-token")
.header(yarnTokenHeader, "random-string").accept(contentType) .header(yarnTokenHeader, "random-string").accept(contentType)
.delete(ClientResponse.class); .delete(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
return null; return null;
} }
}); });
@ -638,7 +634,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token").accept(contentType) .path("delegation-token").accept(contentType)
.delete(ClientResponse.class); .delete(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
return null; return null;
} }
@ -653,7 +649,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token").accept(contentType) .path("delegation-token").accept(contentType)
.entity(dtoken, mediaType).post(ClientResponse.class); .entity(dtoken, mediaType).post(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
DelegationToken tok = getDelegationTokenFromResponse(response); DelegationToken tok = getDelegationTokenFromResponse(response);
return tok; return tok;
} }
@ -667,13 +663,13 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.path("delegation-token") .path("delegation-token")
.header(yarnTokenHeader, tmpToken.getToken()).accept(contentType) .header(yarnTokenHeader, tmpToken.getToken()).accept(contentType)
.delete(ClientResponse.class); .delete(ClientResponse.class);
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
response = response =
resource().path("ws").path("v1").path("cluster") resource().path("ws").path("v1").path("cluster")
.path("delegation-token") .path("delegation-token")
.header(yarnTokenHeader, tmpToken.getToken()).accept(contentType) .header(yarnTokenHeader, tmpToken.getToken()).accept(contentType)
.delete(ClientResponse.class); .delete(ClientResponse.class);
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
return null; return null;
} }
}); });
@ -686,7 +682,7 @@ public class TestRMWebServicesDelegationTokens extends JerseyTestBase {
.path("delegation-token").queryParam("user.name", "testuser") .path("delegation-token").queryParam("user.name", "testuser")
.header(RMWebServices.DELEGATION_TOKEN_HEADER, "random") .header(RMWebServices.DELEGATION_TOKEN_HEADER, "random")
.delete(ClientResponse.class); .delete(ClientResponse.class);
assertEquals(Status.FORBIDDEN, response.getClientResponseStatus()); assertResponseStatusCode(Status.FORBIDDEN, response.getStatusInfo());
} }
private DelegationToken private DelegationToken

View File

@ -30,15 +30,15 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.FairScheduler; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.FairScheduler;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.QueueManager; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.QueueManager;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
import org.codehaus.jettison.json.JSONObject; import org.codehaus.jettison.json.JSONObject;
import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
@ -47,9 +47,9 @@ import com.sun.jersey.test.framework.WebAppDescriptor;
public class TestRMWebServicesFairScheduler extends JerseyTestBase { public class TestRMWebServicesFairScheduler extends JerseyTestBase {
private static MockRM rm; private static MockRM rm;
private YarnConfiguration conf; private static YarnConfiguration conf;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -62,16 +62,21 @@ public class TestRMWebServicesFairScheduler extends JerseyTestBase {
bind(ResourceManager.class).toInstance(rm); bind(ResourceManager.class).toInstance(rm);
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
});
public class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return injector;
}
} }
static {
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
}
@Before
@Override
public void setUp() throws Exception {
super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
}
public TestRMWebServicesFairScheduler() { public TestRMWebServicesFairScheduler() {
super(new WebAppDescriptor.Builder( super(new WebAppDescriptor.Builder(
"org.apache.hadoop.yarn.server.resourcemanager.webapp") "org.apache.hadoop.yarn.server.resourcemanager.webapp")

View File

@ -38,6 +38,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -53,8 +54,6 @@ import org.xml.sax.InputSource;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
@ -78,10 +77,10 @@ public class TestRMWebServicesForCSWithPartitions extends JerseyTestBase {
private static final ImmutableSet<String> CLUSTER_LABELS = private static final ImmutableSet<String> CLUSTER_LABELS =
ImmutableSet.of(LABEL_LX, LABEL_LY, DEFAULT_PARTITION); ImmutableSet.of(LABEL_LX, LABEL_LY, DEFAULT_PARTITION);
private static MockRM rm; private static MockRM rm;
private CapacitySchedulerConfiguration csConf; static private CapacitySchedulerConfiguration csConf;
private YarnConfiguration conf; static private YarnConfiguration conf;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -106,76 +105,79 @@ public class TestRMWebServicesForCSWithPartitions extends JerseyTestBase {
bind(ResourceManager.class).toInstance(rm); bind(ResourceManager.class).toInstance(rm);
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); };
public class GuiceServletConfig extends GuiceServletContextListener { static {
@Override GuiceServletConfig.setInjector(
protected Injector getInjector() { Guice.createInjector(new WebServletModule()));
return injector;
}
} }
private static void setupQueueConfiguration( private static void setupQueueConfiguration(
CapacitySchedulerConfiguration conf, ResourceManager rm) { CapacitySchedulerConfiguration config, ResourceManager resourceManager) {
// Define top-level queues // Define top-level queues
conf.setQueues(CapacitySchedulerConfiguration.ROOT, config.setQueues(CapacitySchedulerConfiguration.ROOT,
new String[] { QUEUE_A, QUEUE_B, QUEUE_C }); new String[] { QUEUE_A, QUEUE_B, QUEUE_C });
String interMediateQueueC = String interMediateQueueC =
CapacitySchedulerConfiguration.ROOT + "." + QUEUE_C; CapacitySchedulerConfiguration.ROOT + "." + QUEUE_C;
conf.setQueues(interMediateQueueC, config.setQueues(interMediateQueueC,
new String[] { LEAF_QUEUE_C1, LEAF_QUEUE_C2 }); new String[] { LEAF_QUEUE_C1, LEAF_QUEUE_C2 });
conf.setCapacityByLabel(CapacitySchedulerConfiguration.ROOT, LABEL_LX, 100); config.setCapacityByLabel(
conf.setCapacityByLabel(CapacitySchedulerConfiguration.ROOT, LABEL_LY, 100); CapacitySchedulerConfiguration.ROOT, LABEL_LX, 100);
config.setCapacityByLabel(
CapacitySchedulerConfiguration.ROOT, LABEL_LY, 100);
String leafQueueA = CapacitySchedulerConfiguration.ROOT + "." + QUEUE_A; String leafQueueA = CapacitySchedulerConfiguration.ROOT + "." + QUEUE_A;
conf.setCapacity(leafQueueA, 30); config.setCapacity(leafQueueA, 30);
conf.setMaximumCapacity(leafQueueA, 50); config.setMaximumCapacity(leafQueueA, 50);
String leafQueueB = CapacitySchedulerConfiguration.ROOT + "." + QUEUE_B; String leafQueueB = CapacitySchedulerConfiguration.ROOT + "." + QUEUE_B;
conf.setCapacity(leafQueueB, 30); config.setCapacity(leafQueueB, 30);
conf.setMaximumCapacity(leafQueueB, 50); config.setMaximumCapacity(leafQueueB, 50);
conf.setCapacity(interMediateQueueC, 40); config.setCapacity(interMediateQueueC, 40);
conf.setMaximumCapacity(interMediateQueueC, 50); config.setMaximumCapacity(interMediateQueueC, 50);
String leafQueueC1 = interMediateQueueC + "." + LEAF_QUEUE_C1; String leafQueueC1 = interMediateQueueC + "." + LEAF_QUEUE_C1;
conf.setCapacity(leafQueueC1, 50); config.setCapacity(leafQueueC1, 50);
conf.setMaximumCapacity(leafQueueC1, 60); config.setMaximumCapacity(leafQueueC1, 60);
String leafQueueC2 = interMediateQueueC + "." + LEAF_QUEUE_C2; String leafQueueC2 = interMediateQueueC + "." + LEAF_QUEUE_C2;
conf.setCapacity(leafQueueC2, 50); config.setCapacity(leafQueueC2, 50);
conf.setMaximumCapacity(leafQueueC2, 70); config.setMaximumCapacity(leafQueueC2, 70);
// Define label specific configuration // Define label specific configuration
conf.setAccessibleNodeLabels(leafQueueA, ImmutableSet.of(DEFAULT_PARTITION)); config.setAccessibleNodeLabels(
conf.setAccessibleNodeLabels(leafQueueB, ImmutableSet.of(LABEL_LX)); leafQueueA, ImmutableSet.of(DEFAULT_PARTITION));
conf.setAccessibleNodeLabels(interMediateQueueC, config.setAccessibleNodeLabels(leafQueueB, ImmutableSet.of(LABEL_LX));
config.setAccessibleNodeLabels(interMediateQueueC,
ImmutableSet.of(LABEL_LX, LABEL_LY)); ImmutableSet.of(LABEL_LX, LABEL_LY));
conf.setAccessibleNodeLabels(leafQueueC1, config.setAccessibleNodeLabels(leafQueueC1,
ImmutableSet.of(LABEL_LX, LABEL_LY)); ImmutableSet.of(LABEL_LX, LABEL_LY));
conf.setAccessibleNodeLabels(leafQueueC2, config.setAccessibleNodeLabels(leafQueueC2,
ImmutableSet.of(LABEL_LX, LABEL_LY)); ImmutableSet.of(LABEL_LX, LABEL_LY));
conf.setDefaultNodeLabelExpression(leafQueueB, LABEL_LX); config.setDefaultNodeLabelExpression(leafQueueB, LABEL_LX);
conf.setDefaultNodeLabelExpression(leafQueueC1, LABEL_LX); config.setDefaultNodeLabelExpression(leafQueueC1, LABEL_LX);
conf.setDefaultNodeLabelExpression(leafQueueC2, LABEL_LY); config.setDefaultNodeLabelExpression(leafQueueC2, LABEL_LY);
conf.setCapacityByLabel(leafQueueB, LABEL_LX, 30); config.setCapacityByLabel(leafQueueB, LABEL_LX, 30);
conf.setCapacityByLabel(interMediateQueueC, LABEL_LX, 70); config.setCapacityByLabel(interMediateQueueC, LABEL_LX, 70);
conf.setCapacityByLabel(leafQueueC1, LABEL_LX, 40); config.setCapacityByLabel(leafQueueC1, LABEL_LX, 40);
conf.setCapacityByLabel(leafQueueC2, LABEL_LX, 60); config.setCapacityByLabel(leafQueueC2, LABEL_LX, 60);
conf.setCapacityByLabel(interMediateQueueC, LABEL_LY, 100); config.setCapacityByLabel(interMediateQueueC, LABEL_LY, 100);
conf.setCapacityByLabel(leafQueueC1, LABEL_LY, 50); config.setCapacityByLabel(leafQueueC1, LABEL_LY, 50);
conf.setCapacityByLabel(leafQueueC2, LABEL_LY, 50); config.setCapacityByLabel(leafQueueC2, LABEL_LY, 50);
conf.setMaximumCapacityByLabel(leafQueueC1, LABEL_LY, 75); config.setMaximumCapacityByLabel(leafQueueC1, LABEL_LY, 75);
conf.setMaximumCapacityByLabel(leafQueueC2, LABEL_LY, 75); config.setMaximumCapacityByLabel(leafQueueC2, LABEL_LY, 75);
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestRMWebServicesForCSWithPartitions() { public TestRMWebServicesForCSWithPartitions() {

View File

@ -41,16 +41,16 @@ import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.NodeToLabelsEntr
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.NodeToLabelsInfo; import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.NodeToLabelsInfo;
import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.NodeToLabelsEntryList; import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.NodeToLabelsEntryList;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
import org.codehaus.jettison.json.JSONObject; import org.codehaus.jettison.json.JSONObject;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.UniformInterfaceException; import com.sun.jersey.api.client.UniformInterfaceException;
@ -69,13 +69,13 @@ public class TestRMWebServicesNodeLabels extends JerseyTestBase {
.getLog(TestRMWebServicesNodeLabels.class); .getLog(TestRMWebServicesNodeLabels.class);
private static MockRM rm; private static MockRM rm;
private YarnConfiguration conf; private static YarnConfiguration conf;
private String userName; private static String userName;
private String notUserName; private static String notUserName;
private RMWebServices rmWebService; private static RMWebServices rmWebService;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
@ -98,14 +98,14 @@ public class TestRMWebServicesNodeLabels extends JerseyTestBase {
TestRMWebServicesAppsModification.TestRMCustomAuthFilter.class); TestRMWebServicesAppsModification.TestRMCustomAuthFilter.class);
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); };
public class GuiceServletConfig extends GuiceServletContextListener { @Override
@Before
@Override public void setUp() throws Exception {
protected Injector getInjector() { super.setUp();
return injector; GuiceServletConfig.setInjector(
} Guice.createInjector(new WebServletModule()));
} }
public TestRMWebServicesNodeLabels() { public TestRMWebServicesNodeLabels() {

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.resourcemanager.webapp; package org.apache.hadoop.yarn.server.resourcemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
@ -51,6 +52,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.SchedulerNodeRepo
import org.apache.hadoop.yarn.util.RackResolver; import org.apache.hadoop.yarn.util.RackResolver;
import org.apache.hadoop.yarn.util.YarnVersionInfo; import org.apache.hadoop.yarn.util.YarnVersionInfo;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.apache.hadoop.yarn.webapp.WebServicesTestUtils; import org.apache.hadoop.yarn.webapp.WebServicesTestUtils;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
@ -65,8 +67,6 @@ import org.xml.sax.InputSource;
import com.google.common.base.Joiner; import com.google.common.base.Joiner;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -79,7 +79,7 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
private static MockRM rm; private static MockRM rm;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -91,20 +91,19 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
bind(ResourceManager.class).toInstance(rm); bind(ResourceManager.class).toInstance(rm);
serve("/*").with(GuiceContainer.class); serve("/*").with(GuiceContainer.class);
} }
}); }
public class GuiceServletConfig extends GuiceServletContextListener { static {
GuiceServletConfig.setInjector(
@Override Guice.createInjector(new WebServletModule()));
protected Injector getInjector() {
return injector;
}
} }
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestRMWebServicesNodes() { public TestRMWebServicesNodes() {
@ -227,7 +226,8 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("nodes is not null", JSONObject.NULL, json.get("nodes")); assertEquals("nodes is not empty",
new JSONObject().toString(), json.get("nodes").toString());
} }
@Test @Test
@ -245,7 +245,7 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
@ -357,7 +357,8 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject json = response.getEntity(JSONObject.class); JSONObject json = response.getEntity(JSONObject.class);
assertEquals("incorrect number of elements", 1, json.length()); assertEquals("incorrect number of elements", 1, json.length());
assertEquals("nodes is not null", JSONObject.NULL, json.get("nodes")); assertEquals("nodes is not empty",
new JSONObject().toString(), json.get("nodes").toString());
} }
public void testNodesHelper(String path, String media) throws JSONException, public void testNodesHelper(String path, String media) throws JSONException,
@ -436,7 +437,7 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
fail("should have thrown exception on non-existent nodeid"); fail("should have thrown exception on non-existent nodeid");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -462,7 +463,7 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
fail("should have thrown exception on non-existent nodeid"); fail("should have thrown exception on non-existent nodeid");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");
@ -488,7 +489,7 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
fail("should have thrown exception on non-existent nodeid"); fail("should have thrown exception on non-existent nodeid");
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.NOT_FOUND, response.getClientResponseStatus()); assertResponseStatusCode(Status.NOT_FOUND, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_XML_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_XML_TYPE, response.getType());
String msg = response.getEntity(String.class); String msg = response.getEntity(String.class);
System.out.println(msg); System.out.println(msg);
@ -531,7 +532,7 @@ public class TestRMWebServicesNodes extends JerseyTestBase {
} catch (UniformInterfaceException ue) { } catch (UniformInterfaceException ue) {
ClientResponse response = ue.getResponse(); ClientResponse response = ue.getResponse();
assertEquals(Status.BAD_REQUEST, response.getClientResponseStatus()); assertResponseStatusCode(Status.BAD_REQUEST, response.getStatusInfo());
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
JSONObject msg = response.getEntity(JSONObject.class); JSONObject msg = response.getEntity(JSONObject.class);
JSONObject exception = msg.getJSONObject("RemoteException"); JSONObject exception = msg.getJSONObject("RemoteException");

View File

@ -18,6 +18,7 @@
package org.apache.hadoop.yarn.server.resourcemanager.webapp; package org.apache.hadoop.yarn.server.resourcemanager.webapp;
import static org.apache.hadoop.yarn.webapp.WebServicesTestUtils.assertResponseStatusCode;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
@ -56,6 +57,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.webapp.dao.ReservationUpdat
import org.apache.hadoop.yarn.util.Clock; import org.apache.hadoop.yarn.util.Clock;
import org.apache.hadoop.yarn.util.UTCClock; import org.apache.hadoop.yarn.util.UTCClock;
import org.apache.hadoop.yarn.webapp.GenericExceptionHandler; import org.apache.hadoop.yarn.webapp.GenericExceptionHandler;
import org.apache.hadoop.yarn.webapp.GuiceServletConfig;
import org.apache.hadoop.yarn.webapp.JerseyTestBase; import org.apache.hadoop.yarn.webapp.JerseyTestBase;
import org.codehaus.jettison.json.JSONArray; import org.codehaus.jettison.json.JSONArray;
import org.codehaus.jettison.json.JSONException; import org.codehaus.jettison.json.JSONException;
@ -70,7 +72,6 @@ import org.junit.runners.Parameterized.Parameters;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector; import com.google.inject.Injector;
import com.google.inject.Singleton; import com.google.inject.Singleton;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
@ -86,10 +87,9 @@ import com.sun.jersey.test.framework.WebAppDescriptor;
public class TestRMWebServicesReservation extends JerseyTestBase { public class TestRMWebServicesReservation extends JerseyTestBase {
private String webserviceUserName = "testuser"; private String webserviceUserName = "testuser";
private boolean setAuthFilter = false; private static boolean setAuthFilter = false;
private static MockRM rm; private static MockRM rm;
private static Injector injector;
private static final int MINIMUM_RESOURCE_DURATION = 1000000; private static final int MINIMUM_RESOURCE_DURATION = 1000000;
private static final Clock clock = new UTCClock(); private static final Clock clock = new UTCClock();
@ -103,14 +103,6 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
private static final String GET_NEW_RESERVATION_PATH = private static final String GET_NEW_RESERVATION_PATH =
"reservation/new-reservation"; "reservation/new-reservation";
public static class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return injector;
}
}
/* /*
* Helper class to allow testing of RM web services which require * Helper class to allow testing of RM web services which require
* authorization Add this class as a filter in the Guice injector for the * authorization Add this class as a filter in the Guice injector for the
@ -139,7 +131,7 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
} }
private abstract class TestServletModule extends ServletModule { private static abstract class TestServletModule extends ServletModule {
public Configuration conf = new Configuration(); public Configuration conf = new Configuration();
public abstract void configureScheduler(); public abstract void configureScheduler();
@ -175,7 +167,7 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
} }
} }
private class CapTestServletModule extends TestServletModule { private static class CapTestServletModule extends TestServletModule {
@Override @Override
public void configureScheduler() { public void configureScheduler() {
conf.set("yarn.resourcemanager.scheduler.class", conf.set("yarn.resourcemanager.scheduler.class",
@ -183,7 +175,7 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
} }
} }
private class FairTestServletModule extends TestServletModule { private static class FairTestServletModule extends TestServletModule {
@Override @Override
public void configureScheduler() { public void configureScheduler() {
try { try {
@ -209,52 +201,65 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
} }
} }
private Injector getNoAuthInjectorCap() { private static class NoAuthServletModule extends CapTestServletModule {
return Guice.createInjector(new CapTestServletModule() { @Override
@Override protected void configureServlets() {
protected void configureServlets() { setAuthFilter = false;
setAuthFilter = false; super.configureServlets();
super.configureServlets(); }
}
});
} }
private Injector getSimpleAuthInjectorCap() { private static class SimpleAuthServletModule extends CapTestServletModule {
return Guice.createInjector(new CapTestServletModule() { @Override
@Override protected void configureServlets() {
protected void configureServlets() { setAuthFilter = true;
setAuthFilter = true; conf.setBoolean(YarnConfiguration.YARN_ACL_ENABLE, true);
conf.setBoolean(YarnConfiguration.YARN_ACL_ENABLE, true); // set the admin acls otherwise all users are considered admins
// set the admin acls otherwise all users are considered admins // and we can't test authorization
// and we can't test authorization conf.setStrings(YarnConfiguration.YARN_ADMIN_ACL, "testuser1");
conf.setStrings(YarnConfiguration.YARN_ADMIN_ACL, "testuser1"); super.configureServlets();
super.configureServlets(); }
}
});
} }
private Injector getNoAuthInjectorFair() { private static class FairNoAuthServletModule extends FairTestServletModule {
return Guice.createInjector(new FairTestServletModule() { @Override
@Override protected void configureServlets() {
protected void configureServlets() { setAuthFilter = false;
setAuthFilter = false; super.configureServlets();
super.configureServlets(); }
}
});
} }
private Injector getSimpleAuthInjectorFair() { private static class FairSimpleAuthServletModule extends
return Guice.createInjector(new FairTestServletModule() { FairTestServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
setAuthFilter = true; setAuthFilter = true;
conf.setBoolean(YarnConfiguration.YARN_ACL_ENABLE, true); conf.setBoolean(YarnConfiguration.YARN_ACL_ENABLE, true);
// set the admin acls otherwise all users are considered admins // set the admin acls otherwise all users are considered admins
// and we can't test authorization // and we can't test authorization
conf.setStrings(YarnConfiguration.YARN_ADMIN_ACL, "testuser1"); conf.setStrings(YarnConfiguration.YARN_ADMIN_ACL, "testuser1");
super.configureServlets(); super.configureServlets();
} }
}); }
private Injector initNoAuthInjectorCap() {
return GuiceServletConfig.setInjector(
Guice.createInjector(new NoAuthServletModule()));
}
private Injector initSimpleAuthInjectorCap() {
return GuiceServletConfig.setInjector(
Guice.createInjector(new SimpleAuthServletModule()));
}
private Injector initNoAuthInjectorFair() {
return GuiceServletConfig.setInjector(
Guice.createInjector(new FairNoAuthServletModule()));
}
private Injector initSimpleAuthInjectorFair() {
return GuiceServletConfig.setInjector(
Guice.createInjector(new FairSimpleAuthServletModule()));
} }
@Parameters @Parameters
@ -279,19 +284,19 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
case 0: case 0:
default: default:
// No Auth Capacity Scheduler // No Auth Capacity Scheduler
injector = getNoAuthInjectorCap(); initNoAuthInjectorCap();
break; break;
case 1: case 1:
// Simple Auth Capacity Scheduler // Simple Auth Capacity Scheduler
injector = getSimpleAuthInjectorCap(); initSimpleAuthInjectorCap();
break; break;
case 2: case 2:
// No Auth Fair Scheduler // No Auth Fair Scheduler
injector = getNoAuthInjectorFair(); initNoAuthInjectorFair();
break; break;
case 3: case 3:
// Simple Auth Fair Scheduler // Simple Auth Fair Scheduler
injector = getSimpleAuthInjectorFair(); initSimpleAuthInjectorFair();
break; break;
} }
} }
@ -959,7 +964,7 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
.post(ClientResponse.class); .post(ClientResponse.class);
if (!this.isAuthenticationEnabled()) { if (!this.isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED, response.getStatusInfo());
return ReservationId.newInstance(clock.getTime(), fallbackReservationId); return ReservationId.newInstance(clock.getTime(), fallbackReservationId);
} }
@ -1013,7 +1018,7 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
.accept(media).post(ClientResponse.class); .accept(media).post(ClientResponse.class);
if (!this.isAuthenticationEnabled()) { if (!this.isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED, response.getStatusInfo());
} }
return response; return response;
@ -1046,13 +1051,13 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
.accept(media).post(ClientResponse.class); .accept(media).post(ClientResponse.class);
if (!this.isAuthenticationEnabled()) { if (!this.isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED, response.getStatusInfo());
return; return;
} }
System.out.println("RESPONSE:" + response); System.out.println("RESPONSE:" + response);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
} }
@ -1095,13 +1100,13 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
.accept(media).post(ClientResponse.class); .accept(media).post(ClientResponse.class);
if (!this.isAuthenticationEnabled()) { if (!this.isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED, response.getStatusInfo());
return; return;
} }
System.out.println("RESPONSE:" + response); System.out.println("RESPONSE:" + response);
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
assertEquals(Status.OK, response.getClientResponseStatus()); assertResponseStatusCode(Status.OK, response.getStatusInfo());
} }
private void testRDLHelper(JSONObject json) throws JSONException { private void testRDLHelper(JSONObject json) throws JSONException {
@ -1126,12 +1131,12 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
ClientResponse response = resource.get(ClientResponse.class); ClientResponse response = resource.get(ClientResponse.class);
if (!this.isAuthenticationEnabled()) { if (!this.isAuthenticationEnabled()) {
assertEquals(Status.UNAUTHORIZED, response.getClientResponseStatus()); assertResponseStatusCode(Status.UNAUTHORIZED, response.getStatusInfo());
return null; return null;
} }
assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType()); assertEquals(MediaType.APPLICATION_JSON_TYPE, response.getType());
assertEquals(status, response.getClientResponseStatus()); assertResponseStatusCode(status, response.getStatusInfo());
return response.getEntity(JSONObject.class); return response.getEntity(JSONObject.class);
} }
@ -1152,7 +1157,7 @@ public class TestRMWebServicesReservation extends JerseyTestBase {
} }
private boolean isHttpSuccessResponse(ClientResponse response) { private boolean isHttpSuccessResponse(ClientResponse response) {
return (response.getStatus() / 100) == 2; return (response.getStatusInfo().getStatusCode() / 100) == 2;
} }
private void setupCluster(int nodes) throws Exception { private void setupCluster(int nodes) throws Exception {

View File

@ -19,12 +19,9 @@
package org.apache.hadoop.yarn.webapp; package org.apache.hadoop.yarn.webapp;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.ClientResponse.Status; import com.sun.jersey.api.client.ClientResponse.Status;
import com.sun.jersey.api.client.UniformInterfaceException;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
import com.sun.jersey.guice.spi.container.servlet.GuiceContainer; import com.sun.jersey.guice.spi.container.servlet.GuiceContainer;
import com.sun.jersey.test.framework.WebAppDescriptor; import com.sun.jersey.test.framework.WebAppDescriptor;
@ -33,7 +30,6 @@ import org.apache.hadoop.security.http.RestCsrfPreventionFilter;
import org.apache.hadoop.service.Service.STATE; import org.apache.hadoop.service.Service.STATE;
import org.apache.hadoop.util.VersionInfo; import org.apache.hadoop.util.VersionInfo;
import org.apache.hadoop.yarn.conf.YarnConfiguration; import org.apache.hadoop.yarn.conf.YarnConfiguration;
import org.apache.hadoop.yarn.server.resourcemanager.ClusterMetrics;
import org.apache.hadoop.yarn.server.resourcemanager.MockRM; import org.apache.hadoop.yarn.server.resourcemanager.MockRM;
import org.apache.hadoop.yarn.server.resourcemanager.ResourceManager; import org.apache.hadoop.yarn.server.resourcemanager.ResourceManager;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler;
@ -41,10 +37,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fifo.FifoSchedule
import org.apache.hadoop.yarn.server.resourcemanager.webapp.JAXBContextResolver; import org.apache.hadoop.yarn.server.resourcemanager.webapp.JAXBContextResolver;
import org.apache.hadoop.yarn.server.resourcemanager.webapp.RMWebServices; import org.apache.hadoop.yarn.server.resourcemanager.webapp.RMWebServices;
import org.apache.hadoop.yarn.util.YarnVersionInfo; import org.apache.hadoop.yarn.util.YarnVersionInfo;
import org.codehaus.jettison.json.JSONException;
import org.codehaus.jettison.json.JSONObject;
import org.junit.Before; import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test; import org.junit.Test;
import org.w3c.dom.Document; import org.w3c.dom.Document;
import org.w3c.dom.Element; import org.w3c.dom.Element;
@ -60,7 +53,6 @@ import java.util.Map;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
/** /**
* Used TestRMWebServices as an example of web invocations of RM and added * Used TestRMWebServices as an example of web invocations of RM and added
@ -70,7 +62,7 @@ public class TestRMWithCSRFFilter extends JerseyTestBase {
private static MockRM rm; private static MockRM rm;
private Injector injector = Guice.createInjector(new ServletModule() { private static class WebServletModule extends ServletModule {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -89,20 +81,14 @@ public class TestRMWithCSRFFilter extends JerseyTestBase {
"OPTIONS,HEAD,TRACE"); "OPTIONS,HEAD,TRACE");
filter("/*").through(csrfFilter, initParams); filter("/*").through(csrfFilter, initParams);
} }
}); };
public class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return injector;
}
}
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
GuiceServletConfig.setInjector(
Guice.createInjector(new WebServletModule()));
} }
public TestRMWithCSRFFilter() { public TestRMWithCSRFFilter() {

View File

@ -19,8 +19,6 @@
package org.apache.hadoop.yarn.webapp; package org.apache.hadoop.yarn.webapp;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector;
import com.google.inject.servlet.GuiceServletContextListener;
import com.google.inject.servlet.ServletModule; import com.google.inject.servlet.ServletModule;
import com.sun.jersey.api.client.ClientResponse; import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource; import com.sun.jersey.api.client.WebResource;
@ -52,19 +50,6 @@ public class TestRMWithXFSFilter extends JerseyTestBase {
private static MockRM rm; private static MockRM rm;
private Injector injector;
/**
*
*/
public class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return injector;
}
}
@Before @Before
@Override @Override
public void setUp() throws Exception { public void setUp() throws Exception {
@ -103,7 +88,7 @@ public class TestRMWithXFSFilter extends JerseyTestBase {
protected void createInjector(final String headerValue, protected void createInjector(final String headerValue,
final boolean explicitlyDisabled) { final boolean explicitlyDisabled) {
injector = Guice.createInjector(new ServletModule() { GuiceServletConfig.setInjector(Guice.createInjector(new ServletModule() {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(JAXBContextResolver.class); bind(JAXBContextResolver.class);
@ -127,7 +112,7 @@ public class TestRMWithXFSFilter extends JerseyTestBase {
filter("/*").through(xfsFilter, initParams); filter("/*").through(xfsFilter, initParams);
} }
}); }));
} }
@Test @Test