test_helper.rb
1.89 KB
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
require_relative "../../../lib/noosfero/api/helpers"
class ActiveSupport::TestCase
include Rack::Test::Methods
def app
Noosfero::API::API
end
def pass_captcha(mocked_url, captcha_verification_body)
stub_request(:post, mocked_url).
with(:body => captcha_verification_body,
:headers => {'Accept'=>'*/*', 'User-Agent'=>'Ruby'}).
to_return(:status => 200, :body => "1", :headers => {'Content-Length' => 1})
end
def fail_captcha_text(mocked_url, captcha_verification_body)
stub_request(:post, mocked_url).
with(:body => captcha_verification_body,
:headers => {'Accept'=>'*/*', 'User-Agent'=>'Ruby'}).
to_return(:status => 200, :body => "0", :headers => {'Content-Length' => 1})
end
def login_with_captcha
json = do_login_captcha_from_api
@private_token = json["private_token"]
@params = { "private_token" => @private_token}
json
end
## Performs a login using the session.rb but mocking the
## real HTTP request to validate the captcha.
def do_login_captcha_from_api
post "/api/v1/login-captcha"
json = JSON.parse(last_response.body)
json
end
def login_api
@environment = Environment.default
@user = User.create!(:login => 'testapi', :password => 'testapi', :password_confirmation => 'testapi', :email => 'test@test.org', :environment => @environment)
@user.activate
@person = @user.person
post "/api/v1/login?login=testapi&password=testapi"
json = JSON.parse(last_response.body)
@private_token = json["private_token"]
unless @private_token
@user.generate_private_token!
@private_token = @user.private_token
end
@params = {:private_token => @private_token}
end
attr_accessor :private_token, :user, :person, :params, :environment
private
def json_response_ids(kind)
json = JSON.parse(last_response.body)
json[kind.to_s].map {|c| c['id']}
end
end