程序化登录在arquillian测试中不起作用

时间:2013-07-15 08:13:01

标签: login jboss-arquillian glassfish-embedded

我正试图在嵌入式glassfish的arquillian测试中使用ProgrammaticLogin类来模拟登录。 我的代码如下:

System.setProperty("java.security.auth.login.config","path/login.config")
com.sun.appserv.security.ProgrammaticLogin loginP = new ProgrammaticLogin();
    try{
        loginP.login("user1","password","fileRealm",true);
    }
    catch (Exception e){
        System.out.println(e.getMessage());
    }

我遇到以下异常:

SEVERE: SEC9050: Programmatic login failed
com.sun.enterprise.security.auth.login.common.LoginException: Login failed: Failed file login for user1.
    at com.sun.enterprise.security.auth.login.LoginContextDriver.doPasswordLogin(LoginContextDriver.java:394)
    at com.sun.enterprise.security.auth.login.LoginContextDriver.login(LoginContextDriver.java:240)
    at com.sun.enterprise.security.auth.login.LoginContextDriver.login(LoginContextDriver.java:153)
    at com.sun.appserv.security.ProgrammaticLogin$1.run(ProgrammaticLogin.java:174)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.appserv.security.ProgrammaticLogin.login(ProgrammaticLogin.java:168)
    at com.sun.appserv.security.ProgrammaticLogin.login(ProgrammaticLogin.java:239)
    at com.sun.appserv.security.ProgrammaticLogin.login(ProgrammaticLogin.java:211)

我添加了包含登录名和密码的属性文件users.properties。

1 个答案:

答案 0 :(得分:0)

如果glassfish容器在其自己的进程中运行,则使用System.setProperty()定义的属性不可用。它只在测试中可用,它在不同的过程中运行。也许您应该在部署中添加一个使用@PostConstruct设置属性的bean。