2

最近,我开始深入研究 Ruby MVC,以便找到最好、最快、最小的框架来构建我的应用程序。由于对 Rails 不满意,我决定尝试一下Padrino。我也是第一次为一个完整的应用程序尝试由外而内 TDD,因此能够为所有组件编写测试是至关重要的。不幸的是,我无法通过在 Padrino 中制作模型,所以我想知道这是否只是 beta 软件的原因,或者只是我的错误。

我首先使用 Cucumber 和 RSpec 创建我的项目以进行测试,并为我的 ORM 创建 Sequel。

$ padrino g project test -d sequel -t cucumber -c sass -b

接下来,我创建一些模型和迁移:

$ padrino g model user

# ./db/migrate/001_create_users.rb
Sequel.migration do
  change do
    create_table :users do
      primary_key :id
      String :name
      String :password
    end
  end
end

接下来,当然是规范。例如,只是一些简单的事情:

# ./spec/models/user_spec.rb
require 'spec_helper'

describe User do
  it 'can be created' do
    user = User.create
  end
end

现在,迁移并运行规范:

$ padrino rake sq:migrate:up
$ rspec spec

F

Failures:

  1) User can be created
     Failure/Error: user = User.create
     Sequel::DatabaseError:
       SQLite3::SQLException: no such table: users
     # ./spec/models/user_spec.rb:5:in `block (2 levels) in <top (required)>'

Finished in 0.00169 seconds
1 example, 1 failure

Failed examples:

rspec ./spec/models/user_spec.rb:4 # User can be created

这非常令人困惑。正是在这一点上,我认为进入 Padrino 控制台可以帮助我解决这个奇怪的问题。我错了。

$ padrino c
> User.create
  => #<User @values={:id=>1, :name=>nil, :password=>nil}>
> User.all
  => [#<User @values={:id=>1, :name=>nil, :password=>nil}>]

足够公平的结果,但后来我在test环境中尝试:

$ padrino c -e test
> User.create
  Sequel::DatabaseError: SQLite3::SQLException: no such table: users

我知道在 RoR 中,要让集成模型运行,您必须执行类似的操作rake db:test:prepare,但这样做padrino rake -T似乎并没有显示任何等效项(使用 Sequel、DataMapper 和 ActiveRecord 进行测试;似乎没有一个具有db:test:prepare)。所以,我的问题是:如何在 Padrino 中运行集成数据库测试?

4

1 回答 1

6

这个论坛帖子中,我发现了为什么 db:test:prepare需要运行这个奇怪的、任意的 rake 任务:它与test环境有关(相对于developmentand production)。在 Padrino 中,这转换为以下代码,虽然有点晦涩,但也更直观:

$ padrino rake sq:migrate:up -e test

这告诉 Padrino 为测试数据库创建表,这允许规范通过。

于 2012-11-11T17:03:22.770 回答