Rails 3 Rspec Ошибка - SQLite3 :: SQLException: нет такого столбца: comments.article_id - PullRequest
0 голосов
/ 07 сентября 2010

Я пытаюсь проверить удаление комментариев с помощью Rspec.Я думаю, что мой тест неверен, потому что когда я пытаюсь удалить комментарий в своем браузере, он работает.

Вот тест Rspec, который я запускаю:

before(:each) do
    @admin = Factory(:user, :admin => true)
    @user = Factory(:user, :email => "example1@example.com")
    @article = Factory(:article, :user => @user, :title => "Article Title", :content => "Article Content")
    @comment = Factory(:comment, :user => @user, :article => @article, :title => "Comment Title", :content => "Comment Content")
  end

  it "should allow access to 'destroy'" do
    lambda do
      delete :destroy, :id => @comment, :article_id => @article
    end.should change(Comment, :count).by(-1)
  end

Вот ошибкаЯ получаю:

1) CommentsController access control for admin should allow access to 'destroy'
    Failure/Error: delete :destroy, :id => @comment, :article_id => @article
    SQLite3::SQLException: no such column: comments.article_id: SELECT     "comments"."id", "comments"."parent_id", "comments"."title", "comments"."content", "comments"."user_id", "comments"."created_at", "comments"."updated_at" FROM       "comments" WHERE     ("comments".article_id = 1) AND ("comments"."id" = 1) ORDER BY  comments.created_at DESC LIMIT 1

Вот часть уничтожения моего контроллера комментариев:

  def destroy
    @article = Article.find(params[:article_id])
    if @article.comments.find(params[:id]).destroy
      flash[:success] = "Comment deleted."
    else
      flash[:error] = "Comment could not be deleted."
    end
    redirect_to @article
  end

Вот часть создания моего контроллера комментариев:

  def create
    @article = Article.find(params[:article_id])
    @comment = @article.comments.build(params[:comment])
    @comment.user_id = current_user.id
    @comment.article_id = @article.id
    if @comment.save
      flash[:success] = "Comment saved."
      redirect_to @article
    else
      flash[:error] = "Error in creating comment."
      @comments = @article.comments.paginate(:page => params[:page])
      render 'articles/show'
    end
  end

Iявно установите @ comment.article_id = @ article.id, поэтому я не знаю, почему он сказал бы, что столбца не существует ...

Ответы [ 2 ]

0 голосов
/ 15 февраля 2011

У меня была похожая проблема с моими тестами, показывающими, что я не могу получить страницу, потому что таблица не существует.Я смог решить ее, запустив rake db:test:prepare, а затем запустив Rspec.

0 голосов
/ 10 сентября 2010

Может быть, тестовая база данных не синхронизирована?Вы пробовали проверить схему в тестовой базе данных, чтобы увидеть, есть ли там столбец?

...