asciinema.org/spec/controllers/sessions_controller_spec.rb
2013-05-28 11:13:01 +02:00

118 lines
2.8 KiB
Ruby

require 'spec_helper'
describe SessionsController do
describe "#create" do
let(:provider) { "twitter" }
let(:uid) { 1234 }
let(:nickname) { "mrFoo" }
before do
OmniAuth.config.mock_auth[:twitter] = {
"provider" => provider,
"uid" => uid,
"info" => { "nickname" => nickname }
}
request.env["omniauth.auth"] = OmniAuth.config.mock_auth[:twitter]
end
context "user exists" do
before do
FactoryGirl.create(:user, :provider => provider, :uid => uid)
get :create, :provider => provider
end
it "should create session" do
session[:user_id].should_not be_nil
@controller.current_user.should_not be_nil
end
it "should redirects user to root url" do
flash[:notice].should == "Logged in!"
should redirect_to(root_url)
end
end
context "user doesn't exist" do
let(:auth) { request.env["omniauth.auth"] }
let(:user) { stub("user", :id => 1, :persisted? => true) }
context "when nickname is not taken" do
it "should call create_with_omniauth" do
User.should_receive(:create_with_omniauth).
with(auth).
and_return(user)
get :create, :provider => provider
end
it "should login user" do
User.stub(:create_with_omniauth).and_return(user)
get :create, :provider => provider
session[:user_id].should_not be_nil
end
end
context "when nicknamne is taken" do
let(:not_saved_user) {
stub_model(User,
:persisted? => false,
:valid? => false,
:uid => uid,
:provider => provider
)
}
before do
User.stub(:create_with_omniauth).and_return(not_saved_user)
end
it "puts uid and provider in session " do
get :create, :provider => provider
session[:new_user][:uid].should == uid
session[:new_user][:provider].should == provider
end
it "renders user/new" do
get :create, :provider => provider
should render_template('users/new')
end
end
end
end
describe "#destroy" do
before do
session[:user_id] = "123"
get :destroy
end
it "should destroy session" do
session[:user_id].should be_nil
@controller.current_user.should be_nil
end
it "should redirects to root_url" do
flash[:notice].should == "Logged out!"
should redirect_to(root_url)
end
end
describe "#failure" do
before do
get :failure
end
it "should redirect to root_url and set error message" do
flash[:alert].should =~ /Authentication failed/
should redirect_to(root_url)
end
end
end