Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
8beddf78
Commit
8beddf78
authored
May 02, 2021
by
Huzaifa Iftikhar
Committed by
Luke Duncalfe
May 02, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix Rails/SaveBang Rubocop offenses for user related models
parent
f9b7a318
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
37 additions
and
32 deletions
+37
-32
.rubocop_manual_todo.yml
.rubocop_manual_todo.yml
+0
-3
changelogs/unreleased/issue-220040-fix-rails-savebang-users-model.yml
...nreleased/issue-220040-fix-rails-savebang-users-model.yml
+5
-0
spec/models/user_preference_spec.rb
spec/models/user_preference_spec.rb
+1
-1
spec/models/user_spec.rb
spec/models/user_spec.rb
+30
-27
spec/models/user_status_spec.rb
spec/models/user_status_spec.rb
+1
-1
No files found.
.rubocop_manual_todo.yml
View file @
8beddf78
...
@@ -219,9 +219,6 @@ Rails/SaveBang:
...
@@ -219,9 +219,6 @@ Rails/SaveBang:
-
'
spec/models/service_spec.rb'
-
'
spec/models/service_spec.rb'
-
'
spec/models/snippet_spec.rb'
-
'
spec/models/snippet_spec.rb'
-
'
spec/models/upload_spec.rb'
-
'
spec/models/upload_spec.rb'
-
'
spec/models/user_preference_spec.rb'
-
'
spec/models/user_spec.rb'
-
'
spec/models/user_status_spec.rb'
Rails/TimeZone
:
Rails/TimeZone
:
Enabled
:
true
Enabled
:
true
...
...
changelogs/unreleased/issue-220040-fix-rails-savebang-users-model.yml
0 → 100644
View file @
8beddf78
---
title
:
Fix Rails/SaveBang Rubocop offenses for user related models
merge_request
:
57901
author
:
Huzaifa Iftikhar @huzaifaiftikhar
type
:
other
spec/models/user_preference_spec.rb
View file @
8beddf78
...
@@ -61,7 +61,7 @@ RSpec.describe UserPreference do
...
@@ -61,7 +61,7 @@ RSpec.describe UserPreference do
describe
'sort_by preferences'
do
describe
'sort_by preferences'
do
shared_examples_for
'a sort_by preference'
do
shared_examples_for
'a sort_by preference'
do
it
'allows nil sort fields'
do
it
'allows nil sort fields'
do
user_preference
.
update
(
attribute
=>
nil
)
user_preference
.
update
!
(
attribute
=>
nil
)
expect
(
user_preference
).
to
be_valid
expect
(
user_preference
).
to
be_valid
end
end
...
...
spec/models/user_spec.rb
View file @
8beddf78
...
@@ -136,7 +136,7 @@ RSpec.describe User do
...
@@ -136,7 +136,7 @@ RSpec.describe User do
it
'creates `user_detail` when `bio` is first updated'
do
it
'creates `user_detail` when `bio` is first updated'
do
user
=
create
(
:user
)
user
=
create
(
:user
)
expect
{
user
.
update
(
bio:
'my bio'
)
}.
to
change
{
user
.
user_detail
.
persisted?
}.
from
(
false
).
to
(
true
)
expect
{
user
.
update
!
(
bio:
'my bio'
)
}.
to
change
{
user
.
user_detail
.
persisted?
}.
from
(
false
).
to
(
true
)
end
end
end
end
...
@@ -659,9 +659,10 @@ RSpec.describe User do
...
@@ -659,9 +659,10 @@ RSpec.describe User do
it
'does not accept not verified emails'
do
it
'does not accept not verified emails'
do
email
=
create
(
:email
)
email
=
create
(
:email
)
user
=
email
.
user
user
=
email
.
user
user
.
update
(
notification_email:
email
.
email
)
user
.
notification_email
=
email
.
email
expect
(
user
).
to
be_invalid
expect
(
user
).
to
be_invalid
expect
(
user
.
errors
[
:notification_email
]).
to
include
(
'is not an email you own'
)
end
end
end
end
...
@@ -669,7 +670,7 @@ RSpec.describe User do
...
@@ -669,7 +670,7 @@ RSpec.describe User do
it
'accepts verified emails'
do
it
'accepts verified emails'
do
email
=
create
(
:email
,
:confirmed
,
email:
'test@test.com'
)
email
=
create
(
:email
,
:confirmed
,
email:
'test@test.com'
)
user
=
email
.
user
user
=
email
.
user
user
.
update
(
public_email:
email
.
email
)
user
.
notification_email
=
email
.
email
expect
(
user
).
to
be_valid
expect
(
user
).
to
be_valid
end
end
...
@@ -677,9 +678,10 @@ RSpec.describe User do
...
@@ -677,9 +678,10 @@ RSpec.describe User do
it
'does not accept not verified emails'
do
it
'does not accept not verified emails'
do
email
=
create
(
:email
)
email
=
create
(
:email
)
user
=
email
.
user
user
=
email
.
user
user
.
update
(
public_email:
email
.
email
)
user
.
public_email
=
email
.
email
expect
(
user
).
to
be_invalid
expect
(
user
).
to
be_invalid
expect
(
user
.
errors
[
:public_email
]).
to
include
(
'is not an email you own'
)
end
end
end
end
...
@@ -1293,7 +1295,7 @@ RSpec.describe User do
...
@@ -1293,7 +1295,7 @@ RSpec.describe User do
let
(
:secondary
)
{
create
(
:email
,
:confirmed
,
email:
'secondary@example.com'
,
user:
user
)
}
let
(
:secondary
)
{
create
(
:email
,
:confirmed
,
email:
'secondary@example.com'
,
user:
user
)
}
before
do
before
do
user
.
emails
.
create
(
email_attrs
)
user
.
emails
.
create
!
(
email_attrs
)
user
.
tap
{
|
u
|
u
.
update!
(
notification_email:
email_attrs
[
:email
])
}.
reload
user
.
tap
{
|
u
|
u
.
update!
(
notification_email:
email_attrs
[
:email
])
}.
reload
end
end
...
@@ -1447,7 +1449,7 @@ RSpec.describe User do
...
@@ -1447,7 +1449,7 @@ RSpec.describe User do
let!
(
:accessible_deploy_keys_project
)
{
create
(
:deploy_keys_project
,
project:
project
)
}
let!
(
:accessible_deploy_keys_project
)
{
create
(
:deploy_keys_project
,
project:
project
)
}
before
do
before
do
public_deploy_keys_project
.
deploy_key
.
update
(
public:
true
)
public_deploy_keys_project
.
deploy_key
.
update
!
(
public:
true
)
project
.
add_developer
(
user
)
project
.
add_developer
(
user
)
end
end
...
@@ -1537,13 +1539,13 @@ RSpec.describe User do
...
@@ -1537,13 +1539,13 @@ RSpec.describe User do
it
'receives callback when external changes'
do
it
'receives callback when external changes'
do
expect
(
user
).
to
receive
(
:ensure_user_rights_and_limits
)
expect
(
user
).
to
receive
(
:ensure_user_rights_and_limits
)
user
.
update
(
external:
false
)
user
.
update
!
(
external:
false
)
end
end
it
'ensures correct rights and limits for user'
do
it
'ensures correct rights and limits for user'
do
stub_config_setting
(
default_can_create_group:
true
)
stub_config_setting
(
default_can_create_group:
true
)
expect
{
user
.
update
(
external:
false
)
}.
to
change
{
user
.
can_create_group
}.
to
(
true
)
expect
{
user
.
update
!
(
external:
false
)
}.
to
change
{
user
.
can_create_group
}.
to
(
true
)
.
and
change
{
user
.
projects_limit
}.
to
(
Gitlab
::
CurrentSettings
.
default_projects_limit
)
.
and
change
{
user
.
projects_limit
}.
to
(
Gitlab
::
CurrentSettings
.
default_projects_limit
)
end
end
end
end
...
@@ -1554,11 +1556,11 @@ RSpec.describe User do
...
@@ -1554,11 +1556,11 @@ RSpec.describe User do
it
'receives callback when external changes'
do
it
'receives callback when external changes'
do
expect
(
user
).
to
receive
(
:ensure_user_rights_and_limits
)
expect
(
user
).
to
receive
(
:ensure_user_rights_and_limits
)
user
.
update
(
external:
true
)
user
.
update
!
(
external:
true
)
end
end
it
'ensures correct rights and limits for user'
do
it
'ensures correct rights and limits for user'
do
expect
{
user
.
update
(
external:
true
)
}.
to
change
{
user
.
can_create_group
}.
to
(
false
)
expect
{
user
.
update
!
(
external:
true
)
}.
to
change
{
user
.
can_create_group
}.
to
(
false
)
.
and
change
{
user
.
projects_limit
}.
to
(
0
)
.
and
change
{
user
.
projects_limit
}.
to
(
0
)
end
end
end
end
...
@@ -2454,7 +2456,7 @@ RSpec.describe User do
...
@@ -2454,7 +2456,7 @@ RSpec.describe User do
end
end
context
'with a redirect route matching the given path'
do
context
'with a redirect route matching the given path'
do
let!
(
:redirect_route
)
{
user
.
namespace
.
redirect_routes
.
create
(
path:
'foo'
)
}
let!
(
:redirect_route
)
{
user
.
namespace
.
redirect_routes
.
create
!
(
path:
'foo'
)
}
context
'without the follow_redirects option'
do
context
'without the follow_redirects option'
do
it
'returns nil'
do
it
'returns nil'
do
...
@@ -2555,7 +2557,7 @@ RSpec.describe User do
...
@@ -2555,7 +2557,7 @@ RSpec.describe User do
expect
(
Gitlab
::
AvatarCache
).
to
receive
(
:delete_by_email
).
with
(
*
user
.
verified_emails
)
expect
(
Gitlab
::
AvatarCache
).
to
receive
(
:delete_by_email
).
with
(
*
user
.
verified_emails
)
user
.
update
(
avatar:
fixture_file_upload
(
'spec/fixtures/dk.png'
))
user
.
update
!
(
avatar:
fixture_file_upload
(
'spec/fixtures/dk.png'
))
end
end
end
end
...
@@ -2869,12 +2871,12 @@ RSpec.describe User do
...
@@ -2869,12 +2871,12 @@ RSpec.describe User do
expect
(
user
.
starred?
(
project1
)).
to
be_truthy
expect
(
user
.
starred?
(
project1
)).
to
be_truthy
expect
(
user
.
starred?
(
project2
)).
to
be_truthy
expect
(
user
.
starred?
(
project2
)).
to
be_truthy
star1
.
destroy
star1
.
destroy
!
expect
(
user
.
starred?
(
project1
)).
to
be_falsey
expect
(
user
.
starred?
(
project1
)).
to
be_falsey
expect
(
user
.
starred?
(
project2
)).
to
be_truthy
expect
(
user
.
starred?
(
project2
)).
to
be_truthy
star2
.
destroy
star2
.
destroy
!
expect
(
user
.
starred?
(
project1
)).
to
be_falsey
expect
(
user
.
starred?
(
project1
)).
to
be_falsey
expect
(
user
.
starred?
(
project2
)).
to
be_falsey
expect
(
user
.
starred?
(
project2
)).
to
be_falsey
...
@@ -3424,7 +3426,7 @@ RSpec.describe User do
...
@@ -3424,7 +3426,7 @@ RSpec.describe User do
expect
(
user
.
authorized_projects
).
to
include
(
project
)
expect
(
user
.
authorized_projects
).
to
include
(
project
)
member
.
destroy
member
.
destroy
!
expect
(
user
.
authorized_projects
).
not_to
include
(
project
)
expect
(
user
.
authorized_projects
).
not_to
include
(
project
)
end
end
...
@@ -3449,7 +3451,7 @@ RSpec.describe User do
...
@@ -3449,7 +3451,7 @@ RSpec.describe User do
expect
(
user2
.
authorized_projects
).
to
include
(
project
)
expect
(
user2
.
authorized_projects
).
to
include
(
project
)
project
.
destroy
project
.
destroy
!
expect
(
user2
.
authorized_projects
).
not_to
include
(
project
)
expect
(
user2
.
authorized_projects
).
not_to
include
(
project
)
end
end
...
@@ -3463,7 +3465,7 @@ RSpec.describe User do
...
@@ -3463,7 +3465,7 @@ RSpec.describe User do
expect
(
user
.
authorized_projects
).
to
include
(
project
)
expect
(
user
.
authorized_projects
).
to
include
(
project
)
group
.
destroy
group
.
destroy
!
expect
(
user
.
authorized_projects
).
not_to
include
(
project
)
expect
(
user
.
authorized_projects
).
not_to
include
(
project
)
end
end
...
@@ -4463,9 +4465,10 @@ RSpec.describe User do
...
@@ -4463,9 +4465,10 @@ RSpec.describe User do
end
end
it
'adds the namespace errors to the user'
do
it
'adds the namespace errors to the user'
do
user
.
u
pdate
(
username:
new_username
)
user
.
u
sername
=
new_username
expect
(
user
.
errors
.
full_messages
.
first
).
to
eq
(
'A user, alias, or group already exists with that username.'
)
expect
(
user
).
to
be_invalid
expect
(
user
.
errors
[
:base
]).
to
include
(
'A user, alias, or group already exists with that username.'
)
end
end
end
end
end
end
...
@@ -5356,21 +5359,21 @@ RSpec.describe User do
...
@@ -5356,21 +5359,21 @@ RSpec.describe User do
with_them
do
with_them
do
context
'when state was changed'
do
context
'when state was changed'
do
subject
{
user
.
update
(
attributes
)
}
subject
{
user
.
update
!
(
attributes
)
}
include_examples
'update highest role with exclusive lease'
include_examples
'update highest role with exclusive lease'
end
end
end
end
context
'when state was not changed'
do
context
'when state was not changed'
do
subject
{
user
.
update
(
email:
'newmail@example.com'
)
}
subject
{
user
.
update
!
(
email:
'newmail@example.com'
)
}
include_examples
'does not update the highest role'
include_examples
'does not update the highest role'
end
end
end
end
describe
'destroy user'
do
describe
'destroy user'
do
subject
{
user
.
destroy
}
subject
{
user
.
destroy
!
}
include_examples
'does not update the highest role'
include_examples
'does not update the highest role'
end
end
...
@@ -5392,7 +5395,7 @@ RSpec.describe User do
...
@@ -5392,7 +5395,7 @@ RSpec.describe User do
context
'when user is a ghost user'
do
context
'when user is a ghost user'
do
before
do
before
do
user
.
update
(
user_type: :ghost
)
user
.
update
!
(
user_type: :ghost
)
end
end
it
{
is_expected
.
to
be
false
}
it
{
is_expected
.
to
be
false
}
...
@@ -5410,7 +5413,7 @@ RSpec.describe User do
...
@@ -5410,7 +5413,7 @@ RSpec.describe User do
with_them
do
with_them
do
before
do
before
do
user
.
update
(
user_type:
user_type
)
user
.
update
!
(
user_type:
user_type
)
end
end
it
{
is_expected
.
to
be
expected_result
}
it
{
is_expected
.
to
be
expected_result
}
...
@@ -5433,7 +5436,7 @@ RSpec.describe User do
...
@@ -5433,7 +5436,7 @@ RSpec.describe User do
context
'when user is an internal user'
do
context
'when user is an internal user'
do
before
do
before
do
user
.
update
(
user_type: :ghost
)
user
.
update
!
(
user_type: :ghost
)
end
end
it
{
is_expected
.
to
be
:forbidden
}
it
{
is_expected
.
to
be
:forbidden
}
...
@@ -5467,7 +5470,7 @@ RSpec.describe User do
...
@@ -5467,7 +5470,7 @@ RSpec.describe User do
context
'when user is an internal user'
do
context
'when user is an internal user'
do
before
do
before
do
user
.
update
(
user_type:
'alert_bot'
)
user
.
update
!
(
user_type:
'alert_bot'
)
end
end
it_behaves_like
'does not require password to be present'
it_behaves_like
'does not require password to be present'
...
@@ -5475,7 +5478,7 @@ RSpec.describe User do
...
@@ -5475,7 +5478,7 @@ RSpec.describe User do
context
'when user is a project bot user'
do
context
'when user is a project bot user'
do
before
do
before
do
user
.
update
(
user_type:
'project_bot'
)
user
.
update
!
(
user_type:
'project_bot'
)
end
end
it_behaves_like
'does not require password to be present'
it_behaves_like
'does not require password to be present'
...
...
spec/models/user_status_spec.rb
View file @
8beddf78
...
@@ -15,7 +15,7 @@ RSpec.describe UserStatus do
...
@@ -15,7 +15,7 @@ RSpec.describe UserStatus do
it
'is expected to be deleted when the user is deleted'
do
it
'is expected to be deleted when the user is deleted'
do
status
=
create
(
:user_status
)
status
=
create
(
:user_status
)
expect
{
status
.
user
.
destroy
}.
to
change
{
described_class
.
count
}.
from
(
1
).
to
(
0
)
expect
{
status
.
user
.
destroy
!
}.
to
change
{
described_class
.
count
}.
from
(
1
).
to
(
0
)
end
end
describe
'#clear_status_after='
do
describe
'#clear_status_after='
do
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment