java - Grails 测试应用程序在 CI 服务器上失败,但在开发人员机器上失败

原文 标签 java hibernate grails maven

我有两台机器,一台 Continuus 集成服务器和一台开发机器。

两台机器都运行相同版本的 java、maven 和 grails,并且都运行 Ubuntu。
我能想到的唯一区别是 CI 在虚拟化环境中。

一些证明:

CI java-版本

java version "1.6.0_24"
Java(TM) SE Runtime Environment (build 1.6.0_24-b07)
Java HotSpot(TM) 64-Bit Server VM (build 19.1-b02, mixed mode) 

开发 Java 版本
java version "1.6.0_24"
Java(TM) SE Runtime Environment (build 1.6.0_24-b07)
Java HotSpot(TM) 64-Bit Server VM (build 19.1-b02, mixed mode) 

CI mvn-版本
Apache Maven 2.2.1 (rdebian-1)
Java version: 1.6.0_24
Java home: /usr/lib/jvm/java-6-sun-1.6.0.24/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux" version: "2.6.32-31-server" arch: "amd64" Family: "unix" 

开发 mvn -版本
Apache Maven 2.2.1 (rdebian-1)
Java version: 1.6.0_24
Java home: /usr/lib/jvm/java-6-sun-1.6.0.24/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux" version: "2.6.32-31-generic" arch: "amd64" Family: "unix" 

CI chalice
Welcome to Grails 1.3.7 - http://grails.org/
Licensed under Apache Standard License 2.0
Grails home is set to: /usr/local/lib/grails-1.3.7 

DEV chalice
Welcome to Grails 1.3.7 - http://grails.org/
Licensed under Apache Standard License 2.0
Grails home is set to: /home/netbrain/dev/apps/grails-1.3.7 

我从两台机器上的版本控制中进行了干净的检查并删除了文件夹 ~/.m2~/.ivy2为了避免任何不一致。

当我运行 grails test-app在我的 CI 服务器上,6 次测试似乎失败了。当它们在我的 DEV 系统上全部通过时。

CI grails 测试应用
Tests Completed in 28213ms ...
-------------------------------------------------------
Tests passed: 14
Tests failed: 6
------------------------------------------------------- 

DEV grails 测试应用
Tests Completed in 25889ms ...
-------------------------------------------------------
Tests passed: 20
Tests failed: 0
------------------------------------------------------- 

当我查看从测试输出中得到的错误消息时,我可以看到如下内容:
junit.framework.AssertionFailedError: expected:<1> but was:<0>
not-null property references a null or transient value

据我所知,测试在逻辑上是正确的,它们不应该出现这些错误,尤其是当几个获得“ transient 值”错误的测试没有将任何内容存储到数据库时!

对我来说,问题似乎出在 hibernate/内存数据库/测试阶段的组合中。

导致此问题的环境之间必须存在一些差异。是否有人对我如何继续以进一步调试问题有任何提示?

再次感谢!

编辑

好的,这就是我尝试过的:
  • 删除文件夹~/.m2 , ~/.ivy2 , ~/.grails
  • 运行 grails 清洁
  • 运行 grails 测试应用程序

  • 但是我仍然在我的 CI 环境中看到失败的测试,但在开发机器上却没有。

    编辑

    一些新的发展..

    我尝试只运行在 CI 上失败的测试,似乎在运行 grails test-app :integration path.to.failing.tests 时他们都是通过 !在运行 grails test-app 时,这些测试会导致 失败! :(

    我完全困惑,对这里发生的事情一无所知......

    最佳答案

    我几乎可以保证这是一个测试污染问题,不同的服务器以不同的顺序运行测试。

    测试污染的最大线索总是当你自己可以成功运行测试,但是当你先运行其他测试时,它会失败。

    我已经多次发生这种情况,我在一个测试中弄乱了 Class 的 metaClass 或注入(inject)的 spring 单例(如服务 bean),忘记清理它,并且其他测试受到它的影响。观察正在运行的测试的输出并比较它们以确保它们在两个盒子上以完全相同的顺序运行。如果不是,那就是测试订购问题。

    找出哪些测试交互不良的“最简单”的方法是运行 grails test-app并按照它们在失败框中发生的相同顺序传递每个测试名称(我通常使用文本编辑器从上一次运行中切出测试名称并将它们连接在一起,所以我知道它们的顺序相同) .

    另一个潜在的问题是,如果一台机器正在使用 mysql,而您错误地将“myisam”配置为默认存储引擎,而不是“innodb”(或另一个支持事务的引擎)。您可以键入“显示引擎;”在 mysql 实例上查看默认的引擎。听起来您正在使用 hsqldb 或其他内存数据库进行测试,所以这可能不是您的问题。

    关于java - Grails 测试应用程序在 CI 服务器上失败,但在开发人员机器上失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6069579/

    相关文章:

    java - Hibernate createSQLquery 出现无效的列名错误

    java - 在使用 Hibernate 时处理架构升级

    rest - Grails-withRest响应不是JSON

    java - Hibernate 是否记录它在准备好的 SQL 语句中分配给占位符的值?

    grails - 将就地插件添加到 grails 3 项目

    grails - grails:如何为SimpleUrlAuthenticationSuccessHandler/AbstractAuthenticationTargetUrlRequestHandler设置targetUrlParameter

    java - 什么可能导致 Android 布局的特定区域停止响应按钮点击?

    java - GWT按钮setEnabled空指针异常错误

    java - 如何使用 ClassName 作为字符串来执行 "new Class"?

    java - 如何在使用 Java 读取和处理数据库记录时进行异步消息传递