Kyl*_*acy 2 ruby model-view-controller rspec padrino sequel
最近,我开始深入研究Ruby MVC,以便找到最好,最快,最小的框架来构建我的应用程序.由于对Rails不满意,我决定尝试Padrino.我也是第一次尝试使用Outside-in TDD获取完整的应用程序,因此能够为所有组件编写测试至关重要.不幸的是,我无法在Padrino中制作模型,所以我想知道它是否只是测试版软件的原因,或者只是我的错误.
我首先使用Cucumber和RSpec创建我的项目进行测试,然后为我的ORM创建Sequel.
$ padrino g project test -d sequel -t cucumber -c sass -b
Run Code Online (Sandbox Code Playgroud)
接下来,我创建一些模型和迁移:
$ 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
Run Code Online (Sandbox Code Playgroud)
接下来,当然是规范.例如,只是简单的事情:
# ./spec/models/user_spec.rb
require 'spec_helper'
describe User do
it 'can be created' do
user = User.create
end
end
Run Code Online (Sandbox Code Playgroud)
现在,迁移并运行规范:
$ 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
Run Code Online (Sandbox Code Playgroud)
这非常令人困惑.正是在这一点上,我认为进入Padrino控制台将帮助我解决这个奇怪的问题.我错了.
$ padrino c
> User.create
=> #<User @values={:id=>1, :name=>nil, :password=>nil}>
> User.all
=> [#<User @values={:id=>1, :name=>nil, :password=>nil}>]
Run Code Online (Sandbox Code Playgroud)
足够公平的结果,但后来我尝试了test环境:
$ padrino c -e test
> User.create
Sequel::DatabaseError: SQLite3::SQLException: no such table: users
Run Code Online (Sandbox Code Playgroud)
我知道在RoR中,为了让集成模型运行,你必须做类似的事情rake db:test:prepare,但做padrino rake -T似乎没有透露任何等价物(用Sequel,DataMapper和ActiveRecord测试;似乎没有db:test:prepare).所以,我的问题是:如何在Padrino中运行集成数据库测试?
从这个论坛帖子中,我发现为什么 db:test:prepare需要运行这个奇怪的,任意的rake任务:它与test环境有关(与development和有关production).在Padrino中,这转换为以下代码,这些代码更加模糊,但也更直观:
$ padrino rake sq:migrate:up -e test
Run Code Online (Sandbox Code Playgroud)
这告诉Padrino为测试数据库创建表,允许spec(s)通过.