security-programmatic

Run
How to run the sample
The source code for this sample can be found in the javaee7-samples GitHub repository. The first thing we need to do is to get the source by downloading the repository and then go into the samples folder:
git clone git://github.com/javaee-samples/javaee7-samples.git
cd javaee7-samples/servlet/security-programmatic/
Now we are ready to start testing. You can run all the tests in this sample by executing:
mvn test
Or you can run individual tests by executing one of the following:
mvn test -Dtest=LoginServletTest

LoginServletTest

Missing a description for the story. Add some javadoc to the TestClass. Show me how!
Missing a description for the deployment. Add some javadoc to the @Deployment method. Show me how!
@Deployment(testable = false)
public static WebArchive createDeployment() {
    WebArchive war = ShrinkWrap.create(WebArchive.class).
            addClass(LoginServlet.class).
            addAsWebInfResource((new File(WEBAPP_SRC + "/WEB-INF", "web.xml")));
    return war;
}
Missing a description for the test scenario. Add some javadoc to the @Test method. Show me how!
@Test
public void testUnauthenticatedRequest() throws IOException, SAXException {
    WebClient webClient = new WebClient();
    HtmlPage page = webClient.getPage(base + "/LoginServlet");
    String responseText = page.asText();

//        WebRequest request = new WebRequest(new URL(base + "/LoginServlet"), HttpMethod.GET);
//        WebResponse response = webClient.getWebConnection().getResponse(request);
//        String responseText = response.getContentAsString();

    assert(responseText.contains("isUserInRole?false"));
    assert(responseText.contains("getRemoteUser?null"));
    assert(responseText.contains("getUserPrincipal?null"));
    assert(responseText.contains("getAuthType?null"));
}
Missing a description for the test scenario. Add some javadoc to the @Test method. Show me how!
@Test
public void testAuthenticatedRequest() throws IOException, SAXException {
    WebClient webClient = new WebClient();
    WebRequest request = new WebRequest(new URL(base + "/LoginServlet?user=u1&password=p1"), HttpMethod.GET);
    WebResponse response = webClient.getWebConnection().getResponse(request);
    String responseText = response.getContentAsString();
    System.out.println(responseText);

    assert(responseText.contains("isUserInRole?true"));
    assert(responseText.contains("getRemoteUser?u1"));
    assert(responseText.contains("getUserPrincipal?u1"));
    assert(responseText.contains("getAuthType?BASIC"));
}

Share the Knowledge

Find this sample useful? Share on

There's a lot more about JavaEE to cover. If you're ready to learn more, check out the other available samples.

Help Improve

Find a bug in the sample? Something missing? You can fix it by editing the source, making the correction and sending a pull request. Or report the problem to the issue tracker

Recent Changelog

  • Jul 12, 2014: New test for programmatic registration of servlets by arun-gupta
  • Dec 11, 2013: Changing the project names to be more intuitive by arun-gupta
How to help improve this sample
The source code for this sample can be found in the javaee7-samples GitHub repository. The first thing you need to do is to get the source by downloading the repository and then go into the samples folder:
git clone git://github.com/javaee-samples/javaee7-samples.git
cd javaee7-samples/servlet/security-programmatic/

Do the changes as you see fit and send a pull request!

Good Luck!