Интеграционное тестирование с Authlogic? - PullRequest
10 голосов
/ 05 августа 2009

Я не понимаю, почему Authlogic не регистрирует меня в этом интеграционном тесте. У меня не было никаких проблем, когда Authlogic регистрировал меня в функциональных тестах с использованием этого кода. Согласно authlogic rdocs (http://tinyurl.com/mb2fp2),, имитирующее вошедшее в систему состояние одинаково в функциональных и интеграционных тестах, так что я в замешательстве. Любая помощь НАМНОГО ценится!

class TipsController < ApplicationController
  before_filter :require_user,  :only => [:destroy, :undelete]
  def destroy
    @tip = Tip.find(params[:id])

    if can_delete?(@tip)

      @tip.destroy

      set_flash("good", "Tip deleted. <a href=\"#{undelete_tip_url(@tip.id)}\">Undo?</a>")
      respond_to do |format|
        format.html { redirect_to city_path(@tip.city)} 
      end
    else
      set_flash("bad", "Seems like you can't delete this tip, sorry.")
      respond_to do |format|
        format.html { render :action => "show", :id => @tip} 
      end
    end
  end
end


class DeleteTipAndRender < ActionController::IntegrationTest
  context "log user in" do
    setup do
      @user = create_user
      @tip = create_tip
    end

    context "delete tip" do
      setup do
        activate_authlogic
        UserSession.create(@user)
        @us = UserSession.find
        post "/tips/destroy", :id => @tip.id
      end

      should_redirect_to("city_path(@tip.city)"){city_path(@tip.city)} 
    end
  end
end

Ответы [ 9 ]

4 голосов
/ 16 сентября 2009

Я также использую Authlogic с musta (но с factory_girl сверху).

Мои функциональные тесты выглядят так:

require 'test_helper'

class LoansControllerTest < ActionController::TestCase
[...]

  context "as a signed-in user, with an active loan" do
    setup do
      @user = Factory(:user)
      @user_session = UserSession.create(@user)
      @loan = Factory(:loan, :ownership => Factory(:ownership, :user => @user))
    end

    context "on GET to :index" do
      setup do
        get :index
      end

      should_respond_with_success
    end
  end
end

На самом деле, вы МОЖЕТЕ передать действительного пользователя в UserSession, он также находится в rdoc. Вам также следует избегать вызова activ_authlogic в каждом тесте контроллера:

ENV["RAILS_ENV"] = "test"
require File.expand_path(File.dirname(__FILE__) + "/../config/environment")
require 'test_help'

class ActiveSupport::TestCase
  [...]
  # Add more helper methods to be used by all tests here...
  include Authlogic::TestCase

  def setup
    activate_authlogic
  end
end
3 голосов
/ 26 августа 2009

На основе кода в методе user_sessions_controller create, который принимает хэш учетных данных для входа в систему, я смог заставить его работать так в моем интеграционном тесте:

UserSession.create(:email => 'someone@example.com', :password => 'password')

но не с:

UserSession.create(@user)
2 голосов
/ 09 июня 2014

Я не мог заставить его работать с принятым ответом, но был близок. Мне пришлось добавить восклицательный знак в конце функции:

UserSession.create!(@user)

Работает с Ruby v3.2.18 и Authlogic v3.4.2. Спасибо, что указали мне правильное направление.

2 голосов
/ 02 октября 2009

Да, на этой неделе я обнаружил, что с помощью rspec: в функциональных спецификациях вы просто имитируете вход в систему с помощью UserSession.create(@user). Но если вы попробуете это в спецификации интеграции, это не сработает. Чтобы войти в систему из спецификаций интеграции, я обнаружил, что мне нужно было управлять формами (с вебратом), что, очевидно, будет проблемой для таких вещей, как Facebook и OpenID.

2 голосов
/ 03 сентября 2009

Я обнаружил, что для интеграционных тестов мне нужно войти через сообщение:

setup do
  post 'user_session', :user_session => {:email => 'someone@example.com', :password => 'password'}
end

Это правильно настраивает сеанс, а упомянутый выше метод работает только для меня в функциональных тестах.

0 голосов
/ 04 сентября 2012

У меня была такая же проблема, и я мог ее исправить, войдя в систему вручную (как уже отвечали другие)

Кроме того, мне пришлось исправить мой домен cookie :

Rails использует www.example.com для своих тестов, и, поскольку я установил для домена cookie другое значение в моем application.rb (через config.cookie_domain) сеансовом cookie, созданном после того, как вход в систему был недоступен из последующих запросов.

После установки правильного домена cookie все снова заработало.

0 голосов
/ 28 октября 2010

Для людей, которые находят этот пост в Google и Великой Справедливости - вы должны установить атрибут persitence_token в модели пользователя. Например. Вы можете позвонить @user.reset_persistence_token! и все просто начать работать. :)

0 голосов
/ 17 октября 2010

Я использую решение от Cucumber и James вместе со следующим исправлением, которое сработало для меня:

https://webrat.lighthouseapp.com/projects/10503/tickets/383-reset_session-and-webrat-dont-play-nicely-with-one-another

0 голосов
/ 05 августа 2009

Посмотрите на rdoc .

...