summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJames Lopez <james@jameslopez.es>2017-06-13 16:24:36 +0200
committerJames Lopez <james@jameslopez.es>2017-06-13 16:24:36 +0200
commit50dc44a467fed6a915937b9cc4b09c9e79575c7e (patch)
treecb909e83a4c396fca6bcfd9774f4dc8d89cbb4cb
parentbfab2f5f2ac3e9b9a021f3f4791f53f5438c278b (diff)
downloadgitlab-ce-feature/add-new-services.tar.gz
added bang option to specfeature/add-new-services
-rw-r--r--spec/services/users/update_service_spec.rb30
1 files changed, 30 insertions, 0 deletions
diff --git a/spec/services/users/update_service_spec.rb b/spec/services/users/update_service_spec.rb
index 87a3957bc3b..fd32a4f0f33 100644
--- a/spec/services/users/update_service_spec.rb
+++ b/spec/services/users/update_service_spec.rb
@@ -7,6 +7,7 @@ describe Users::UpdateService, services: true do
describe '#execute' do
it 'updates the name' do
result = update_user(user, user, name: 'New Name')
+
expect(result).to eq({ status: :success })
expect(user.name).to eq('New Name')
end
@@ -14,6 +15,7 @@ describe Users::UpdateService, services: true do
context 'when updated by an admin' do
it 'updates the name' do
result = update_user(admin, user, name: 'New Name')
+
expect(result).to eq({ status: :success })
expect(user.name).to eq('New Name')
end
@@ -29,4 +31,32 @@ describe Users::UpdateService, services: true do
described_class.new(current_user, user, opts).execute
end
end
+
+ describe '#execute!' do
+ it 'updates the name' do
+ result = update_user(user, user, name: 'New Name')
+
+ expect(result).to be true
+ expect(user.name).to eq('New Name')
+ end
+
+ context 'when updated by an admin' do
+ it 'updates the name' do
+ result = update_user(admin, user, name: 'New Name')
+
+ expect(result).to be true
+ expect(user.name).to eq('New Name')
+ end
+ end
+
+ it 'returns an error result when record cannot be updated' do
+ expect do
+ update_user(user, create(:user), { name: 'New Name' })
+ end.to raise_error Gitlab::Access::AccessDeniedError
+ end
+
+ def update_user(current_user, user, opts)
+ described_class.new(current_user, user, opts).execute!
+ end
+ end
end