Initial Contribution

Signed-off-by: Vinay Vishal <vinay.vishal@oracle.com>
diff --git a/appserver/tests/quicklook/security/appperms/src/java/TestServlet.java b/appserver/tests/quicklook/security/appperms/src/java/TestServlet.java
new file mode 100644
index 0000000..e50ba65
--- /dev/null
+++ b/appserver/tests/quicklook/security/appperms/src/java/TestServlet.java
@@ -0,0 +1,167 @@
+/*
+ * Copyright (c) 2013, 2018 Oracle and/or its affiliates. All rights reserved.
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v. 2.0, which is available at
+ * http://www.eclipse.org/legal/epl-2.0.
+ *
+ * This Source Code may also be made available under the following Secondary
+ * Licenses when the conditions for such availability set forth in the
+ * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
+ * version 2 with the GNU Classpath Exception, which is available at
+ * https://www.gnu.org/software/classpath/license.html.
+ *
+ * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
+ */
+
+package myapp;
+
+import java.io.*;
+import java.net.*;
+import java.security.AccessControlException;
+import java.security.AccessController;
+
+import javax.ejb.EJB;
+import javax.naming.*;
+
+import javax.servlet.*;
+import javax.servlet.http.*;
+
+public class TestServlet extends HttpServlet {
+   
+    @EJB
+    private BeanRootInterface root;
+
+    @EJB
+    private BeanMessageInterface msg;
+
+    private ServletContext sc;
+
+    private String message;
+
+    public void init(ServletConfig config) throws ServletException  {
+        super.init(config);
+        sc = config.getServletContext();
+        message = msg.getMessage();
+        System.out.println("servlet init: message="+message);
+    }
+
+    protected void processRequest(HttpServletRequest request,
+            HttpServletResponse response) throws ServletException, IOException {
+        response.setContentType("text/plain");
+        PrintWriter out = response.getWriter();
+        String EXPECTED_RESULT = "PostBeanRootPostBeanLeafHelloBeanLeaf";
+        boolean status = false;
+
+        try {
+
+            String testcase = request.getParameter("tc");
+            out.println("testcase = " + testcase);
+            out.println("TestServlet");
+            out.println("contextPath=" + request.getContextPath());
+
+            if (testcase != null) {
+
+                if ("InjectLookup".equals(testcase)) {
+                    // EJB injection check
+                    // out.println("injected root: " + root);
+                    String hello = root.sayHello();
+                    out.println("Hello from injected bean: " + hello);
+
+                    // EJB lookup check
+                    InitialContext ic = new InitialContext();
+                    // "java"glabal[/<app-name>]/<module-name>/<bean-name>"
+                    // app-name -- name of ear file (option)
+                    // module-name -- name of war or jar file
+                    // bean-name -- name of ejb
+                    BeanRootInterface root2 = (BeanRootInterface) ic
+                            .lookup("java:global/appperms/apppermsEJB/BeanRoot");
+
+                    // out.println("global root: " + root2);
+                    String hello2 = root2.sayHello();
+                    out.println("Hello from lookup bean: " + hello2);
+
+                    StringBuffer checkReport = new StringBuffer(" -Servlet test- ");
+                    FilePermission fp = new FilePermission(
+                            "/scratch/spei/bug/test/war.txt", "delete");
+                    try {
+                        if (System.getSecurityManager() != null) {
+                            AccessController.checkPermission(fp);
+                            checkReport.append("servlet - success for WAR.txt; ");
+                        } else
+                            checkReport.append("servlet - bypass for WAR.txt; ");
+                        
+                    } catch (AccessControlException e) {
+                        checkReport.append("servlet - failed for WAR.txt; ");
+                    }
+
+                    fp = new FilePermission("/scratch/spei/bug/test/ear.txt",
+                            "delete");
+                    try {
+                        if (System.getSecurityManager() != null) {
+                            AccessController.checkPermission(fp);
+                            checkReport.append("servlet - success for EAR.txt; ");
+                        } else
+                            checkReport.append("servlet - bypass for EAR.txt; ");
+                    } catch (AccessControlException e) {
+                        checkReport.append("servlet - failed for EAR.txt; ");
+                    }
+
+                    fp = new FilePermission("/scratch/spei/bug/test/ejb.txt",
+                            "delete");
+                    try {
+                        if (System.getSecurityManager() != null) {
+                            AccessController.checkPermission(fp);
+                            checkReport.append("servlet - success for EJB.txt; ");
+                        } else
+                            checkReport.append("servlet - bypass for EJB.txt; ");
+                    } catch (AccessControlException e) {
+                        checkReport.append("servlet - failed for EJB.txt; ");
+                    }
+
+                    String crStr = checkReport.toString();
+                    out.println("test: " + crStr);
+
+                    
+                    
+                    if (hello.equals(hello2) && 
+                        !crStr.contains("failed") &&
+                        !hello.contains("failed")) {
+                        status = true;
+                    }
+                } else if ("Startup".equals(testcase)) {
+                    // deployment check for startup
+                    out.println("message by deployment: " + message);
+                    if (message != null && message.equals(EXPECTED_RESULT)) {
+                        status = true;
+                    }
+                }
+            }
+
+        } catch (Throwable th) {
+            th.printStackTrace(out);
+        } finally {
+            if (status) {
+                out.println("Test:Pass");
+            } else {
+                out.println("Test:Fail");
+            }
+            out.close();
+        }
+    }
+
+    protected void doGet(HttpServletRequest request,
+            HttpServletResponse response) throws ServletException, IOException {
+        processRequest(request, response);
+    }
+
+    protected void doPost(HttpServletRequest request,
+            HttpServletResponse response) throws ServletException, IOException {
+        processRequest(request, response);
+    }
+
+    public String getServletInfo() {
+        return "Short description";
+    }
+
+}