summaryrefslogtreecommitdiff
path: root/users/test/functional/sessions_controller_test.rb
blob: 8f2d95c82d563343212855708069b3ae271880d8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
require 'test_helper'

# This is a simple controller unit test.
# We're stubbing out both warden and srp.
# There's an integration test testing the full rack stack and srp
class SessionsControllerTest < ActionController::TestCase

  setup do
    @user = stub :login => "me", :id => 123
    @client_hex = 'a123'
  end

  test "should get login screen" do
    request.env['warden'].expects(:winning_strategy)
    get :new
    assert_response :success
    assert_equal "text/html", response.content_type
    assert_template "sessions/new"
  end

  test "renders json" do
    request.env['warden'].expects(:winning_strategy)
    get :new, :format => :json
    assert_response :success
    assert_json_response :errors => nil
  end

  test "renders warden errors" do
    strategy = stub :message => "Warden auth did not work"
    request.env['warden'].expects(:winning_strategy).returns(strategy)
    get :new, :format => :json
    assert_response :success
    assert_json_response :errors => strategy.message
  end

  # Warden takes care of parsing the params and
  # rendering the response. So not much to test here.
  test "should perform handshake" do
    request.env['warden'].expects(:authenticate!)
    # make sure we don't get a template missing error:
    @controller.stubs(:render)
    post :create, :login => @user.login, 'A' => @client_hex
  end

  test "should authorize" do
    request.env['warden'].expects(:authenticate!)
    handshake = stub(:to_json => "JSON")
    session[:handshake] = handshake
    post :update, :id => @user.login, :client_auth => @client_hex
    assert_nil session[:handshake]
    assert_response :success
    assert_equal handshake.to_json, @response.body
  end

  test "logout should reset warden user" do
    expect_warden_logout
    delete :destroy
    assert_response :redirect
    assert_redirected_to root_url
  end

  def expect_warden_logout
    raw = mock('raw session') do
      expects(:inspect)
    end
    request.env['warden'].expects(:raw_session).returns(raw)
    request.env['warden'].expects(:logout)
  end


end