最近,我开始深入研究 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 中运行集成数据库测试?