有没有办法从插件中进行猴子补丁测试?

时间:2011-04-21 05:47:06

标签: ruby-on-rails plugins redmine redmine-plugins

我和我的团队一直在为Rails 2.3应用程序(Redmine,目前是1.1分支)大量生成插件。到目前为止,我们通过将大部分更改写为rails插件来控制Redmine的基本代码。这有两个主要好处:

  • 大多数情况下,与较新的Redmine版本的集成非常简单。
  • 我们可以通过删除/删除插件来启用/禁用某些自定义行为。事实上,这对我们来说是一个关键因素,因为我们的客户有着截然不同的要求。

我们的一些插件猴子补丁Redmine的类。例如,我们有一个插件可以为Issue模型“注入”更严格的验证:start_datedue_dateestimated_hoursleaf?问题所必需的。< / p>

这种猴子修补程序使得多次测试失败和/或引发异常。例如,这个插件使create_issue!类的IssueNestedSetTest方法产生无效问题(即缺少插件强制执行的必需属性):

# Helper that creates an issue with default attributes
def create_issue!(attributes={})
  Issue.create!({:project_id => 1, :tracker_id => 1, :author_id => 1, :subject => 'test'}.merge(attributes))
end

由于插件可能处于活动状态,也可能不处于活动状态,因此我们不希望更改测试本身。我们认为最好是插件猴子相应的测试补丁:

module StandardTestPatches
  module InstanceMethods
    def create_issue_with_gespro_standards!(attributes={})
      attributes.merge!(:start_date => 1.day.ago, :due_date => 1.day.from_now, :estimated_hours => 8)
      create_issue_without_gespro_standards!(attributes)
    end
  end

  def self.included(base)
    base.send :include, InstanceMethods
    base.class_eval do
      alias_method_chain :create_issue!, :gespro_standards
    end
  end
end

然而,由于在加载测试类之前我们需要插件的init.rb文件,因此我们无法在那里修补IssueNestedSetTest类。

有没有办法从插件中修补rails测试?

更新:仍然是一个悬而未决的问题。在http://www.redmine.org/boards/1/topics/23672

提供

1 个答案:

答案 0 :(得分:1)

每当我写Redmine或ChiliProject插件时,我总是认为:

  • 插件的测试将自行运行(在插件目录内)
  • 插件可能会修改核心代码,导致核心测试失败

我试图通过修补核心测试来帮助其他人解决这个问题,但我们从来没有找到一个好的解决方案。测试会在核心中发生变化,另一个插件会破坏某些东西,或其他东西。我甚至试图模拟测试中的接口,但维护它们是时间杀手。

我推荐(和做)是:

  1. 删除所有非核心插件
  2. 检查核心测试是否通过
  3. 安装PluginA
  4. cd进入PluginA的目录
  5. 单独运行PluginA的测试
  6. (如果同时安装了PluginA和PluginB,您可能会遇到问题)

    抱歉没有更好的解决方案。