最近,我开始深入研究 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 中运行集成数据库测试?
最佳答案
来自 this forum post ,我发现为什么 db:test:prepare
是一个需要运行的奇怪的、任意的 rake 任务:它与 test
环境有关(相对于 development
和 production
)。在 Padrino 中,这转化为以下代码,它有点晦涩,但也更直观:
$ padrino rake sq:migrate:up -e test
这告诉 Padrino 为测试数据库创建表,这允许规范通过。
关于ruby - Padrino 和 RSpec 不适用于 Sequel?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13328570/