最近,我开始深入研究ruby mvcs,以便找到构建我的应用程序的最佳、最快、最简单的框架。由于对rails不满意,我决定尝试Padrino。我还在TDD中首次尝试完整的应用程序,因此能够为所有组件编写测试是至关重要的。不幸的是,我无法通过在帕德里诺制作模型,所以我想知道这是否只是测试版软件的原因,或者只是我的错误。
首先,我用cucumber和rspec创建了一个项目,用于测试orm和续集。
$ 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 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中,我发现了为什么需要运行这个奇怪的、任意的rake任务:它与db:test:prepare
环境有关(与test
和development
相比)。在padrino中,这将转换为下面的代码,这些代码更加模糊,但也更加直观:
$ padrino rake sq:migrate:up -e test
这告诉padrino为测试数据库创建表,从而允许规范通过。
关于ruby - Padrino和RSpec不能与Sequel一起使用吗?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13328570/