gds-sso 14.3.0 → 16.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +23 -56
- data/Rakefile +11 -6
- data/app/controllers/api/user_controller.rb +30 -28
- data/app/controllers/authentications_controller.rb +4 -6
- data/app/views/layouts/unauthorised.html.erb +1 -1
- data/config/routes.rb +7 -6
- data/lib/gds-sso.rb +27 -24
- data/lib/gds-sso/api_access.rb +1 -1
- data/lib/gds-sso/bearer_token.rb +24 -24
- data/lib/gds-sso/config.rb +13 -12
- data/lib/gds-sso/controller_methods.rb +7 -8
- data/lib/gds-sso/failure_app.rb +8 -8
- data/lib/gds-sso/lint/user_spec.rb +27 -28
- data/lib/gds-sso/lint/user_test.rb +28 -28
- data/lib/gds-sso/railtie.rb +12 -0
- data/lib/gds-sso/user.rb +13 -13
- data/lib/gds-sso/version.rb +1 -1
- data/lib/gds-sso/warden_config.rb +21 -31
- data/spec/controller/api_user_controller_spec.rb +40 -37
- data/spec/controller/controller_methods_spec.rb +28 -42
- data/spec/internal/app/assets/config/manifest.js +0 -0
- data/spec/internal/app/controllers/application_controller.rb +1 -1
- data/spec/internal/app/controllers/example_controller.rb +1 -2
- data/spec/internal/config/initializers/gds-sso.rb +2 -2
- data/spec/internal/config/routes.rb +5 -2
- data/spec/internal/config/storage.yml +3 -0
- data/spec/internal/db/combustion_test.sqlite +0 -0
- data/spec/internal/db/schema.rb +9 -5
- data/spec/internal/log/test.log +1142 -1200
- data/spec/requests/end_to_end_spec.rb +45 -46
- data/spec/spec_helper.rb +12 -13
- data/spec/support/controller_spy.rb +14 -0
- data/spec/support/serializable_user.rb +3 -0
- data/spec/support/signon_integration_helpers.rb +10 -8
- data/spec/support/test_user.rb +29 -0
- data/spec/support/timecop.rb +1 -1
- data/spec/unit/api_access_spec.rb +7 -7
- data/spec/unit/bearer_token_spec.rb +14 -15
- data/spec/unit/config_spec.rb +5 -5
- data/spec/unit/mock_bearer_token_spec.rb +4 -4
- data/spec/unit/railtie_spec.rb +14 -0
- data/spec/unit/session_serialisation_spec.rb +5 -9
- data/spec/unit/user_spec.rb +20 -51
- metadata +94 -54
data/spec/unit/config_spec.rb
CHANGED
@@ -1,26 +1,26 @@
|
|
1
|
-
require
|
1
|
+
require "spec_helper"
|
2
2
|
|
3
3
|
describe GDS::SSO::Config do
|
4
4
|
describe "#permissions_for_dummy_user" do
|
5
5
|
context "with no additional mock permissions" do
|
6
6
|
it "returns signin" do
|
7
7
|
subject.additional_mock_permissions_required = nil
|
8
|
-
expect(subject.permissions_for_dummy_api_user).to eq([
|
8
|
+
expect(subject.permissions_for_dummy_api_user).to eq(%w[signin])
|
9
9
|
end
|
10
10
|
end
|
11
11
|
|
12
12
|
context "with an additional mock permission as a string" do
|
13
13
|
it "returns an array of permissions" do
|
14
14
|
subject.additional_mock_permissions_required = "internal_app"
|
15
|
-
expected_permissions = [
|
15
|
+
expected_permissions = %w[signin internal_app]
|
16
16
|
expect(subject.permissions_for_dummy_api_user).to eq(expected_permissions)
|
17
17
|
end
|
18
18
|
end
|
19
19
|
|
20
20
|
context "with additional mock permissions as an array" do
|
21
21
|
it "returns an array of permissions" do
|
22
|
-
subject.additional_mock_permissions_required = [
|
23
|
-
expected_permissions = [
|
22
|
+
subject.additional_mock_permissions_required = %w[another_permission yet_another_permission]
|
23
|
+
expected_permissions = %w[signin another_permission yet_another_permission]
|
24
24
|
expect(subject.permissions_for_dummy_api_user).to eq(expected_permissions)
|
25
25
|
end
|
26
26
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
require
|
2
|
-
require
|
1
|
+
require "spec_helper"
|
2
|
+
require "gds-sso/bearer_token"
|
3
3
|
|
4
4
|
describe GDS::SSO::MockBearerToken do
|
5
5
|
it "updates the permissions of the user" do
|
@@ -7,7 +7,7 @@ describe GDS::SSO::MockBearerToken do
|
|
7
7
|
# call .locate to create the dummy user initially
|
8
8
|
GDS::SSO::Config.additional_mock_permissions_required = nil
|
9
9
|
dummy_user = subject.locate("ABC")
|
10
|
-
expect(dummy_user.permissions).to match_array([
|
10
|
+
expect(dummy_user.permissions).to match_array(%w[signin])
|
11
11
|
|
12
12
|
# add an extra permission
|
13
13
|
GDS::SSO::Config.additional_mock_permissions_required = "extra_permission"
|
@@ -17,6 +17,6 @@ describe GDS::SSO::MockBearerToken do
|
|
17
17
|
|
18
18
|
# call .locate again...this should update our permissions
|
19
19
|
dummy_user_two = subject.locate("ABC")
|
20
|
-
expect(dummy_user_two.permissions).to match_array([
|
20
|
+
expect(dummy_user_two.permissions).to match_array(%w[signin extra_permission])
|
21
21
|
end
|
22
22
|
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require "rails"
|
2
|
+
require "spec_helper"
|
3
|
+
|
4
|
+
RSpec.describe GDS::SSO::Railtie do
|
5
|
+
let(:cache) { double(:cache) }
|
6
|
+
|
7
|
+
it "re-uses the Rails cache" do
|
8
|
+
expect(GDS::SSO::Config.cache).to eq Rails.cache
|
9
|
+
end
|
10
|
+
|
11
|
+
it "honours API only setting" do
|
12
|
+
expect(GDS::SSO::Config.api_only).to eq false
|
13
|
+
end
|
14
|
+
end
|
@@ -1,11 +1,7 @@
|
|
1
|
-
require
|
2
|
-
require
|
1
|
+
require "spec_helper"
|
2
|
+
require "active_record"
|
3
3
|
|
4
4
|
describe Warden::SessionSerializer do
|
5
|
-
class SerializableUser
|
6
|
-
include GDS::SSO::User
|
7
|
-
end
|
8
|
-
|
9
5
|
before :each do
|
10
6
|
@old_user_model = GDS::SSO::Config.user_model
|
11
7
|
GDS::SSO::Config.user_model = SerializableUser
|
@@ -35,7 +31,7 @@ describe Warden::SessionSerializer do
|
|
35
31
|
|
36
32
|
describe "deserialize a user" do
|
37
33
|
it "should return the user if the timestamp is current and a Time" do
|
38
|
-
expect(SerializableUser).to receive(:where).with(:
|
34
|
+
expect(SerializableUser).to receive(:where).with(uid: 1234, remotely_signed_out: false).and_return(double(first: :a_user))
|
39
35
|
|
40
36
|
result = @serializer.deserialize [1234, Time.now.utc - GDS::SSO::Config.auth_valid_for + 3600]
|
41
37
|
|
@@ -43,7 +39,7 @@ describe Warden::SessionSerializer do
|
|
43
39
|
end
|
44
40
|
|
45
41
|
it "should return the user if the timestamp is current and is an ISO 8601 string" do
|
46
|
-
expect(SerializableUser).to receive(:where).with(:
|
42
|
+
expect(SerializableUser).to receive(:where).with(uid: 1234, remotely_signed_out: false).and_return(double(first: :a_user))
|
47
43
|
|
48
44
|
result = @serializer.deserialize [1234, (Time.now.utc - GDS::SSO::Config.auth_valid_for + 3600).iso8601]
|
49
45
|
|
@@ -69,7 +65,7 @@ describe Warden::SessionSerializer do
|
|
69
65
|
it "should return nil for a user with a badly formatted timestamp" do
|
70
66
|
expect(SerializableUser).not_to receive(:where)
|
71
67
|
|
72
|
-
result = @serializer.deserialize [1234,
|
68
|
+
result = @serializer.deserialize [1234, "this is not a timestamp"]
|
73
69
|
|
74
70
|
expect(result).to be_nil
|
75
71
|
end
|
data/spec/unit/user_spec.rb
CHANGED
@@ -1,67 +1,36 @@
|
|
1
|
-
require
|
2
|
-
require
|
3
|
-
require
|
1
|
+
require "spec_helper"
|
2
|
+
require "gds-sso/user"
|
3
|
+
require "gds-sso/lint/user_spec"
|
4
4
|
|
5
|
-
require
|
5
|
+
require "ostruct"
|
6
6
|
|
7
7
|
describe GDS::SSO::User do
|
8
8
|
before :each do
|
9
9
|
@auth_hash = {
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
}
|
18
|
-
}
|
10
|
+
"provider" => "gds",
|
11
|
+
"uid" => "abcde",
|
12
|
+
"credentials" => { "token" => "abcdefg", "secret" => "abcdefg" },
|
13
|
+
"info" => { "name" => "Matt Patterson", "email" => "matt@alphagov.co.uk" },
|
14
|
+
"extra" => {
|
15
|
+
"user" => {
|
16
|
+
"permissions" => [], "organisation_slug" => nil, "organisation_content_id" => nil, "disabled" => false
|
17
|
+
},
|
18
|
+
},
|
19
19
|
}
|
20
20
|
end
|
21
21
|
|
22
22
|
it "should extract the user params from the oauth hash" do
|
23
|
-
expected = {
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
}
|
23
|
+
expected = { "uid" => "abcde",
|
24
|
+
"name" => "Matt Patterson",
|
25
|
+
"email" => "matt@alphagov.co.uk",
|
26
|
+
"permissions" => [],
|
27
|
+
"organisation_slug" => nil,
|
28
|
+
"organisation_content_id" => nil,
|
29
|
+
"disabled" => false }
|
31
30
|
expect(GDS::SSO::User.user_params_from_auth_hash(@auth_hash)).to eq(expected)
|
32
31
|
end
|
33
32
|
|
34
33
|
context "making sure that the lint spec is valid" do
|
35
|
-
class TestUser < OpenStruct
|
36
|
-
include GDS::SSO::User
|
37
|
-
|
38
|
-
def self.where(opts)
|
39
|
-
[]
|
40
|
-
end
|
41
|
-
|
42
|
-
def self.create!(options, scope = {})
|
43
|
-
new(options)
|
44
|
-
end
|
45
|
-
|
46
|
-
def update_attribute(key, value)
|
47
|
-
send("#{key}=".to_sym, value)
|
48
|
-
end
|
49
|
-
|
50
|
-
def update_attributes(options)
|
51
|
-
options.each do |key, value|
|
52
|
-
update_attribute(key, value)
|
53
|
-
end
|
54
|
-
end
|
55
|
-
|
56
|
-
def remotely_signed_out?
|
57
|
-
remotely_signed_out
|
58
|
-
end
|
59
|
-
|
60
|
-
def disabled?
|
61
|
-
disabled
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
34
|
let(:described_class) { TestUser }
|
66
35
|
it_behaves_like "a gds-sso user class"
|
67
36
|
end
|
metadata
CHANGED
@@ -1,43 +1,29 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: gds-sso
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version:
|
4
|
+
version: 16.0.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- GOV.UK Dev
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-06-10 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
|
-
name:
|
15
|
-
requirement: !ruby/object:Gem::Requirement
|
16
|
-
requirements:
|
17
|
-
- - ">="
|
18
|
-
- !ruby/object:Gem::Version
|
19
|
-
version: '4'
|
20
|
-
type: :runtime
|
21
|
-
prerelease: false
|
22
|
-
version_requirements: !ruby/object:Gem::Requirement
|
23
|
-
requirements:
|
24
|
-
- - ">="
|
25
|
-
- !ruby/object:Gem::Version
|
26
|
-
version: '4'
|
27
|
-
- !ruby/object:Gem::Dependency
|
28
|
-
name: warden
|
14
|
+
name: multi_json
|
29
15
|
requirement: !ruby/object:Gem::Requirement
|
30
16
|
requirements:
|
31
17
|
- - "~>"
|
32
18
|
- !ruby/object:Gem::Version
|
33
|
-
version: '1.
|
19
|
+
version: '1.0'
|
34
20
|
type: :runtime
|
35
21
|
prerelease: false
|
36
22
|
version_requirements: !ruby/object:Gem::Requirement
|
37
23
|
requirements:
|
38
24
|
- - "~>"
|
39
25
|
- !ruby/object:Gem::Version
|
40
|
-
version: '1.
|
26
|
+
version: '1.0'
|
41
27
|
- !ruby/object:Gem::Dependency
|
42
28
|
name: oauth2
|
43
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -81,47 +67,61 @@ dependencies:
|
|
81
67
|
- !ruby/object:Gem::Version
|
82
68
|
version: '3.2'
|
83
69
|
- !ruby/object:Gem::Dependency
|
84
|
-
name:
|
70
|
+
name: plek
|
85
71
|
requirement: !ruby/object:Gem::Requirement
|
86
72
|
requirements:
|
87
73
|
- - "~>"
|
88
74
|
- !ruby/object:Gem::Version
|
89
|
-
version:
|
75
|
+
version: '4.0'
|
90
76
|
type: :runtime
|
91
77
|
prerelease: false
|
92
78
|
version_requirements: !ruby/object:Gem::Requirement
|
93
79
|
requirements:
|
94
80
|
- - "~>"
|
95
81
|
- !ruby/object:Gem::Version
|
96
|
-
version:
|
82
|
+
version: '4.0'
|
97
83
|
- !ruby/object:Gem::Dependency
|
98
|
-
name:
|
84
|
+
name: rails
|
85
|
+
requirement: !ruby/object:Gem::Requirement
|
86
|
+
requirements:
|
87
|
+
- - ">="
|
88
|
+
- !ruby/object:Gem::Version
|
89
|
+
version: '5'
|
90
|
+
type: :runtime
|
91
|
+
prerelease: false
|
92
|
+
version_requirements: !ruby/object:Gem::Requirement
|
93
|
+
requirements:
|
94
|
+
- - ">="
|
95
|
+
- !ruby/object:Gem::Version
|
96
|
+
version: '5'
|
97
|
+
- !ruby/object:Gem::Dependency
|
98
|
+
name: warden
|
99
99
|
requirement: !ruby/object:Gem::Requirement
|
100
100
|
requirements:
|
101
101
|
- - "~>"
|
102
102
|
- !ruby/object:Gem::Version
|
103
|
-
version: '1.
|
103
|
+
version: '1.2'
|
104
104
|
type: :runtime
|
105
105
|
prerelease: false
|
106
106
|
version_requirements: !ruby/object:Gem::Requirement
|
107
107
|
requirements:
|
108
108
|
- - "~>"
|
109
109
|
- !ruby/object:Gem::Version
|
110
|
-
version: '1.
|
110
|
+
version: '1.2'
|
111
111
|
- !ruby/object:Gem::Dependency
|
112
|
-
name:
|
112
|
+
name: warden-oauth2
|
113
113
|
requirement: !ruby/object:Gem::Requirement
|
114
114
|
requirements:
|
115
|
-
- - "
|
115
|
+
- - "~>"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version:
|
118
|
-
type: :
|
117
|
+
version: 0.0.1
|
118
|
+
type: :runtime
|
119
119
|
prerelease: false
|
120
120
|
version_requirements: !ruby/object:Gem::Requirement
|
121
121
|
requirements:
|
122
|
-
- - "
|
122
|
+
- - "~>"
|
123
123
|
- !ruby/object:Gem::Version
|
124
|
-
version:
|
124
|
+
version: 0.0.1
|
125
125
|
- !ruby/object:Gem::Dependency
|
126
126
|
name: capybara
|
127
127
|
requirement: !ruby/object:Gem::Requirement
|
@@ -137,35 +137,35 @@ dependencies:
|
|
137
137
|
- !ruby/object:Gem::Version
|
138
138
|
version: '2'
|
139
139
|
- !ruby/object:Gem::Dependency
|
140
|
-
name:
|
140
|
+
name: capybara-mechanize
|
141
141
|
requirement: !ruby/object:Gem::Requirement
|
142
142
|
requirements:
|
143
143
|
- - ">="
|
144
144
|
- !ruby/object:Gem::Version
|
145
|
-
version: '
|
145
|
+
version: '1'
|
146
146
|
type: :development
|
147
147
|
prerelease: false
|
148
148
|
version_requirements: !ruby/object:Gem::Requirement
|
149
149
|
requirements:
|
150
150
|
- - ">="
|
151
151
|
- !ruby/object:Gem::Version
|
152
|
-
version: '
|
152
|
+
version: '1'
|
153
153
|
- !ruby/object:Gem::Dependency
|
154
|
-
name:
|
154
|
+
name: combustion
|
155
155
|
requirement: !ruby/object:Gem::Requirement
|
156
156
|
requirements:
|
157
157
|
- - ">="
|
158
158
|
- !ruby/object:Gem::Version
|
159
|
-
version: '
|
159
|
+
version: '0.9'
|
160
160
|
type: :development
|
161
161
|
prerelease: false
|
162
162
|
version_requirements: !ruby/object:Gem::Requirement
|
163
163
|
requirements:
|
164
164
|
- - ">="
|
165
165
|
- !ruby/object:Gem::Version
|
166
|
-
version: '
|
166
|
+
version: '0.9'
|
167
167
|
- !ruby/object:Gem::Dependency
|
168
|
-
name:
|
168
|
+
name: rake
|
169
169
|
requirement: !ruby/object:Gem::Requirement
|
170
170
|
requirements:
|
171
171
|
- - ">="
|
@@ -178,20 +178,48 @@ dependencies:
|
|
178
178
|
- - ">="
|
179
179
|
- !ruby/object:Gem::Version
|
180
180
|
version: '0.9'
|
181
|
+
- !ruby/object:Gem::Dependency
|
182
|
+
name: rspec-rails
|
183
|
+
requirement: !ruby/object:Gem::Requirement
|
184
|
+
requirements:
|
185
|
+
- - ">="
|
186
|
+
- !ruby/object:Gem::Version
|
187
|
+
version: '3'
|
188
|
+
type: :development
|
189
|
+
prerelease: false
|
190
|
+
version_requirements: !ruby/object:Gem::Requirement
|
191
|
+
requirements:
|
192
|
+
- - ">="
|
193
|
+
- !ruby/object:Gem::Version
|
194
|
+
version: '3'
|
195
|
+
- !ruby/object:Gem::Dependency
|
196
|
+
name: rubocop-govuk
|
197
|
+
requirement: !ruby/object:Gem::Requirement
|
198
|
+
requirements:
|
199
|
+
- - ">="
|
200
|
+
- !ruby/object:Gem::Version
|
201
|
+
version: '0'
|
202
|
+
type: :development
|
203
|
+
prerelease: false
|
204
|
+
version_requirements: !ruby/object:Gem::Requirement
|
205
|
+
requirements:
|
206
|
+
- - ">="
|
207
|
+
- !ruby/object:Gem::Version
|
208
|
+
version: '0'
|
181
209
|
- !ruby/object:Gem::Dependency
|
182
210
|
name: sqlite3
|
183
211
|
requirement: !ruby/object:Gem::Requirement
|
184
212
|
requirements:
|
185
213
|
- - "~>"
|
186
214
|
- !ruby/object:Gem::Version
|
187
|
-
version: 1.
|
215
|
+
version: '1.4'
|
188
216
|
type: :development
|
189
217
|
prerelease: false
|
190
218
|
version_requirements: !ruby/object:Gem::Requirement
|
191
219
|
requirements:
|
192
220
|
- - "~>"
|
193
221
|
- !ruby/object:Gem::Version
|
194
|
-
version: 1.
|
222
|
+
version: '1.4'
|
195
223
|
- !ruby/object:Gem::Dependency
|
196
224
|
name: timecop
|
197
225
|
requirement: !ruby/object:Gem::Requirement
|
@@ -231,6 +259,7 @@ files:
|
|
231
259
|
- lib/gds-sso/failure_app.rb
|
232
260
|
- lib/gds-sso/lint/user_spec.rb
|
233
261
|
- lib/gds-sso/lint/user_test.rb
|
262
|
+
- lib/gds-sso/railtie.rb
|
234
263
|
- lib/gds-sso/user.rb
|
235
264
|
- lib/gds-sso/version.rb
|
236
265
|
- lib/gds-sso/warden_config.rb
|
@@ -238,12 +267,14 @@ files:
|
|
238
267
|
- spec/controller/controller_methods_spec.rb
|
239
268
|
- spec/fixtures/integration/authorize_api_users.sql
|
240
269
|
- spec/fixtures/integration/signon.sql
|
270
|
+
- spec/internal/app/assets/config/manifest.js
|
241
271
|
- spec/internal/app/controllers/application_controller.rb
|
242
272
|
- spec/internal/app/controllers/example_controller.rb
|
243
273
|
- spec/internal/app/models/user.rb
|
244
274
|
- spec/internal/config/database.yml
|
245
275
|
- spec/internal/config/initializers/gds-sso.rb
|
246
276
|
- spec/internal/config/routes.rb
|
277
|
+
- spec/internal/config/storage.yml
|
247
278
|
- spec/internal/db/combustion_test.sqlite
|
248
279
|
- spec/internal/db/schema.rb
|
249
280
|
- spec/internal/log/test.log
|
@@ -251,12 +282,16 @@ files:
|
|
251
282
|
- spec/requests/end_to_end_spec.rb
|
252
283
|
- spec/spec_helper.rb
|
253
284
|
- spec/support/backport_controller_test_params.rb
|
285
|
+
- spec/support/controller_spy.rb
|
286
|
+
- spec/support/serializable_user.rb
|
254
287
|
- spec/support/signon_integration_helpers.rb
|
288
|
+
- spec/support/test_user.rb
|
255
289
|
- spec/support/timecop.rb
|
256
290
|
- spec/unit/api_access_spec.rb
|
257
291
|
- spec/unit/bearer_token_spec.rb
|
258
292
|
- spec/unit/config_spec.rb
|
259
293
|
- spec/unit/mock_bearer_token_spec.rb
|
294
|
+
- spec/unit/railtie_spec.rb
|
260
295
|
- spec/unit/session_serialisation_spec.rb
|
261
296
|
- spec/unit/user_spec.rb
|
262
297
|
homepage: https://github.com/alphagov/gds-sso
|
@@ -271,41 +306,46 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
271
306
|
requirements:
|
272
307
|
- - ">="
|
273
308
|
- !ruby/object:Gem::Version
|
274
|
-
version: 2.
|
309
|
+
version: '2.6'
|
275
310
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
276
311
|
requirements:
|
277
312
|
- - ">="
|
278
313
|
- !ruby/object:Gem::Version
|
279
314
|
version: '0'
|
280
315
|
requirements: []
|
281
|
-
|
282
|
-
rubygems_version: 2.7.6
|
316
|
+
rubygems_version: 3.1.6
|
283
317
|
signing_key:
|
284
318
|
specification_version: 4
|
285
319
|
summary: Client for GDS' OAuth 2-based SSO
|
286
320
|
test_files:
|
321
|
+
- spec/controller/controller_methods_spec.rb
|
322
|
+
- spec/controller/api_user_controller_spec.rb
|
323
|
+
- spec/internal/config/storage.yml
|
324
|
+
- spec/internal/config/routes.rb
|
287
325
|
- spec/internal/config/database.yml
|
288
326
|
- spec/internal/config/initializers/gds-sso.rb
|
289
|
-
- spec/internal/config/routes.rb
|
290
327
|
- spec/internal/public/favicon.ico
|
328
|
+
- spec/internal/app/assets/config/manifest.js
|
291
329
|
- spec/internal/app/controllers/application_controller.rb
|
292
330
|
- spec/internal/app/controllers/example_controller.rb
|
293
331
|
- spec/internal/app/models/user.rb
|
294
332
|
- spec/internal/log/test.log
|
295
|
-
- spec/internal/db/combustion_test.sqlite
|
296
333
|
- spec/internal/db/schema.rb
|
297
|
-
- spec/
|
298
|
-
- spec/
|
299
|
-
- spec/support/
|
334
|
+
- spec/internal/db/combustion_test.sqlite
|
335
|
+
- spec/support/serializable_user.rb
|
336
|
+
- spec/support/controller_spy.rb
|
337
|
+
- spec/support/test_user.rb
|
300
338
|
- spec/support/backport_controller_test_params.rb
|
301
339
|
- spec/support/signon_integration_helpers.rb
|
302
|
-
- spec/
|
303
|
-
- spec/
|
304
|
-
- spec/unit/api_access_spec.rb
|
340
|
+
- spec/support/timecop.rb
|
341
|
+
- spec/spec_helper.rb
|
305
342
|
- spec/unit/config_spec.rb
|
306
|
-
- spec/unit/session_serialisation_spec.rb
|
307
|
-
- spec/unit/user_spec.rb
|
308
343
|
- spec/unit/bearer_token_spec.rb
|
309
344
|
- spec/unit/mock_bearer_token_spec.rb
|
310
|
-
- spec/
|
345
|
+
- spec/unit/api_access_spec.rb
|
346
|
+
- spec/unit/railtie_spec.rb
|
347
|
+
- spec/unit/session_serialisation_spec.rb
|
348
|
+
- spec/unit/user_spec.rb
|
349
|
+
- spec/fixtures/integration/authorize_api_users.sql
|
350
|
+
- spec/fixtures/integration/signon.sql
|
311
351
|
- spec/requests/end_to_end_spec.rb
|