Rspe c для контроллера сессий - PullRequest
0 голосов
/ 20 января 2020

Я пытаюсь написать rspe c для контроллера сессий. Но я не могу этого сделать.

Я хотел проверить контроллер на допустимые и недействительные допустимые атрибуты. Тесты должны пройти, если допустимые атрибуты переданы для конкретного пользователя, и не пройдут, если недопустимые атрибуты переданы для данного пользователя.

require 'rails_helper'

RSpec.describe SessionsController, type: :controller do

   let(:user)  { User.create(name: "some",email: 'other@example.com', password: 'rous',password_confirmation: "some") } 

     describe "get login path" do
        it "login page" do
            get :new
            expect(response).to render_template('sessions/new')
        end
     end

         describe "valid attributes" do
   it "create a session" do 
        post :create, session: { email: user.email, password: user.password }
        expect(response.status).to render_template('/users/@user.id')
   end
 end

 describe "invalid attributes" do
    it "does not create a session" do 
        post :create, session: { email: user.email, password: "12345" }
        expect(response.status).to render_template('sessions/new')
    end
 end


     describe "does not create a session" do

        it "if email is empty" do 
            post :create, session: {password: "some"}
            expect(response.status).to render_template('sessions/new')
        end

        it "if password is empty" do 
            post :create, session: {email: "some@gmail.com"}
            expect(response.status).to render_template('sessions/new')
        end

     end
end

Описать «недействительные атрибуты» и «действительные атрибуты» не работают нормально.

Если адрес электронной почты / пароль неверны, пользователь перенаправляется на сессию № новой страницы.

Если адрес электронной почты и пароль верны, пользователь должен быть перенаправлен на user_path, т. Е. Пользователи показывают страницу.

1 Ответ

0 голосов
/ 20 января 2020

Вы должны действительно использовать запрос или функцию spe c вместо этого, поскольку они управляют полным стеком. Вы не только хотите проверить, что ваш контроллер перенаправляет куда-то - вы действительно хотите проверить, что перенаправляет куда-то и регистрирует пользователя. Желательно, не вставляя во внутренние органы или высмеивая фактический процесс аутентификации, который вы должны тестировать в первую очередь. ,

Обе команды RSpe c и Rails отказываются от написания тестов / спецификаций контроллера для новых приложений. Проверьте поведение вашего приложения. Не так, как он выполняет свою работу.

require "rails_helper"

RSpec.feature "User sign in", type: :feature do

  let!(:user) { FactoryBot.create(:user) }

  scenario "User signs in with valid crentials" do
    visit "/sessions/new"
    fill_in "Email", with: user.email
    fill_in "Password", with: user.password
    click_button "Sign In"
    expect(page).to have_text "You have been signed in"
  end

  scenario "User signs in with invalid crentials" do
    visit "/sessions/new"
    fill_in "Email", with: user.email
    fill_in "Password", with: "nottherightpassword"
    click_button "Sign In"
    expect(page).to_not have_text "You have been signed in"
    expect(page).to have_text "Invalid email or password"
  end
end

Или как запрос более низкого уровня spe c:

require "rails_helper"

RSpec.describe "Sessions", type: :request do

  let!(:user) { FactoryBot.create(:user) }

  describe "POST /sessions" do

    context "with valid credentials" do
      it "redirects the user" do
        post '/sessions', 
          params: { session: { email: user.email, password: user.password } }
        expect(response).to redirect_to user_path(user)
        follow_redirect!
        expect(response.body).to include("You have been signed in")
      end
    end

    context "with invalid credentials" do
      it "does not redirect the user" do
        post '/sessions', 
          params: { session: { email: user.email, password: "nottherightpassword" } }
        expect(response).to_not redirect_to user_path(user)
        expect(response.body).to include("Invalid email or password")
      end
    end
  end
end
...