控制器集成测试

时间:2010-11-15 20:51:30

标签: grails integration-testing

控制器行动:

def deleteDept = {

        def departmentInstance = Department.findByName(params.department.name)

        if (!departmentInstance) {
            println "no dept instance"
            throw new org.codehaus.groovy.grails.exceptions.NewInstanceCreationException ("could not create DeptInstance for ${params.department.name}")
        } else if (departmentInstance.paySvcs && !departmentInstance.paySvcs.isEmpty()){
            println "instance with paySvcs"
            // !!!! do not delete the department if it has payment services !!!!
            departmentInstance.errors.reject('department.do.not.delete.message')
//            render(view: "editDept", model: [departmentInstance: departmentInstance])
            redirect(action: "editDept", id: departmentInstance.id)
        } else{
            println "proceed to delete"
            try {
                departmentInstance.delete(flush: true)
                flash.message = "${message(code: 'default.deleted.message', args: [message(code: 'department.label', default: 'Department'), departmentInstance.name])}"
                redirect(action: "appAdmin", id: departmentInstance.id)
            }
            catch (org.springframework.dao.DataIntegrityViolationException e) {
                println "something went wrong"
                flash.message = "${message(code: 'default.not.deleted.message', args: [message(code: 'department.label', default: 'Department'), departmentInstance.name])}"
                redirect(action: "editDept", id: departmentInstance.id)
            }
        }
    }

整合测试:

        def AppAdminController controller = new AppAdminController()        // create the controller
        controller.metaClass.message = { Map p -> return "foo" }            // message dummy returning garbage - work around the controller message exception
        controller.params.department = [name:"dept1", phone:"817-273-3260", g_password:"password", street:"Main St.", g_userID:"user", unitCode:"1234567", email:"dept1@yahoo.com", zip:"75097", fax:"817-273-2222"]
        def dept2 = new Department (name: "Dept2", unitCode: "1234568", street: "Main St.", zip: "75097", fax: "817-273-2222", phone: "817-273 3260", email: "dept2@yahoo.com", g_userID: "user", g_password: "password")
        def dept1 = new Department (name: "Dept1", unitCode: "1234568", street: "Main St.", zip: "75097", fax: "817-273-2222", phone: "817-273 3260", email: "dept1@yahoo.com", g_userID: "user", g_password: "password")
        def math = new PaySvc()
        def another = new PaySvc()
        dept.paySvcs = []
        dept.paySvcs.add(math)
        dept.paySvcs.add(another)
        mockDomain(Department, [dept1, dept2])

        def svcTest = Department.findByName("Dept1")
        assertNotNull svcTest                                           // record Dept1 exists
        assertEquals 2, svcTest.paySvcs.size()                          // 2 paySvcs total

        controller.deleteDept()                                         // calling the action

        svcTest = null
        svcTest = Department.findByName("Dept1")
        assertNotNull svcTest                                           // record Dept1 still exists, it was not deleted
        // can't test render, controller.response.contentAsString is null
        // but testing at the UI is OK
 //       assertEquals "editDept", controller.response.contentAsString    // action should render "editDept"
        assertEquals "editDept", controller.redirectArgs.action

问题:

render(view: "editDept", model: [departmentInstance: departmentInstance]) 

在UI上手动测试时有效。但是在集成测试中,controller.response在使用render时为null,但在使用重定向时返回预期的redirectArg。 有什么想法吗?

1 个答案:

答案 0 :(得分:10)

可能为时已晚,但可以帮助其他人: 使用render,您需要使用控制器上的modelAndView对象,例如以下示例:

assertEquals controller.modelAndView.model.departmentInstance, departmentInstance

assertEquals controller.modelAndView.viewName, "/test/editDept"

祝你好运!