最近,我开始深入研究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环境有关(与testdevelopment相比)。在padrino中,这将转换为下面的代码,这些代码更加模糊,但也更加直观:

$ padrino rake sq:migrate:up -e test

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

关于ruby - Padrino和RSpec不能与Sequel一起使用吗?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13328570/

10-13 08:57