Merge branch 'master' into 3618-column-ordering
[arvados.git] / services / api / test / integration / users_test.rb
1 require 'test_helper'
2 require 'helpers/users_test_helper'
3
4 class UsersTest < ActionDispatch::IntegrationTest
5   include UsersTestHelper
6
7   test "setup user multiple times" do
8     repo_name = 'test_repo'
9
10     post "/arvados/v1/users/setup", {
11       repo_name: repo_name,
12       openid_prefix: 'https://www.google.com/accounts/o8/id',
13       user: {
14         uuid: 'zzzzz-tpzed-abcdefghijklmno',
15         first_name: "in_create_test_first_name",
16         last_name: "test_last_name",
17         email: "foo@example.com"
18       }
19     }, auth(:admin)
20
21     assert_response :success
22
23     response_items = json_response['items']
24
25     created = find_obj_in_resp response_items, 'arvados#user', nil
26
27     assert_equal 'in_create_test_first_name', created['first_name']
28     assert_not_nil created['uuid'], 'expected non-null uuid for the new user'
29     assert_equal 'zzzzz-tpzed-abcdefghijklmno', created['uuid']
30     assert_not_nil created['email'], 'expected non-nil email'
31     assert_nil created['identity_url'], 'expected no identity_url'
32
33     # arvados#user, repo link and link add user to 'All users' group
34     verify_link response_items, 'arvados#user', true, 'permission', 'can_login',
35         created['uuid'], created['email'], 'arvados#user', false, 'arvados#user'
36
37     verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage',
38         repo_name, created['uuid'], 'arvados#repository', true, 'Repository'
39
40     verify_link response_items, 'arvados#group', true, 'permission', 'can_read',
41         'All users', created['uuid'], 'arvados#group', true, 'Group'
42
43     verify_link response_items, 'arvados#virtualMachine', false, 'permission', 'can_login',
44         nil, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine'
45
46     verify_system_group_permission_link_for created['uuid']
47
48     # invoke setup again with the same data
49     post "/arvados/v1/users/setup", {
50       repo_name: repo_name,
51       vm_uuid: virtual_machines(:testvm).uuid,
52       openid_prefix: 'https://www.google.com/accounts/o8/id',
53       user: {
54         uuid: 'zzzzz-tpzed-abcdefghijklmno',
55         first_name: "in_create_test_first_name",
56         last_name: "test_last_name",
57         email: "foo@example.com"
58       }
59     }, auth(:admin)
60
61     assert_response :success
62
63     response_items = json_response['items']
64
65     created = find_obj_in_resp response_items, 'arvados#user', nil
66     assert_equal 'in_create_test_first_name', created['first_name']
67     assert_not_nil created['uuid'], 'expected non-null uuid for the new user'
68     assert_equal 'zzzzz-tpzed-abcdefghijklmno', created['uuid']
69     assert_not_nil created['email'], 'expected non-nil email'
70     assert_nil created['identity_url'], 'expected no identity_url'
71
72     # arvados#user, repo link and link add user to 'All users' group
73     verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage',
74         repo_name, created['uuid'], 'arvados#repository', true, 'Repository'
75
76     verify_link response_items, 'arvados#group', true, 'permission', 'can_read',
77         'All users', created['uuid'], 'arvados#group', true, 'Group'
78
79     verify_link response_items, 'arvados#virtualMachine', true, 'permission', 'can_login',
80         virtual_machines(:testvm).uuid, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine'
81
82     verify_system_group_permission_link_for created['uuid']
83   end
84
85   test "setup user in multiple steps and verify response" do
86     post "/arvados/v1/users/setup", {
87       openid_prefix: 'http://www.example.com/account',
88       user: {
89         email: "foo@example.com"
90       }
91     }, auth(:admin)
92
93     assert_response :success
94     response_items = json_response['items']
95     created = find_obj_in_resp response_items, 'arvados#user', nil
96
97     assert_not_nil created['uuid'], 'expected uuid for new user'
98     assert_not_nil created['email'], 'expected non-nil email'
99     assert_equal created['email'], 'foo@example.com', 'expected input email'
100
101     # three new links: system_group, arvados#user, and 'All users' group.
102     verify_link response_items, 'arvados#user', true, 'permission', 'can_login',
103         created['uuid'], created['email'], 'arvados#user', false, 'arvados#user'
104
105     verify_link response_items, 'arvados#group', true, 'permission', 'can_read',
106         'All users', created['uuid'], 'arvados#group', true, 'Group'
107
108     verify_link response_items, 'arvados#repository', false, 'permission', 'can_manage',
109         'test_repo', created['uuid'], 'arvados#repository', true, 'Repository'
110
111     verify_link response_items, 'arvados#virtualMachine', false, 'permission', 'can_login',
112         nil, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine'
113
114    # invoke setup with a repository
115     post "/arvados/v1/users/setup", {
116       openid_prefix: 'http://www.example.com/account',
117       repo_name: 'new_repo',
118       uuid: created['uuid']
119     }, auth(:admin)
120
121     assert_response :success
122
123     response_items = json_response['items']
124     created = find_obj_in_resp response_items, 'arvados#user', nil
125
126     assert_equal 'foo@example.com', created['email'], 'expected input email'
127
128      # verify links
129     verify_link response_items, 'arvados#group', true, 'permission', 'can_read',
130         'All users', created['uuid'], 'arvados#group', true, 'Group'
131
132     verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage',
133         'new_repo', created['uuid'], 'arvados#repository', true, 'Repository'
134
135     verify_link response_items, 'arvados#virtualMachine', false, 'permission', 'can_login',
136         nil, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine'
137
138     # invoke setup with a vm_uuid
139     post "/arvados/v1/users/setup", {
140       vm_uuid: virtual_machines(:testvm).uuid,
141       openid_prefix: 'http://www.example.com/account',
142       user: {
143         email: 'junk_email'
144       },
145       uuid: created['uuid']
146     }, auth(:admin)
147
148     assert_response :success
149
150     response_items = json_response['items']
151     created = find_obj_in_resp response_items, 'arvados#user', nil
152
153     assert_equal created['email'], 'foo@example.com', 'expected original email'
154
155     # verify links
156     verify_link response_items, 'arvados#group', true, 'permission', 'can_read',
157         'All users', created['uuid'], 'arvados#group', true, 'Group'
158
159     # since no repo name in input, we won't get any; even though user has one
160     verify_link response_items, 'arvados#repository', false, 'permission', 'can_manage',
161         'new_repo', created['uuid'], 'arvados#repository', true, 'Repository'
162
163     verify_link response_items, 'arvados#virtualMachine', true, 'permission', 'can_login',
164         virtual_machines(:testvm).uuid, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine'
165   end
166
167   test "setup and unsetup user" do
168     post "/arvados/v1/users/setup", {
169       repo_name: 'test_repo',
170       vm_uuid: virtual_machines(:testvm).uuid,
171       user: {email: 'foo@example.com'},
172       openid_prefix: 'https://www.google.com/accounts/o8/id'
173     }, auth(:admin)
174
175     assert_response :success
176     response_items = json_response['items']
177     created = find_obj_in_resp response_items, 'arvados#user', nil
178     assert_not_nil created['uuid'], 'expected uuid for the new user'
179     assert_equal created['email'], 'foo@example.com', 'expected given email'
180
181     # five extra links: system_group, login, group, repo and vm
182     verify_link response_items, 'arvados#user', true, 'permission', 'can_login',
183         created['uuid'], created['email'], 'arvados#user', false, 'arvados#user'
184
185     verify_link response_items, 'arvados#group', true, 'permission', 'can_read',
186         'All users', created['uuid'], 'arvados#group', true, 'Group'
187
188     verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage',
189         'test_repo', created['uuid'], 'arvados#repository', true, 'Repository'
190
191     verify_link response_items, 'arvados#virtualMachine', true, 'permission', 'can_login',
192         virtual_machines(:testvm).uuid, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine'
193
194     verify_link_existence created['uuid'], created['email'], true, true, true, true, false
195
196     post "/arvados/v1/users/#{created['uuid']}/unsetup", {}, auth(:admin)
197
198     assert_response :success
199
200     created2 = json_response
201     assert_not_nil created2['uuid'], 'expected uuid for the newly created user'
202     assert_equal created['uuid'], created2['uuid'], 'expected uuid not found'
203
204     verify_link_existence created['uuid'], created['email'], false, false, false, false, false
205   end
206
207   def find_obj_in_resp (response_items, kind, head_kind=nil)
208     response_items.each do |x|
209       if x && x['kind']
210         return x if (x['kind'] == kind && x['head_kind'] == head_kind)
211       end
212     end
213     nil
214   end
215
216 end