Rspec возвращает "PG:: Ошибка: ERROR: отношение" table_name "не существует"
Среда - это REE (2011.12) на rvm, rspec 2.8.0, rails 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 series до 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
, но это не удалось. Есть ли у вас какие-либо идеи?
Похоже, тест не запускался в тестовой базе данных... Как мне это сделать?: (
Ответы
Ответ 1
Я столкнулся с этим в двух экземплярах (обновлено 6/13/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
Ответ 2
Обычно это происходит, когда во время миграции выполняется rspec (обычно с помощью защитного устройства). Простое решение - выйти из режима охраны, выполнить миграцию и перезапустить сторож.
Ответ 3
Обычно это указывает на наличие другого открытого соединения 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)
Ответ 4
Просто нажмите эту же ошибку, ничего не сработало, но отбросило и заново создало базу данных, это исправило это для меня.
rake db:drop db:create db:migrate