rspec возвращает «PG :: Ошибка: ОШИБКА: отношение« имя_таблицы »не существует» - PullRequest
11 голосов
/ 05 марта 2012

Среда представляет собой REE (2011.12) для rvm, rspec 2.8.0, рельсов 3.0.6 и pg 0.13.2.Использование PostgreSQL 8.3.17 в CentOS 5.6.Db: migrate работает правильно.Но у rspec есть следующая ошибка.

1) ApiController articles OK
 Failure/Error: Unable to find matching line from backtrace
 ActiveRecord::StatementInvalid:
   PG::Error: ERROR:  relation "table_name" does not exist
   : DELETE FROM "table_name"

Я обновляю свой проект с rails 2.3.5 с серией rspec 1.x до rails 3.0 с rspec2.Скопировал все тесты rspec, и я объединил старый spec_helper.rb и новый (он был сгенерирован rails g rspec:install).

ENV["RAILS_ENV"] ||= 'test'
require File.expand_path("../../config/environment", __FILE__)
require 'rspec/rails'
require 'rspec/autorun'

Dir[Rails.root.join("spec/support/**/*.rb")].each {|f| require f}

RSpec.configure do |config|

  config.fixture_path = "#{::Rails.root}/spec/fixtures"
  config.use_transactional_fixtures = true

end

Я прочитал похожий вопрос об этой ошибке. Поэтому я попытался rake db:test:prepare или rake db:test:load, но это не решимость.Есть ли у вас какие-либо идеи?Похоже, тест не запускался на тестовой базе данных ... Как мне это сделать?(

Ответы [ 4 ]

26 голосов
/ 16 марта 2012

Я столкнулся с этим в двух случаях (обновлено 13.06.2012):

Первое:

Я еще не перенес свою тестовую базу данных ...

rake db:migrate

... что вам нужно сделать, прежде чем db:test:prepare и db:test:load.

Когда вы вызываете rspec, он должен prepare и load вашБаза данных для вас в любом случае.Вам не нужно делать это вручную.

Второе:

Опечатка в моей миграции.Я случайно изменил имена своих таблиц и столбцов в списке параметров.

Миграция в проекте Rails 3.1:

def change
  add_column :had_import_errors, :studies, :boolean, :default => false
  add_column :import_data_cache, :studies, :text
end

... что неправильно , потому чтоhas_import_errors и import_data_cache являются именами моих столбцов, и поэтому они должны стоять на втором месте, а не на первом.

Правильная миграция с первым именем таблицы:

def change
  add_column :studies, :had_import_errors, :boolean, :default => false
  add_column :studies, :import_data_cache, :text
end
4 голосов
/ 15 февраля 2013

Это обычно происходит, когда у вас работает rspec во время миграции (обычно через охрану).Простое решение - выйти из охраны, выполнить миграцию и перезапустить охрану.

3 голосов
/ 19 марта 2012

Обычно это означает, что существует другое открытое соединение PostgreSql. Чтобы исправить ошибку, попробуйте % rake db:test:prepare

Запуск подготовки к тестированию показал следующее ниже, и когда открытое соединение (в моем случае PGAdmin) было закрыто, проблема была решена.

rake aborted!
PG::Error: ERROR:  database "xyz_test" is being accessed by other users
DETAIL:  There are 1 other session(s) using the database.
: DROP DATABASE IF EXISTS "xyz_test"

Tasks: TOP => db:test:load => db:test:purge
(See full trace by running task with --trace)
1 голос
/ 27 января 2015

Просто нажмите на ту же ошибку, ничего не получалось, кроме удаления и повторного создания базы данных, это исправило ее для меня.

rake db:drop db:create db:migrate

...