woople-session 0.0.1 → 0.0.2

Sign up to get free protection for your applications and to get access to all the features.
@@ -4,6 +4,7 @@ require 'bundler/setup'
4
4
  require 'woople-session/version'
5
5
  require 'woople-session/base'
6
6
  require 'woople/tokenizer'
7
+ require 'woople/login_helper'
7
8
 
8
9
  module Woople
9
10
  class Session
@@ -1,5 +1,5 @@
1
1
  module Woople
2
2
  class Session
3
- VERSION = "0.0.1"
3
+ VERSION = "0.0.2"
4
4
  end
5
5
  end
@@ -0,0 +1,9 @@
1
+ module Woople
2
+ module LoginHelper
3
+ def login_as(object = {})
4
+ token = Woople::Tokenizer.new(ENV['WOOPLE_KEY'], ENV['WOOPLE_SECRET'], object)
5
+ visit sso_path(:token => CGI.unescape(token.sso_token))
6
+ end
7
+ end
8
+ end
9
+
@@ -0,0 +1,25 @@
1
+ require 'spec_helper'
2
+ require_relative '../../lib/woople/login_helper'
3
+
4
+ class FeatureStep
5
+ include Woople::LoginHelper
6
+ end
7
+
8
+ describe FeatureStep do
9
+ it "visits sso path" do
10
+ time = Time.current + 1.hour
11
+ user_info = { name: 'Cameron', expires_at: time }
12
+
13
+ token = stub(sso_token: 'token')
14
+ sso_path = stub
15
+ unescaped_token = stub
16
+
17
+ Woople::Tokenizer.should_receive(:new).with(ENV['WOOPLE_KEY'], ENV['WOOPLE_SECRET'], user_info) { token }
18
+ CGI.should_receive(:unescape).with(token.sso_token) { unescaped_token }
19
+
20
+ subject.should_receive(:sso_path).with(:token => unescaped_token ).and_return(sso_path)
21
+ subject.should_receive(:visit).with(sso_path)
22
+
23
+ subject.login_as(user_info)
24
+ end
25
+ end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: woople-session
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.1
4
+ version: 0.0.2
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-02-21 00:00:00.000000000 Z
12
+ date: 2012-02-22 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: rspec
16
- requirement: &70117980375940 !ruby/object:Gem::Requirement
16
+ requirement: &70227979191380 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ~>
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '2.8'
22
22
  type: :development
23
23
  prerelease: false
24
- version_requirements: *70117980375940
24
+ version_requirements: *70227979191380
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: activemodel
27
- requirement: &70117980375320 !ruby/object:Gem::Requirement
27
+ requirement: &70227979190860 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - =
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: 3.2.1
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *70117980375320
35
+ version_requirements: *70227979190860
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: ezcrypto
38
- requirement: &70117980374720 !ruby/object:Gem::Requirement
38
+ requirement: &70227979190440 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,7 +43,7 @@ dependencies:
43
43
  version: '0'
44
44
  type: :runtime
45
45
  prerelease: false
46
- version_requirements: *70117980374720
46
+ version_requirements: *70227979190440
47
47
  description: Our internal session library
48
48
  email:
49
49
  - camwest@gmail.com
@@ -60,9 +60,11 @@ files:
60
60
  - lib/woople-session.rb
61
61
  - lib/woople-session/base.rb
62
62
  - lib/woople-session/version.rb
63
+ - lib/woople/login_helper.rb
63
64
  - lib/woople/tokenizer.rb
64
65
  - spec/spec_helper.rb
65
66
  - spec/woople-session/base_spec.rb
67
+ - spec/woople/login_helper_spec.rb
66
68
  - woople-session.gemspec
67
69
  homepage: ''
68
70
  licenses: []
@@ -91,3 +93,4 @@ summary: An easy way to login as a woople administrator
91
93
  test_files:
92
94
  - spec/spec_helper.rb
93
95
  - spec/woople-session/base_spec.rb
96
+ - spec/woople/login_helper_spec.rb