Chris@0
|
1 # Redmine - project management software
|
Chris@1494
|
2 # Copyright (C) 2006-2014 Jean-Philippe Lang
|
Chris@0
|
3 #
|
Chris@0
|
4 # This program is free software; you can redistribute it and/or
|
Chris@0
|
5 # modify it under the terms of the GNU General Public License
|
Chris@0
|
6 # as published by the Free Software Foundation; either version 2
|
Chris@0
|
7 # of the License, or (at your option) any later version.
|
Chris@909
|
8 #
|
Chris@0
|
9 # This program is distributed in the hope that it will be useful,
|
Chris@0
|
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
|
Chris@0
|
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
Chris@0
|
12 # GNU General Public License for more details.
|
Chris@909
|
13 #
|
Chris@0
|
14 # You should have received a copy of the GNU General Public License
|
Chris@0
|
15 # along with this program; if not, write to the Free Software
|
Chris@0
|
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
Chris@0
|
17
|
Chris@119
|
18 require File.expand_path('../../test_helper', __FILE__)
|
Chris@0
|
19
|
Chris@0
|
20 class TokenTest < ActiveSupport::TestCase
|
Chris@0
|
21 fixtures :tokens
|
Chris@0
|
22
|
Chris@0
|
23 def test_create
|
Chris@0
|
24 token = Token.new
|
Chris@0
|
25 token.save
|
Chris@0
|
26 assert_equal 40, token.value.length
|
Chris@0
|
27 assert !token.expired?
|
Chris@0
|
28 end
|
Chris@909
|
29
|
Chris@0
|
30 def test_create_should_remove_existing_tokens
|
Chris@0
|
31 user = User.find(1)
|
Chris@0
|
32 t1 = Token.create(:user => user, :action => 'autologin')
|
Chris@0
|
33 t2 = Token.create(:user => user, :action => 'autologin')
|
Chris@0
|
34 assert_not_equal t1.value, t2.value
|
Chris@0
|
35 assert !Token.exists?(t1.id)
|
Chris@0
|
36 assert Token.exists?(t2.id)
|
Chris@0
|
37 end
|
Chris@1115
|
38
|
Chris@1115
|
39 def test_destroy_expired_should_not_destroy_feeds_and_api_tokens
|
Chris@1115
|
40 Token.delete_all
|
Chris@1115
|
41
|
Chris@1115
|
42 Token.create!(:user_id => 1, :action => 'api', :created_on => 7.days.ago)
|
Chris@1115
|
43 Token.create!(:user_id => 1, :action => 'feeds', :created_on => 7.days.ago)
|
Chris@1115
|
44
|
Chris@1115
|
45 assert_no_difference 'Token.count' do
|
Chris@1115
|
46 assert_equal 0, Token.destroy_expired
|
Chris@1115
|
47 end
|
Chris@1115
|
48 end
|
Chris@1115
|
49
|
Chris@1115
|
50 def test_destroy_expired_should_destroy_expired_tokens
|
Chris@1115
|
51 Token.delete_all
|
Chris@1115
|
52
|
Chris@1115
|
53 Token.create!(:user_id => 1, :action => 'autologin', :created_on => 7.days.ago)
|
Chris@1115
|
54 Token.create!(:user_id => 2, :action => 'autologin', :created_on => 3.days.ago)
|
Chris@1115
|
55 Token.create!(:user_id => 3, :action => 'autologin', :created_on => 1.hour.ago)
|
Chris@1115
|
56
|
Chris@1115
|
57 assert_difference 'Token.count', -2 do
|
Chris@1115
|
58 assert_equal 2, Token.destroy_expired
|
Chris@1115
|
59 end
|
Chris@1115
|
60 end
|
Chris@1464
|
61
|
Chris@1464
|
62 def test_find_active_user_should_return_user
|
Chris@1464
|
63 token = Token.create!(:user_id => 1, :action => 'api')
|
Chris@1464
|
64 assert_equal User.find(1), Token.find_active_user('api', token.value)
|
Chris@1464
|
65 end
|
Chris@1464
|
66
|
Chris@1464
|
67 def test_find_active_user_should_return_nil_for_locked_user
|
Chris@1464
|
68 token = Token.create!(:user_id => 1, :action => 'api')
|
Chris@1464
|
69 User.find(1).lock!
|
Chris@1464
|
70 assert_nil Token.find_active_user('api', token.value)
|
Chris@1464
|
71 end
|
Chris@1464
|
72
|
Chris@1464
|
73 def test_find_user_should_return_user
|
Chris@1464
|
74 token = Token.create!(:user_id => 1, :action => 'api')
|
Chris@1464
|
75 assert_equal User.find(1), Token.find_user('api', token.value)
|
Chris@1464
|
76 end
|
Chris@1464
|
77
|
Chris@1464
|
78 def test_find_user_should_return_locked_user
|
Chris@1464
|
79 token = Token.create!(:user_id => 1, :action => 'api')
|
Chris@1464
|
80 User.find(1).lock!
|
Chris@1464
|
81 assert_equal User.find(1), Token.find_user('api', token.value)
|
Chris@1464
|
82 end
|
Chris@1464
|
83
|
Chris@1464
|
84 def test_find_token_should_return_the_token
|
Chris@1464
|
85 token = Token.create!(:user_id => 1, :action => 'api')
|
Chris@1464
|
86 assert_equal token, Token.find_token('api', token.value)
|
Chris@1464
|
87 end
|
Chris@1464
|
88
|
Chris@1464
|
89 def test_find_token_should_return_the_token_with_validity
|
Chris@1464
|
90 token = Token.create!(:user_id => 1, :action => 'api', :created_on => 1.hour.ago)
|
Chris@1464
|
91 assert_equal token, Token.find_token('api', token.value, 1)
|
Chris@1464
|
92 end
|
Chris@1464
|
93
|
Chris@1464
|
94 def test_find_token_should_return_nil_with_wrong_action
|
Chris@1464
|
95 token = Token.create!(:user_id => 1, :action => 'feeds')
|
Chris@1464
|
96 assert_nil Token.find_token('api', token.value)
|
Chris@1464
|
97 end
|
Chris@1464
|
98
|
Chris@1464
|
99 def test_find_token_should_return_nil_without_user
|
Chris@1464
|
100 token = Token.create!(:user_id => 999, :action => 'api')
|
Chris@1464
|
101 assert_nil Token.find_token('api', token.value)
|
Chris@1464
|
102 end
|
Chris@1464
|
103
|
Chris@1464
|
104 def test_find_token_should_return_nil_with_validity_expired
|
Chris@1464
|
105 token = Token.create!(:user_id => 999, :action => 'api', :created_on => 2.days.ago)
|
Chris@1464
|
106 assert_nil Token.find_token('api', token.value, 1)
|
Chris@1464
|
107 end
|
Chris@0
|
108 end
|