ruby on rails - एपीसी टेस्ट में डेविस के साथ प्रमाणीकरण



ruby-on-rails rspec (1)

उन वस्तुओं पर सही तरीके से चलाने के लिए मुझे अपना रुपेपिक परीक्षण प्राप्त करने में समस्या हो रही है, जहां पहले उपयोगकर्ता से उपयोगकर्ता के पहले_फिलटर प्रमाणित करने का प्रयास किया जा रहा है

मैं डिविसे गिट विकी से उदाहरण का पालन करता हूं: कैसे करें: रेल 3 (और आरएसपीईसी) के साथ नियंत्रकों और दृश्य परीक्षण

कल्पना / spec_helper.rb:

# This file is copied to spec/ when you run 'rails generate 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.include Devise::TestHelpers, :type => :controller
   config.extend ControllerMacros, :type => :controller
   config.fixture_path = "#{::Rails.root}/spec/fixtures"
   config.use_transactional_fixtures = true
   config.infer_base_class_for_anonymous_controllers = false
end

कल्पना / support / controller_macros.rb:

 module ControllerMacros
   def login_user
     before(:each) do
       @request.env["devise.mapping"] = Devise.mappings[:user]
       user = FactoryGirl.create(:user)
       sign_in user
     end
   end
 end

कल्पना / नियंत्रक / test.rb:

require 'spec_helper'
describe ProjectsController do
  def valid_attributes
    {
    :name         => 'Project',
    :description  => 'Description'
    }
  end

  def valid_session
    {}
  end

  describe "Test" do

    login_user

    it "assigns all projects as @projects" do
      # test passes if the following line is here, otherwise fails
      subject.current_user.should_not be_nil

      project = Project.create! valid_attributes
      get :index, {}, valid_session
      assigns(:projects).should eq([project])
    end
  end
end

ऐप / नियंत्रक / प्रोजेक्ट_कंट्रोलर.आरबी (सीधे फिल्टर से पहले के अलावा जनरेटर से:

class ProjectsController < ApplicationController

  before_filter :authenticate_user!

  # GET /projects
  # GET /projects.json
  def index
    @projects = Project.all

    respond_to do |format|
      format.html # index.html.erb
      format.json { render json: @projects }
    end
  end

  # GET /projects/1
  # GET /projects/1.json
  def show
    @project = Project.find(params[:id])

    respond_to do |format|
      format.html # show.html.erb
      format.json { render json: @project }
    end
  end

  # GET /projects/new
  # GET /projects/new.json
  def new
    @project = Project.new

    respond_to do |format|
      format.html # new.html.erb
      format.json { render json: @project }
    end
  end

  # GET /projects/1/edit
  def edit
    @project = Project.find(params[:id])
  end

  # POST /projects
  # POST /projects.json
  def create
    @project = Project.new(params[:project])

    respond_to do |format|
      if @project.save
        format.html { redirect_to @project, notice: 'Project was successfully created.' }
        format.json { render json: @project, status: :created, location: @project }
      else
        format.html { render action: "new" }
        format.json { render json: @project.errors, status: :unprocessable_entity }
      end
    end
  end

  # PUT /projects/1
  # PUT /projects/1.json
  def update
    @project = Project.find(params[:id])

    respond_to do |format|
      if @project.update_attributes(params[:project])
        format.html { redirect_to @project, notice: 'Project was successfully updated.' }
        format.json { head :ok }
      else
        format.html { render action: "edit" }
        format.json { render json: @project.errors, status: :unprocessable_entity }
      end
    end
  end

  # DELETE /projects/1
  # DELETE /projects/1.json
  def destroy
    @project = Project.find(params[:id])
    @project.destroy

    respond_to do |format|
      format.html { redirect_to projects_url }
      format.json { head :ok }
    end
  end
end

परीक्षा क्यों पास करती है subject.current_user.should_not be_nil को शामिल करने के साथ लेकिन विफल हो जाता है जब यह शामिल नहीं है?


जब आप का उल्लेख करते हैं तो मैं उसी समस्या में गया था । इसका समाधान हर अनुरोध से valid_session को कॉल निकालने के लिए है, चूंकि यह sign_in सहायक द्वारा निर्धारित सत्र मानों को ओवरराइड करता है।

यह वास्तव में एक कोड-ब्लॉक में प्रलेखित किया गया है जिस तरह से, मैं इसे भी याद किया :(





devise