如何对非数据库支持的ActiveModel模型进行单元测试?

时间:2012-12-20 07:05:33

标签: ruby-on-rails unit-testing testing

我有一个基于ActiveModel的类(基于this RailsCast):

class ShareTransactionWizard
  include ActiveModel::Validations
  include ActiveModel::Conversion
  extend ActiveModel::Naming

  attr_accessor :num_issue, :num_for, :type

  validates_presence_of :num_issue, :num_for, :type

  validate :issue_greater_than_for,  if: Proc.new {a | a.type == 'split' }

  def initialize(attributes = {})
    attributes.each do |name, value|
      send("#{name}=", value)
    end
  end

  def persisted?
    false
  end

  def issue_greater_than_for
   if !(num_issue > num_for)
      errors.add(:num_issue, "Split must have issued greater than for")
    end
  end
end

单元测试:

require 'test_helper'

class ShareTransactionWizardTest < ActiveSupport::TestCase
  test "Must have :issue greater than :for if type is 'split'" do
    stw = ShareTransactionWizard.new(num_issue: 1, num_for: 10, type: 'split')
    assert !stw.valid?
  end    
end

当我去进行测试时,它说:

Error:  
test_Must_have_:issue_greater_than_:for_if_type_is_'split'(ShareTransactionWizardTest)
ActiveRecord::StatementInvalid: Mysql2::Error: Table
'companybox_test.share_transaction_wizards' doesn't exist: DELETE FROM    
`share_transaction_wizards`

如何在不尝试删除不存在的表中的记录的情况下运行测试?

1 个答案:

答案 0 :(得分:2)

看起来是因为当我创建模型时,它会在fixtures文件夹中放置一些灯具。删除这些灯具会使错误消失。