0

Grails 1.3.5 并安装了 selenium-rc、easyb 和 spring-security-core 插件。除了我遇到的这种情况外,一切似乎都很好。我有一个正在测试的页面,其中包含以下标记:

<sec:ifAnyGranted roles='ROLE_ADMIN'>
    <span class="menuButton">
      <g:link mapping="adminPage">
        <g:message code="default.admin.label" default="--Admin--"/>
      </g:link>
    </span>
</sec:ifAnyGranted>

正常运行应用程序时,一切正常。如果我以普通用户身份登录,则不会显示管理员链接。如果我以管理员身份登录,链接会显示。运行我的测试时,无论谁登录,检查都会失败,因此永远不会呈现 Admin 链接。

scenario "An Admin User logs into the system", {
   when "the user completes the login form with proper credentials", {

   grailsApplication = ApplicationHolder.application
   springSecurityService = ApplicationHolder.application.mainContext.getBean("springSecurityService")

   def userAdmin = new User(username: 'testAdmin', firstName: 'Test', lastName: 'Admin', enabled: true, password: springSecurityService.encodePassword("password")).save(flush: true)
   def roleAdmin = new Role(authority: 'ROLE_ADMIN').save(flush: true)
   UserRole.create(userAdmin, roleAdmin)

   selenium.openAndWait("/platform/login/auth")
   selenium.type('j_username', 'testAdmin')
   selenium.type('j_password', 'password')
   selenium.clickAndWait('signInBtn')

 }
 then "the user should be logged in and viewing their My Account page, as an admin", {
   selenium.isTextPresent("Welcome Test").shouldBe true
   selenium.isElementPresent('link=Admin').shouldBe true

 }
}

其他标签也可以正常工作,例如 ifLoggedIn 和 ifNotLoggedIn。任何人都知道这是一个已知问题或任何其他信息吗?谢谢。

4

1 回答 1

1

尝试添加冲洗

 UserRole.create(userAdmin, roleAdmin, true)

http://burtbeckwith.github.com/grails-spring-security-core/docs/manual/guide/4%20Required%20and%20Optional%20Domain%20Classes.html#4.2%20Authority%20Class

于 2010-10-15T21:09:33.173 回答