Как проверить дочернее создание в иерархических родительско-дочерних отношениях с Rspe c / Rails 5.2? - PullRequest
0 голосов
/ 06 апреля 2020

Мое приложение управляет BusinessFlow, которое может быть создано только в родительской BusinessArea. «Новый» метод в контроллере BusinessFlows:

  def new
    @business_area = BusinessArea.find(params[:business_area_id])
    @business_flow = BusinessFlow.new
  end

Фабрика, используемая для тестирования, работает нормально, создает родительскую BusinessArea и BusinessFlow, как и ожидалось:

FactoryBot.define do
  factory :business_flow do
    association :parent,  factory: :business_area
    playground_id       {0}
    name                {"Test Business Flow"}
    code                {Faker::Code.unique.rut}
    description         {"This is a test Business Flow used for unit testing"}
    created_by          {"Fred"}
    updated_by          {"Fred"}
    owner_id            {0}
    responsible_id      {0}
    deputy_id           {0}
    organisation_id     {0}
    status_id           {0}
  end
end

Но когда дело доходит до проверки возможности отображения «нового» представления, контроллер выдает ошибку из-за пропущенных параметров [: business_area_id]:

 ActiveRecord::RecordNotFound:
   Couldn't find BusinessArea without an ID

Вот сценарий тестирования возможностей :

require 'rails_helper'

RSpec.describe BusinessFlow, type: :request do
  include Warden::Test::Helpers

  describe "Business Flows pages: " do
    let(:bf) {FactoryBot.create(:business_flow)}

    context "when not signed in " do
      it "should propose to log in when requesting index view" do
        get business_flows_path
        follow_redirect!
        expect(response.body).to include('Sign in')
      end
      it "should propose to log in when requesting new view" do
        get new_business_flow_path
        follow_redirect!
        expect(response.body).to include('Sign in')
      end
      it "should propose to log in when requesting edit view" do
        get edit_business_flow_path(bf)
        follow_redirect!
        expect(response.body).to include('Sign in')
      end
      it "should propose to log in when requesting show view" do
        get business_flow_path(bf)
        follow_redirect!
        expect(response.body).to include('Sign in')
      end
    end
    context "when signed in" do
      before do
        get "/users/sign_in"
        test_user = FactoryBot.create(:user)
        login_as test_user, scope: :user
      end
      it "should display index" do
        get business_flows_path
        expect(response).to render_template(:index)
      end
      it "should display new view" do
        get new_business_flow_path(bf.parent.id)
        expect(response).to render_template(:_form)
      end
      it "should display edit view" do
        get edit_business_flow_path(bf)
        expect(response).to render_template(:_form)
      end
      it "should display show view" do
        get business_flow_path(bf)
        expect(response).to render_template(:show)
      end
    end
  end
end

Только «новый» метод теста в контексте «при входе» не проходит. Можете ли вы помочь мне решить эту проблему?

Большое спасибо!

1 Ответ

0 голосов
/ 06 апреля 2020
 it "should display new view" do
     get new_business_flow_path(business_area_id: bf.parent)
     expect(response).to render_template(:_form)
 end

Rails думает, что передаваемый вами идентификатор является частью пути бизнес-потока (а это не так), я думаю, его нужно передать как параметр.

...