4

已经写了很多关于引擎开发和使用虚拟应用程序进行测试的文章。

在我们的例子中,我们正在开发一个引擎,它不是一个独立的实体,而是依赖于一个真实的 Rails 3 应用程序。我们仍然希望这段代码存在于引擎中,而不是成为应用程序的一部分,因为引擎的工作是从具有自己的表和模型映射的遗留系统中导入数据,我们希望最终再次将其删除。

旧遗留表和新模式之间的数据映射很复杂,我们希望对引擎进行 TDD(使用 rspec)。

  • 我遵循了 Jose Valim 的书“Crafting Rails Appliations”,并且正在使用enginex gem
  • 我已替换/spec/dummy_app为指向真正 Rails 3 应用程序的 git 子模块。
  • 我无法从引擎加载模型(未定义的符号错误),因为真正的应用程序的 Gemfile 没有指向引擎,而且我也无法修改config/application.rb,以要求引擎(这是虚拟应用程序所做的) ,如本书第 15-16 页所述)。
  • 我将引擎的lib文件夹包含在加载路径$:spec_helper,并且路径可用。
  • 投入requirespec_helper.rb没有解决问题。
  • 我想知道是否有一个内部 Rails API(或一个聪明的猴子补丁)来挂钩真实应用程序的启动序列并需要引擎,而无需修改真实应用程序的代码(因为它在子模块中)。
  • 我不完全确定的另一个问题是我有 2 个 Gemfile(一个在引擎中,一个在应用程序中),当引擎处于活动状态时,它们都应该被使用。

想法?

4

1 回答 1

8

所以,我想出了一些事情,并会回答我自己的问题,现在我已经开始工作了。

为简单起见,我将我的 gem 的名称称为“my_gem”和“MyGem”:

engine.rb文件中,我添加了:

require 'my_gem'
require 'rails'

这修复了以下类型的错误:

my_gem/lib/my_gem/engine.rb:2: uninitialized constant MyGem::Rails (NameError)

spec_helper.rb中,我在顶部添加了:

require 'bundler/setup'
require 'my_gem'

这是为了确保立即初始化 Bundler,而不是通过应用程序初始化。这样我就可以在这里加载 MyGem,它会被挂接到应用程序的初始化序列中。这修复NameError了引擎模型类的异常。

这就留下了Gemfile使用什么的问题。问题是我的应用程序有自己的 gemfile,而 gem/engine 需要在自己的Gemfile.

我找不到任何用于 Bundler 的 API 将两个传递Gemfile给它,实际上 Bundler 似乎是围绕单个权威的假设构建的Gemfile。所以我在spec_helper. 我获取应用程序的 gemfile 并gemspec以 GemSpec 格式附加指向 gem 的依赖项。(gemspec顺便说一句,Jose Valim 的书中缺少关于的提示)。

我不知道是否有比在测试启动期间连接文件更好的方法。如果你知道一个,请回复。

有用的资源是:

于 2011-07-06T00:54:42.250 回答