gpt4 book ai didi

Grails 集成测试不会回滚

转载 作者:行者123 更新时间:2023-12-04 23:08:33 24 4
gpt4 key购买 nike

我正在从“Grails In Action”一书中学习 grails,我正在尝试从示例中运行集成测试。书中说,每个集成测试函数都应该在每个测试完成时回滚其操作。它不是回滚每个事务(因为当我完成数据库是脏的)。我试图找出原因并发现了一个名为“交易”的属性。据称,您将此属性设置为 true,它将使测试用例具有事务性,但它似乎不会改变行为。我已经包含了下面单元测试的代码。

我正在使用 grails 1.3.7 并连接到 MySql 数据库。测试运行成功,只是不回滚。我在这个集成测试中做错了什么,它跳过了回滚?

UserIntegrationTests.groovy:

package com.grailsinaction

import framework.TestTools

class UserIntegrationTests extends GroovyTestCase {
static transactional = true

protected void setUp() {
super.setUp()
}

protected void tearDown() {
super.tearDown()
}

void testCreateUser() {
TestTools.banner(log, "testCreateUser()")

def user = new User(userId:"joe", password:"secret")
assertNotNull user.save()
assertNotNull user.id

def foundUser = User.get(user.id)
assertEquals 'joe', foundUser.userId
}

void testSaveAndUpdate() {
TestTools.banner(log, "testSaveAndUpdate()")

def user = new User(userId:"joe2", password:"secret")
assertNotNull user.save()

def foundUser = User.get(user.id)
foundUser.password = 'sesame'
foundUser.save()

def editedUser = User.get(user.id)
assertEquals 'sesame', editedUser.password
}

void testSaveThenDelete() {
TestTools.banner(log, "testSaveThenDelete()")

def user = new User(userId: 'joe3', password: 'secret')
assertNotNull user.save()

def foundUser = User.get(user.id)
foundUser.delete()
assertFalse User.exists(foundUser.id)
}

void testValidation() {
TestTools.banner(log, "testValidation()")

def user = new User(userId: 'chuck-norris', password: 'tiny')
assertFalse user.validate()
assertTrue user.hasErrors()

def errors = user.errors
assertNotNull errors

errors.allErrors.each {
log.info("field: ${it.field}, code=${it.code}, rejected=${it.rejectedValue}")
}
}
}

用户.groovy
package com.grailsinaction

class User {
String userId
String password
Date dateCreated
Profile profile

static constraints = {
userId(size: 3..20, unique: true)
password(size: 6..8, validator: {password, user ->
return (password != user.userId)
})
dateCreated()
profile(nullable: true)
}

static mapping = {
profile lazy: false
}

static hasMany = [posts : Post]
}

测试执行日志
Testing started at 8:28 PM ...
Welcome to Grails 1.3.7 - http://grails.org/
Licensed under Apache Standard License 2.0
Grails home is set to: C:\Users\jmquigley\workspace\apps\Grails\grails-1.3.7
Base Directory: C:\Users\jmquigley\workspace\samples\lang-grails\hubbub
Resolving dependencies...
Dependencies resolved in 963ms.
Running script C:\Users\jmquigley\workspace\apps\Grails\grails-1.3.7\scripts\TestApp.groovy
Environment set to test
[groovyc] Compiling 1 source file to C:\Users\jmquigley\workspace\samples\lang-grails\hubbub\target\classes
[mkdir] Created dir: C:\Users\jmquigley\workspace\samples\lang-grails\hubbub\target\test-reports\html
[mkdir] Created dir: C:\Users\jmquigley\workspace\samples\lang-grails\hubbub\target\test-reports\plain
Starting integration test phase ...
[groovyc] Compiling 1 source file to C:\Users\jmquigley\workspace\samples\lang-grails\hubbub\target\classes
[groovyc] Compiling 1 source file to C:\Users\jmquigley\workspace\samples\lang-grails\hubbub\target\classes
[INFO ]20110417@20:28:42,959:grails.spring.BeanBuilder: [RuntimeConfiguration] Configuring data source for environment: TEST
[groovyc] Compiling 1 source file to C:\Users\jmquigley\workspace\samples\lang-grails\hubbub\target\test-classes\integration
-------------------------------------------------------
Running 4 integration tests...
Running test com.grailsinaction.UserIntegrationTests...
--Output from testCreateUser--
[INFO ]20110417@20:28:46,897:groovy.util.GroovyTestCase: Test Case: testCreateUser()
--Output from testSaveAndUpdate--
[INFO ]20110417@20:28:47,534:groovy.util.GroovyTestCase: Test Case: testSaveAndUpdate()
--Output from testSaveThenDelete--
[INFO ]20110417@20:28:47,568:groovy.util.GroovyTestCase: Test Case: testSaveThenDelete()
--Output from testValidation--
[INFO ]20110417@20:28:47,642:groovy.util.GroovyTestCase: Test Case: testValidation()
[INFO ]20110417@20:28:47,668:groovy.util.GroovyTestCase: field: password, code=size.toosmall, rejected=tiny
null
PASSED
Tests Completed in 1173ms ...
-------------------------------------------------------
Tests passed: 4
Tests failed: 0
-------------------------------------------------------
[junitreport] Processing C:\Users\jmquigley\workspace\samples\lang-grails\hubbub\target\test-reports\TESTS-TestSuites.xml to C:\Users\JMQUIG~1\AppData\Local\Temp\null90011239
[junitreport] Loading stylesheet C:\Users\jmquigley\workspace\apps\Grails\grails-1.3.7\lib\junit-frames.xsl
[junitreport] Transform time: 415ms
[junitreport] Deleting: C:\Users\JMQUIG~1\AppData\Local\Temp\null90011239
Tests PASSED - view reports in target\test-reports
Application context shutting down...
Application context shutdown.

Process finished with exit code 0

最佳答案

默认情况下,测试(和服务)是事务性的,因此您通常只指定静态 transactional属性(property)当它是false .如果您尚未指定方言,它可能会自动检测 MySQL,但随后会使用默认引擎(可能是 MyISAM)创建表。非事务性的 MyISAM 表。确保在使用 MySQL 时指定 InnoDB 方言,例如

test {
dataSource {
dialect= org.hibernate.dialect.MySQLInnoDBDialect
driverClassName = 'com.mysql.jdbc.Driver'
username = '...'
password = '...'
url = '...'
dbCreate = 'update'
}
}

或者,如果您在所有环境中都使用 MySQL,则可以将其移至顶级,例如
dataSource {
pooled = true
dialect = org.hibernate.dialect.MySQLInnoDBDialect
driverClassName = 'com.mysql.jdbc.Driver'
}

关于Grails 集成测试不会回滚,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5697764/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com