Как создать тесты RSpec для следующего кода - PullRequest
0 голосов
/ 28 марта 2019

Мне нужно создать тестирование RSpec для следующего кода ruby ​​и, похоже, я сталкиваюсь с проблемами при каждой попытке. Мне бы понравился пример или два теста RSpec, которые можно было бы создать для следующего кода / методов, которые есть в моем контроллере:

  def edit
    @movie = Movie.find params[:id]
  end
   def update
    @movie = Movie.find params[:id]
    @movie.update_attributes!(movie_params)
    flash[:notice] = "#{@movie.title} was successfully updated."
    redirect_to movie_path(@movie)
  end
   def destroy
    @movie = Movie.find(params[:id])
    @movie.destroy
    flash[:notice] = "Movie '#{@movie.title}' deleted."
    redirect_to movies_path
  end
   def find_with_same_director
    @movie = Movie.find(params[:id])
    @movies, check_info = Movie.find_with_same_director(params[:id])
    if check_info
      flash[:notice] = "'#{@movie.title}' has no director info"
      redirect_to movies_path
    end
  end

Пока у меня есть это:

RSpec.describe MoviesController, type: :controller do
  it 'should get all movies in the database' do
      get :index
      expect(response).to render_template :index
      expect(assigns[:movies]).to eq(Movie.all)
  end
  describe 'find_with_same_director' do
    it 'should call the find_with_same_director model method' do
      expect(Movie).to receive(:find_with_same_director).with(no_args)
      get :find_with_same_director, id: movie.id
    end
  end
end

но он не покрывает это правильно. Любая помощь будет оценена, спасибо.

1 Ответ

0 голосов
/ 28 марта 2019
RSpec.describe MoviesController, type: :controller do
 it 'should get all movies in the database' do
    get :index
    expect(response).to render_template :index
    expect(assigns[:movies]).to eq(Movie.all)
 end

 it 'should update movie in the database' do
   Factory.girl.create(:movie)
   before_movie_count = Movie.count

   put :update, id: movie.id

   expect(assigns[:movies]).to eq(...) # whatever data is passed

   expect(Movie.count).to eq(before_ml_count)
   expect(flash[:snack_class]).to eq(:notice.to_s)
   expect(flash[:snack_message]).to ends_with('was successfully updated')
   expect(response).to have_http_status(:redirect)
 end

 it 'should delete movie in the database' do
    Factory.girl.create(:movie)
    before_movie_count = Movie.count

    delete :update, id: movie.id

    expect(Movie.count).to eq(before_ml_count - 1)
    expect(flash[:snack_class]).to eq(:notice.to_s)
    expect(flash[:snack_message]).to ends_with('deleted')
    expect(response).to have_http_status(:redirect)
 end

 describe 'find_with_same_director' do
   it 'should call the find_with_same_director model method' do
     expect(Movie).to receive(:find_with_same_director).with(no_args)
     get :find_with_same_director, id: movie.id
   end
 end
end


#### in factory movie.rb

FactoryGirl.define do
  factory :movie do
    # assign data to movie attributes here.
  end
end
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...