2

Ruby 1.9.3 で Rails 3.2.13 を使用しています。次のエラーが発生し続けます。

Failure/Error: @user = Fabricate :user, role_ids: [role.id]
PG::Error:
   incomplete multibyte character
 # ./spec/controllers/api_controllers/projects_controller_spec.rb:6:in `block (2 levels) in <top (required)>'

このエラーでイライラするのは、断続的に発生することです。テストを 10 回実行しても発生しない場合もあれば、毎回発生する場合もあります。

エラーが発生した projects_controller_spec.rb ファイルの 6 行目付近のコードは次のようになります。

require 'spec_helper'

describe Api::V1::ProjectsController do
  before do
    role = Fabricate :data_collector_role
    @user = Fabricate :user, role_ids: [role.id] # this is line 6
    @project = Fabricate.build(:project, proposal: Fabricate(:full_proposal))
    @project.save(validate: false)
    @permission = Fabricate :permission, user: @user, project: @project
    @project2 = Fabricate.build(:project, proposal: Fabricate(:full_proposal))
    @project2.save(validate: false)
    request.env["HTTP_ACCEPT"] = 'application/json'
    request.env['HTTP_AUTHORIZATION'] =   ActionController::HttpAuthentication::Token.encode_credentials(@user.api_key)
  end

上記の 6 行目で呼び出される Fabricator は次のようになります。

Fabricator :user do
    username { sequence(:username) { |n| "foo#{n}" } }
    password 'foobar'
    password_confirmation 'foobar'
    email_address "user@example.com"
    home_phone "123456789"
    work_phone "456789189"
    sales_channel
end

API コントローラー用ではない他の仕様で同じコードが呼び出され、100% の時間で動作します。

ときどき RSPEC が完全にクラッシュし、次のエラーが発生します。

     Failure/Error: get :show, { id: @project.id }
     ActiveRecord::StatementInvalid:
/Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/formatters/base_text_formatter.rb:182:in `split': invalid byte sequence in UTF-8 (ArgumentError)
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/formatters/base_text_formatter.rb:182:in `dump_failure_info'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/formatters/base_text_formatter.rb:175:in `dump_failure'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/formatters/base_text_formatter.rb:19:in `block in dump_failures'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/formatters/base_text_formatter.rb:17:in `each'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/formatters/base_text_formatter.rb:17:in `each_with_index'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/formatters/base_text_formatter.rb:17:in `dump_failures'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/reporter.rb:98:in `block in notify'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/reporter.rb:97:in `each'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/reporter.rb:97:in `notify'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/reporter.rb:81:in `finish'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/reporter.rb:36:in `report'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/command_line.rb:25:in `run'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/runner.rb:66:in `rescue in run'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/runner.rb:62:in `run'
from /Users/michael/.rvm/gems/ruby-1.9.3-p448/gems/rspec-core-2.11.1/lib/rspec/core/runner.rb:8:in `block in autorun'
4

1 に答える 1

0

これをファイル spec/controllers/api_controllers/projects_controller_spec.rb の先頭に追加します

# !/usr/bin/env ruby
# encoding: utf-8
于 2014-01-29T04:04:17.907 に答える