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
0
Merge Requests
0
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
Boxiang Sun
gitlab-ce
Commits
d4976829
Commit
d4976829
authored
May 01, 2017
by
Robert Speicher
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Auto-correct `RSpec/DescribedClass` violations
parent
0a556523
Changes
40
Hide whitespace changes
Inline
Side-by-side
Showing
40 changed files
with
141 additions
and
141 deletions
+141
-141
spec/controllers/application_controller_spec.rb
spec/controllers/application_controller_spec.rb
+4
-4
spec/finders/issues_finder_spec.rb
spec/finders/issues_finder_spec.rb
+4
-4
spec/finders/merge_requests_finder_spec.rb
spec/finders/merge_requests_finder_spec.rb
+4
-4
spec/finders/snippets_finder_spec.rb
spec/finders/snippets_finder_spec.rb
+16
-16
spec/lib/banzai/renderer_spec.rb
spec/lib/banzai/renderer_spec.rb
+1
-1
spec/lib/gitlab/changes_list_spec.rb
spec/lib/gitlab/changes_list_spec.rb
+1
-1
spec/lib/gitlab/ci/build/credentials/factory_spec.rb
spec/lib/gitlab/ci/build/credentials/factory_spec.rb
+2
-2
spec/lib/gitlab/ci/build/credentials/registry_spec.rb
spec/lib/gitlab/ci/build/credentials/registry_spec.rb
+3
-3
spec/lib/gitlab/current_settings_spec.rb
spec/lib/gitlab/current_settings_spec.rb
+2
-2
spec/lib/gitlab/cycle_analytics/base_event_fetcher_spec.rb
spec/lib/gitlab/cycle_analytics/base_event_fetcher_spec.rb
+1
-1
spec/lib/gitlab/git/util_spec.rb
spec/lib/gitlab/git/util_spec.rb
+1
-1
spec/lib/gitlab/gitaly_client/ref_spec.rb
spec/lib/gitlab/gitaly_client/ref_spec.rb
+1
-1
spec/lib/gitlab/ldap/person_spec.rb
spec/lib/gitlab/ldap/person_spec.rb
+3
-3
spec/lib/gitlab/metrics_spec.rb
spec/lib/gitlab/metrics_spec.rb
+14
-14
spec/lib/gitlab/sidekiq_throttler_spec.rb
spec/lib/gitlab/sidekiq_throttler_spec.rb
+2
-2
spec/lib/gitlab/slash_commands/dsl_spec.rb
spec/lib/gitlab/slash_commands/dsl_spec.rb
+1
-1
spec/lib/gitlab/template/gitignore_template_spec.rb
spec/lib/gitlab/template/gitignore_template_spec.rb
+1
-1
spec/lib/gitlab/template/gitlab_ci_yml_template_spec.rb
spec/lib/gitlab/template/gitlab_ci_yml_template_spec.rb
+1
-1
spec/lib/gitlab/template/issue_template_spec.rb
spec/lib/gitlab/template/issue_template_spec.rb
+1
-1
spec/lib/gitlab/template/merge_request_template_spec.rb
spec/lib/gitlab/template/merge_request_template_spec.rb
+1
-1
spec/lib/gitlab/usage_data_spec.rb
spec/lib/gitlab/usage_data_spec.rb
+2
-2
spec/mailers/notify_spec.rb
spec/mailers/notify_spec.rb
+41
-41
spec/requests/api/helpers/internal_helpers_spec.rb
spec/requests/api/helpers/internal_helpers_spec.rb
+1
-1
spec/requests/api/helpers_spec.rb
spec/requests/api/helpers_spec.rb
+1
-1
spec/services/merge_requests/get_urls_service_spec.rb
spec/services/merge_requests/get_urls_service_spec.rb
+2
-2
spec/services/merge_requests/merge_request_diff_cache_service_spec.rb
...s/merge_requests/merge_request_diff_cache_service_spec.rb
+1
-1
spec/services/merge_requests/resolve_service_spec.rb
spec/services/merge_requests/resolve_service_spec.rb
+6
-6
spec/services/projects/housekeeping_service_spec.rb
spec/services/projects/housekeeping_service_spec.rb
+1
-1
spec/tasks/config_lint_spec.rb
spec/tasks/config_lint_spec.rb
+2
-2
spec/workers/delete_user_worker_spec.rb
spec/workers/delete_user_worker_spec.rb
+2
-2
spec/workers/emails_on_push_worker_spec.rb
spec/workers/emails_on_push_worker_spec.rb
+1
-1
spec/workers/git_garbage_collect_worker_spec.rb
spec/workers/git_garbage_collect_worker_spec.rb
+1
-1
spec/workers/gitlab_usage_ping_worker_spec.rb
spec/workers/gitlab_usage_ping_worker_spec.rb
+1
-1
spec/workers/group_destroy_worker_spec.rb
spec/workers/group_destroy_worker_spec.rb
+1
-1
spec/workers/merge_worker_spec.rb
spec/workers/merge_worker_spec.rb
+1
-1
spec/workers/post_receive_spec.rb
spec/workers/post_receive_spec.rb
+9
-9
spec/workers/project_destroy_worker_spec.rb
spec/workers/project_destroy_worker_spec.rb
+1
-1
spec/workers/remove_expired_members_worker_spec.rb
spec/workers/remove_expired_members_worker_spec.rb
+1
-1
spec/workers/remove_unreferenced_lfs_objects_worker_spec.rb
spec/workers/remove_unreferenced_lfs_objects_worker_spec.rb
+1
-1
spec/workers/repository_fork_worker_spec.rb
spec/workers/repository_fork_worker_spec.rb
+1
-1
No files found.
spec/controllers/application_controller_spec.rb
View file @
d4976829
...
@@ -4,7 +4,7 @@ describe ApplicationController do
...
@@ -4,7 +4,7 @@ describe ApplicationController do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
describe
'#check_password_expiration'
do
describe
'#check_password_expiration'
do
let
(
:controller
)
{
ApplicationController
.
new
}
let
(
:controller
)
{
described_class
.
new
}
it
'redirects if the user is over their password expiry'
do
it
'redirects if the user is over their password expiry'
do
user
.
password_expires_at
=
Time
.
new
(
2002
)
user
.
password_expires_at
=
Time
.
new
(
2002
)
...
@@ -34,7 +34,7 @@ describe ApplicationController do
...
@@ -34,7 +34,7 @@ describe ApplicationController do
describe
"#authenticate_user_from_token!"
do
describe
"#authenticate_user_from_token!"
do
describe
"authenticating a user from a private token"
do
describe
"authenticating a user from a private token"
do
controller
(
ApplicationController
)
do
controller
(
described_class
)
do
def
index
def
index
render
text:
"authenticated"
render
text:
"authenticated"
end
end
...
@@ -66,7 +66,7 @@ describe ApplicationController do
...
@@ -66,7 +66,7 @@ describe ApplicationController do
end
end
describe
"authenticating a user from a personal access token"
do
describe
"authenticating a user from a personal access token"
do
controller
(
ApplicationController
)
do
controller
(
described_class
)
do
def
index
def
index
render
text:
'authenticated'
render
text:
'authenticated'
end
end
...
@@ -115,7 +115,7 @@ describe ApplicationController do
...
@@ -115,7 +115,7 @@ describe ApplicationController do
end
end
context
'two-factor authentication'
do
context
'two-factor authentication'
do
let
(
:controller
)
{
ApplicationController
.
new
}
let
(
:controller
)
{
described_class
.
new
}
describe
'#check_two_factor_requirement'
do
describe
'#check_two_factor_requirement'
do
subject
{
controller
.
send
:check_two_factor_requirement
}
subject
{
controller
.
send
:check_two_factor_requirement
}
...
...
spec/finders/issues_finder_spec.rb
View file @
d4976829
...
@@ -16,7 +16,7 @@ describe IssuesFinder do
...
@@ -16,7 +16,7 @@ describe IssuesFinder do
set
(
:label_link
)
{
create
(
:label_link
,
label:
label
,
target:
issue2
)
}
set
(
:label_link
)
{
create
(
:label_link
,
label:
label
,
target:
issue2
)
}
let
(
:search_user
)
{
user
}
let
(
:search_user
)
{
user
}
let
(
:params
)
{
{}
}
let
(
:params
)
{
{}
}
let
(
:issues
)
{
IssuesFinder
.
new
(
search_user
,
params
.
reverse_merge
(
scope:
scope
,
state:
'opened'
)).
execute
}
let
(
:issues
)
{
described_class
.
new
(
search_user
,
params
.
reverse_merge
(
scope:
scope
,
state:
'opened'
)).
execute
}
before
(
:context
)
do
before
(
:context
)
do
project1
.
team
<<
[
user
,
:master
]
project1
.
team
<<
[
user
,
:master
]
...
@@ -282,15 +282,15 @@ describe IssuesFinder do
...
@@ -282,15 +282,15 @@ describe IssuesFinder do
let!
(
:confidential_issue
)
{
create
(
:issue
,
project:
project
,
confidential:
true
)
}
let!
(
:confidential_issue
)
{
create
(
:issue
,
project:
project
,
confidential:
true
)
}
it
'returns non confidential issues for nil user'
do
it
'returns non confidential issues for nil user'
do
expect
(
IssuesFinder
.
send
(
:not_restricted_by_confidentiality
,
nil
)).
to
include
(
public_issue
)
expect
(
described_class
.
send
(
:not_restricted_by_confidentiality
,
nil
)).
to
include
(
public_issue
)
end
end
it
'returns non confidential issues for user not authorized for the issues projects'
do
it
'returns non confidential issues for user not authorized for the issues projects'
do
expect
(
IssuesFinder
.
send
(
:not_restricted_by_confidentiality
,
user
)).
to
include
(
public_issue
)
expect
(
described_class
.
send
(
:not_restricted_by_confidentiality
,
user
)).
to
include
(
public_issue
)
end
end
it
'returns all issues for user authorized for the issues projects'
do
it
'returns all issues for user authorized for the issues projects'
do
expect
(
IssuesFinder
.
send
(
:not_restricted_by_confidentiality
,
authorized_user
)).
to
include
(
public_issue
,
confidential_issue
)
expect
(
described_class
.
send
(
:not_restricted_by_confidentiality
,
authorized_user
)).
to
include
(
public_issue
,
confidential_issue
)
end
end
end
end
end
end
spec/finders/merge_requests_finder_spec.rb
View file @
d4976829
...
@@ -23,26 +23,26 @@ describe MergeRequestsFinder do
...
@@ -23,26 +23,26 @@ describe MergeRequestsFinder do
describe
"#execute"
do
describe
"#execute"
do
it
'filters by scope'
do
it
'filters by scope'
do
params
=
{
scope:
'authored'
,
state:
'opened'
}
params
=
{
scope:
'authored'
,
state:
'opened'
}
merge_requests
=
MergeRequestsFinder
.
new
(
user
,
params
).
execute
merge_requests
=
described_class
.
new
(
user
,
params
).
execute
expect
(
merge_requests
.
size
).
to
eq
(
3
)
expect
(
merge_requests
.
size
).
to
eq
(
3
)
end
end
it
'filters by project'
do
it
'filters by project'
do
params
=
{
project_id:
project1
.
id
,
scope:
'authored'
,
state:
'opened'
}
params
=
{
project_id:
project1
.
id
,
scope:
'authored'
,
state:
'opened'
}
merge_requests
=
MergeRequestsFinder
.
new
(
user
,
params
).
execute
merge_requests
=
described_class
.
new
(
user
,
params
).
execute
expect
(
merge_requests
.
size
).
to
eq
(
1
)
expect
(
merge_requests
.
size
).
to
eq
(
1
)
end
end
it
'filters by non_archived'
do
it
'filters by non_archived'
do
params
=
{
non_archived:
true
}
params
=
{
non_archived:
true
}
merge_requests
=
MergeRequestsFinder
.
new
(
user
,
params
).
execute
merge_requests
=
described_class
.
new
(
user
,
params
).
execute
expect
(
merge_requests
.
size
).
to
eq
(
3
)
expect
(
merge_requests
.
size
).
to
eq
(
3
)
end
end
it
'filters by iid'
do
it
'filters by iid'
do
params
=
{
project_id:
project1
.
id
,
iids:
merge_request1
.
iid
}
params
=
{
project_id:
project1
.
id
,
iids:
merge_request1
.
iid
}
merge_requests
=
MergeRequestsFinder
.
new
(
user
,
params
).
execute
merge_requests
=
described_class
.
new
(
user
,
params
).
execute
expect
(
merge_requests
).
to
contain_exactly
(
merge_request1
)
expect
(
merge_requests
).
to
contain_exactly
(
merge_request1
)
end
end
...
...
spec/finders/snippets_finder_spec.rb
View file @
d4976829
...
@@ -14,13 +14,13 @@ describe SnippetsFinder do
...
@@ -14,13 +14,13 @@ describe SnippetsFinder do
let!
(
:snippet3
)
{
create
(
:personal_snippet
,
:public
)
}
let!
(
:snippet3
)
{
create
(
:personal_snippet
,
:public
)
}
it
"returns all private and internal snippets"
do
it
"returns all private and internal snippets"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :all
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :all
)
expect
(
snippets
).
to
include
(
snippet2
,
snippet3
)
expect
(
snippets
).
to
include
(
snippet2
,
snippet3
)
expect
(
snippets
).
not_to
include
(
snippet1
)
expect
(
snippets
).
not_to
include
(
snippet1
)
end
end
it
"returns all public snippets"
do
it
"returns all public snippets"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
nil
,
filter: :all
)
snippets
=
described_class
.
new
.
execute
(
nil
,
filter: :all
)
expect
(
snippets
).
to
include
(
snippet3
)
expect
(
snippets
).
to
include
(
snippet3
)
expect
(
snippets
).
not_to
include
(
snippet1
,
snippet2
)
expect
(
snippets
).
not_to
include
(
snippet1
,
snippet2
)
end
end
...
@@ -32,7 +32,7 @@ describe SnippetsFinder do
...
@@ -32,7 +32,7 @@ describe SnippetsFinder do
let!
(
:snippet3
)
{
create
(
:personal_snippet
,
:public
)
}
let!
(
:snippet3
)
{
create
(
:personal_snippet
,
:public
)
}
it
"returns public public snippets"
do
it
"returns public public snippets"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
nil
,
filter: :public
)
snippets
=
described_class
.
new
.
execute
(
nil
,
filter: :public
)
expect
(
snippets
).
to
include
(
snippet3
)
expect
(
snippets
).
to
include
(
snippet3
)
expect
(
snippets
).
not_to
include
(
snippet1
,
snippet2
)
expect
(
snippets
).
not_to
include
(
snippet1
,
snippet2
)
...
@@ -45,36 +45,36 @@ describe SnippetsFinder do
...
@@ -45,36 +45,36 @@ describe SnippetsFinder do
let!
(
:snippet3
)
{
create
(
:personal_snippet
,
:public
,
author:
user
)
}
let!
(
:snippet3
)
{
create
(
:personal_snippet
,
:public
,
author:
user
)
}
it
"returns all public and internal snippets"
do
it
"returns all public and internal snippets"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user1
,
filter: :by_user
,
user:
user
)
snippets
=
described_class
.
new
.
execute
(
user1
,
filter: :by_user
,
user:
user
)
expect
(
snippets
).
to
include
(
snippet2
,
snippet3
)
expect
(
snippets
).
to
include
(
snippet2
,
snippet3
)
expect
(
snippets
).
not_to
include
(
snippet1
)
expect
(
snippets
).
not_to
include
(
snippet1
)
end
end
it
"returns internal snippets"
do
it
"returns internal snippets"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_user
,
user:
user
,
scope:
"are_internal"
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_user
,
user:
user
,
scope:
"are_internal"
)
expect
(
snippets
).
to
include
(
snippet2
)
expect
(
snippets
).
to
include
(
snippet2
)
expect
(
snippets
).
not_to
include
(
snippet1
,
snippet3
)
expect
(
snippets
).
not_to
include
(
snippet1
,
snippet3
)
end
end
it
"returns private snippets"
do
it
"returns private snippets"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_user
,
user:
user
,
scope:
"are_private"
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_user
,
user:
user
,
scope:
"are_private"
)
expect
(
snippets
).
to
include
(
snippet1
)
expect
(
snippets
).
to
include
(
snippet1
)
expect
(
snippets
).
not_to
include
(
snippet2
,
snippet3
)
expect
(
snippets
).
not_to
include
(
snippet2
,
snippet3
)
end
end
it
"returns public snippets"
do
it
"returns public snippets"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_user
,
user:
user
,
scope:
"are_public"
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_user
,
user:
user
,
scope:
"are_public"
)
expect
(
snippets
).
to
include
(
snippet3
)
expect
(
snippets
).
to
include
(
snippet3
)
expect
(
snippets
).
not_to
include
(
snippet1
,
snippet2
)
expect
(
snippets
).
not_to
include
(
snippet1
,
snippet2
)
end
end
it
"returns all snippets"
do
it
"returns all snippets"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_user
,
user:
user
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_user
,
user:
user
)
expect
(
snippets
).
to
include
(
snippet1
,
snippet2
,
snippet3
)
expect
(
snippets
).
to
include
(
snippet1
,
snippet2
,
snippet3
)
end
end
it
"returns only public snippets if unauthenticated user"
do
it
"returns only public snippets if unauthenticated user"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
nil
,
filter: :by_user
,
user:
user
)
snippets
=
described_class
.
new
.
execute
(
nil
,
filter: :by_user
,
user:
user
)
expect
(
snippets
).
to
include
(
snippet3
)
expect
(
snippets
).
to
include
(
snippet3
)
expect
(
snippets
).
not_to
include
(
snippet2
,
snippet1
)
expect
(
snippets
).
not_to
include
(
snippet2
,
snippet1
)
end
end
...
@@ -88,43 +88,43 @@ describe SnippetsFinder do
...
@@ -88,43 +88,43 @@ describe SnippetsFinder do
end
end
it
"returns public snippets for unauthorized user"
do
it
"returns public snippets for unauthorized user"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
nil
,
filter: :by_project
,
project:
project1
)
snippets
=
described_class
.
new
.
execute
(
nil
,
filter: :by_project
,
project:
project1
)
expect
(
snippets
).
to
include
(
@snippet3
)
expect
(
snippets
).
to
include
(
@snippet3
)
expect
(
snippets
).
not_to
include
(
@snippet1
,
@snippet2
)
expect
(
snippets
).
not_to
include
(
@snippet1
,
@snippet2
)
end
end
it
"returns public and internal snippets for non project members"
do
it
"returns public and internal snippets for non project members"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
)
expect
(
snippets
).
to
include
(
@snippet2
,
@snippet3
)
expect
(
snippets
).
to
include
(
@snippet2
,
@snippet3
)
expect
(
snippets
).
not_to
include
(
@snippet1
)
expect
(
snippets
).
not_to
include
(
@snippet1
)
end
end
it
"returns public snippets for non project members"
do
it
"returns public snippets for non project members"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
,
scope:
"are_public"
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
,
scope:
"are_public"
)
expect
(
snippets
).
to
include
(
@snippet3
)
expect
(
snippets
).
to
include
(
@snippet3
)
expect
(
snippets
).
not_to
include
(
@snippet1
,
@snippet2
)
expect
(
snippets
).
not_to
include
(
@snippet1
,
@snippet2
)
end
end
it
"returns internal snippets for non project members"
do
it
"returns internal snippets for non project members"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
,
scope:
"are_internal"
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
,
scope:
"are_internal"
)
expect
(
snippets
).
to
include
(
@snippet2
)
expect
(
snippets
).
to
include
(
@snippet2
)
expect
(
snippets
).
not_to
include
(
@snippet1
,
@snippet3
)
expect
(
snippets
).
not_to
include
(
@snippet1
,
@snippet3
)
end
end
it
"does not return private snippets for non project members"
do
it
"does not return private snippets for non project members"
do
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
,
scope:
"are_private"
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
,
scope:
"are_private"
)
expect
(
snippets
).
not_to
include
(
@snippet1
,
@snippet2
,
@snippet3
)
expect
(
snippets
).
not_to
include
(
@snippet1
,
@snippet2
,
@snippet3
)
end
end
it
"returns all snippets for project members"
do
it
"returns all snippets for project members"
do
project1
.
team
<<
[
user
,
:developer
]
project1
.
team
<<
[
user
,
:developer
]
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
)
expect
(
snippets
).
to
include
(
@snippet1
,
@snippet2
,
@snippet3
)
expect
(
snippets
).
to
include
(
@snippet1
,
@snippet2
,
@snippet3
)
end
end
it
"returns private snippets for project members"
do
it
"returns private snippets for project members"
do
project1
.
team
<<
[
user
,
:developer
]
project1
.
team
<<
[
user
,
:developer
]
snippets
=
SnippetsFinder
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
,
scope:
"are_private"
)
snippets
=
described_class
.
new
.
execute
(
user
,
filter: :by_project
,
project:
project1
,
scope:
"are_private"
)
expect
(
snippets
).
to
include
(
@snippet1
)
expect
(
snippets
).
to
include
(
@snippet1
)
end
end
end
end
...
...
spec/lib/banzai/renderer_spec.rb
View file @
d4976829
...
@@ -11,7 +11,7 @@ describe Banzai::Renderer do
...
@@ -11,7 +11,7 @@ describe Banzai::Renderer do
end
end
describe
'#render_field'
do
describe
'#render_field'
do
let
(
:renderer
)
{
Banzai
::
Renderer
}
let
(
:renderer
)
{
described_class
}
subject
{
renderer
.
render_field
(
object
,
:field
)
}
subject
{
renderer
.
render_field
(
object
,
:field
)
}
context
'with a stale cache'
do
context
'with a stale cache'
do
...
...
spec/lib/gitlab/changes_list_spec.rb
View file @
d4976829
...
@@ -5,7 +5,7 @@ describe Gitlab::ChangesList do
...
@@ -5,7 +5,7 @@ describe Gitlab::ChangesList do
let
(
:invalid_changes
)
{
1
}
let
(
:invalid_changes
)
{
1
}
context
'when changes is a valid string'
do
context
'when changes is a valid string'
do
let
(
:changes_list
)
{
Gitlab
::
ChangesList
.
new
(
valid_changes_string
)
}
let
(
:changes_list
)
{
described_class
.
new
(
valid_changes_string
)
}
it
'splits elements by newline character'
do
it
'splits elements by newline character'
do
expect
(
changes_list
).
to
contain_exactly
({
expect
(
changes_list
).
to
contain_exactly
({
...
...
spec/lib/gitlab/ci/build/credentials/factory_spec.rb
View file @
d4976829
...
@@ -3,14 +3,14 @@ require 'spec_helper'
...
@@ -3,14 +3,14 @@ require 'spec_helper'
describe
Gitlab
::
Ci
::
Build
::
Credentials
::
Factory
do
describe
Gitlab
::
Ci
::
Build
::
Credentials
::
Factory
do
let
(
:build
)
{
create
(
:ci_build
,
name:
'spinach'
,
stage:
'test'
,
stage_idx:
0
)
}
let
(
:build
)
{
create
(
:ci_build
,
name:
'spinach'
,
stage:
'test'
,
stage_idx:
0
)
}
subject
{
Gitlab
::
Ci
::
Build
::
Credentials
::
Factory
.
new
(
build
).
create!
}
subject
{
described_class
.
new
(
build
).
create!
}
class
TestProvider
class
TestProvider
def
initialize
(
build
);
end
def
initialize
(
build
);
end
end
end
before
do
before
do
allow_any_instance_of
(
Gitlab
::
Ci
::
Build
::
Credentials
::
Factory
).
to
receive
(
:providers
).
and_return
([
TestProvider
])
allow_any_instance_of
(
described_class
).
to
receive
(
:providers
).
and_return
([
TestProvider
])
end
end
context
'when provider is valid'
do
context
'when provider is valid'
do
...
...
spec/lib/gitlab/ci/build/credentials/registry_spec.rb
View file @
d4976829
...
@@ -4,14 +4,14 @@ describe Gitlab::Ci::Build::Credentials::Registry do
...
@@ -4,14 +4,14 @@ describe Gitlab::Ci::Build::Credentials::Registry do
let
(
:build
)
{
create
(
:ci_build
,
name:
'spinach'
,
stage:
'test'
,
stage_idx:
0
)
}
let
(
:build
)
{
create
(
:ci_build
,
name:
'spinach'
,
stage:
'test'
,
stage_idx:
0
)
}
let
(
:registry_url
)
{
'registry.example.com:5005'
}
let
(
:registry_url
)
{
'registry.example.com:5005'
}
subject
{
Gitlab
::
Ci
::
Build
::
Credentials
::
Registry
.
new
(
build
)
}
subject
{
described_class
.
new
(
build
)
}
before
do
before
do
stub_container_registry_config
(
host_port:
registry_url
)
stub_container_registry_config
(
host_port:
registry_url
)
end
end
it
'contains valid DockerRegistry credentials'
do
it
'contains valid DockerRegistry credentials'
do
expect
(
subject
).
to
be_kind_of
(
Gitlab
::
Ci
::
Build
::
Credentials
::
Registry
)
expect
(
subject
).
to
be_kind_of
(
described_class
)
expect
(
subject
.
username
).
to
eq
'gitlab-ci-token'
expect
(
subject
.
username
).
to
eq
'gitlab-ci-token'
expect
(
subject
.
password
).
to
eq
build
.
token
expect
(
subject
.
password
).
to
eq
build
.
token
...
@@ -20,7 +20,7 @@ describe Gitlab::Ci::Build::Credentials::Registry do
...
@@ -20,7 +20,7 @@ describe Gitlab::Ci::Build::Credentials::Registry do
end
end
describe
'.valid?'
do
describe
'.valid?'
do
subject
{
Gitlab
::
Ci
::
Build
::
Credentials
::
Registry
.
new
(
build
).
valid?
}
subject
{
described_class
.
new
(
build
).
valid?
}
context
'when registry is enabled'
do
context
'when registry is enabled'
do
before
do
before
do
...
...
spec/lib/gitlab/current_settings_spec.rb
View file @
d4976829
...
@@ -10,7 +10,7 @@ describe Gitlab::CurrentSettings do
...
@@ -10,7 +10,7 @@ describe Gitlab::CurrentSettings do
describe
'#current_application_settings'
do
describe
'#current_application_settings'
do
context
'with DB available'
do
context
'with DB available'
do
before
do
before
do
allow_any_instance_of
(
Gitlab
::
CurrentSetting
s
).
to
receive
(
:connect_to_db?
).
and_return
(
true
)
allow_any_instance_of
(
described_clas
s
).
to
receive
(
:connect_to_db?
).
and_return
(
true
)
end
end
it
'attempts to use cached values first'
do
it
'attempts to use cached values first'
do
...
@@ -36,7 +36,7 @@ describe Gitlab::CurrentSettings do
...
@@ -36,7 +36,7 @@ describe Gitlab::CurrentSettings do
context
'with DB unavailable'
do
context
'with DB unavailable'
do
before
do
before
do
allow_any_instance_of
(
Gitlab
::
CurrentSetting
s
).
to
receive
(
:connect_to_db?
).
and_return
(
false
)
allow_any_instance_of
(
described_clas
s
).
to
receive
(
:connect_to_db?
).
and_return
(
false
)
end
end
it
'returns an in-memory ApplicationSetting object'
do
it
'returns an in-memory ApplicationSetting object'
do
...
...
spec/lib/gitlab/cycle_analytics/base_event_fetcher_spec.rb
View file @
d4976829
...
@@ -20,7 +20,7 @@ describe Gitlab::CycleAnalytics::BaseEventFetcher do
...
@@ -20,7 +20,7 @@ describe Gitlab::CycleAnalytics::BaseEventFetcher do
before
do
before
do
allow_any_instance_of
(
Gitlab
::
ReferenceExtractor
).
to
receive
(
:issues
).
and_return
(
Issue
.
all
)
allow_any_instance_of
(
Gitlab
::
ReferenceExtractor
).
to
receive
(
:issues
).
and_return
(
Issue
.
all
)
allow_any_instance_of
(
Gitlab
::
CycleAnalytics
::
BaseEventFetcher
).
to
receive
(
:serialize
)
do
|
event
|
allow_any_instance_of
(
described_class
).
to
receive
(
:serialize
)
do
|
event
|
event
event
end
end
...
...
spec/lib/gitlab/git/util_spec.rb
View file @
d4976829
...
@@ -9,7 +9,7 @@ describe Gitlab::Git::Util do
...
@@ -9,7 +9,7 @@ describe Gitlab::Git::Util do
[
"foo
\n\n
"
,
2
],
[
"foo
\n\n
"
,
2
],
].
each
do
|
string
,
line_count
|
].
each
do
|
string
,
line_count
|
it
"counts
#{
line_count
}
lines in
#{
string
.
inspect
}
"
do
it
"counts
#{
line_count
}
lines in
#{
string
.
inspect
}
"
do
expect
(
Gitlab
::
Git
::
Util
.
count_lines
(
string
)).
to
eq
(
line_count
)
expect
(
described_class
.
count_lines
(
string
)).
to
eq
(
line_count
)
end
end
end
end
end
end
...
...
spec/lib/gitlab/gitaly_client/ref_spec.rb
View file @
d4976829
...
@@ -3,7 +3,7 @@ require 'spec_helper'
...
@@ -3,7 +3,7 @@ require 'spec_helper'
describe
Gitlab
::
GitalyClient
::
Ref
do
describe
Gitlab
::
GitalyClient
::
Ref
do
let
(
:project
)
{
create
(
:empty_project
)
}
let
(
:project
)
{
create
(
:empty_project
)
}
let
(
:repo_path
)
{
project
.
repository
.
path_to_repo
}
let
(
:repo_path
)
{
project
.
repository
.
path_to_repo
}
let
(
:client
)
{
Gitlab
::
GitalyClient
::
Ref
.
new
(
project
.
repository
)
}
let
(
:client
)
{
described_class
.
new
(
project
.
repository
)
}
before
do
before
do
allow
(
Gitlab
.
config
.
gitaly
).
to
receive
(
:enabled
).
and_return
(
true
)
allow
(
Gitlab
.
config
.
gitaly
).
to
receive
(
:enabled
).
and_return
(
true
)
...
...
spec/lib/gitlab/ldap/person_spec.rb
View file @
d4976829
...
@@ -20,7 +20,7 @@ describe Gitlab::LDAP::Person do
...
@@ -20,7 +20,7 @@ describe Gitlab::LDAP::Person do
it
'uses the configured name attribute and handles values as an array'
do
it
'uses the configured name attribute and handles values as an array'
do
name
=
'John Doe'
name
=
'John Doe'
entry
[
'cn'
]
=
[
name
]
entry
[
'cn'
]
=
[
name
]
person
=
Gitlab
::
LDAP
::
Person
.
new
(
entry
,
'ldapmain'
)
person
=
described_class
.
new
(
entry
,
'ldapmain'
)
expect
(
person
.
name
).
to
eq
(
name
)
expect
(
person
.
name
).
to
eq
(
name
)
end
end
...
@@ -30,7 +30,7 @@ describe Gitlab::LDAP::Person do
...
@@ -30,7 +30,7 @@ describe Gitlab::LDAP::Person do
it
'returns the value of mail, if present'
do
it
'returns the value of mail, if present'
do
mail
=
'john@example.com'
mail
=
'john@example.com'
entry
[
'mail'
]
=
mail
entry
[
'mail'
]
=
mail
person
=
Gitlab
::
LDAP
::
Person
.
new
(
entry
,
'ldapmain'
)
person
=
described_class
.
new
(
entry
,
'ldapmain'
)
expect
(
person
.
email
).
to
eq
([
mail
])
expect
(
person
.
email
).
to
eq
([
mail
])
end
end
...
@@ -38,7 +38,7 @@ describe Gitlab::LDAP::Person do
...
@@ -38,7 +38,7 @@ describe Gitlab::LDAP::Person do
it
'returns the value of userPrincipalName, if mail and email are not present'
do
it
'returns the value of userPrincipalName, if mail and email are not present'
do
user_principal_name
=
'john.doe@example.com'
user_principal_name
=
'john.doe@example.com'
entry
[
'userPrincipalName'
]
=
user_principal_name
entry
[
'userPrincipalName'
]
=
user_principal_name
person
=
Gitlab
::
LDAP
::
Person
.
new
(
entry
,
'ldapmain'
)
person
=
described_class
.
new
(
entry
,
'ldapmain'
)
expect
(
person
.
email
).
to
eq
([
user_principal_name
])
expect
(
person
.
email
).
to
eq
([
user_principal_name
])
end
end
...
...
spec/lib/gitlab/metrics_spec.rb
View file @
d4976829
...
@@ -20,7 +20,7 @@ describe Gitlab::Metrics do
...
@@ -20,7 +20,7 @@ describe Gitlab::Metrics do
expect
(
pool
).
to
receive
(
:with
).
and_yield
(
connection
)
expect
(
pool
).
to
receive
(
:with
).
and_yield
(
connection
)
expect
(
connection
).
to
receive
(
:write_points
).
with
(
an_instance_of
(
Array
))
expect
(
connection
).
to
receive
(
:write_points
).
with
(
an_instance_of
(
Array
))
expect
(
Gitlab
::
Metric
s
).
to
receive
(
:pool
).
and_return
(
pool
)
expect
(
described_clas
s
).
to
receive
(
:pool
).
and_return
(
pool
)
described_class
.
submit_metrics
([{
'series'
=>
'kittens'
,
'tags'
=>
{}
}])
described_class
.
submit_metrics
([{
'series'
=>
'kittens'
,
'tags'
=>
{}
}])
end
end
...
@@ -64,7 +64,7 @@ describe Gitlab::Metrics do
...
@@ -64,7 +64,7 @@ describe Gitlab::Metrics do
describe
'.measure'
do
describe
'.measure'
do
context
'without a transaction'
do
context
'without a transaction'
do
it
'returns the return value of the block'
do
it
'returns the return value of the block'
do
val
=
Gitlab
::
Metric
s
.
measure
(
:foo
)
{
10
}
val
=
described_clas
s
.
measure
(
:foo
)
{
10
}
expect
(
val
).
to
eq
(
10
)
expect
(
val
).
to
eq
(
10
)
end
end
...
@@ -74,7 +74,7 @@ describe Gitlab::Metrics do
...
@@ -74,7 +74,7 @@ describe Gitlab::Metrics do
let
(
:transaction
)
{
Gitlab
::
Metrics
::
Transaction
.
new
}
let
(
:transaction
)
{
Gitlab
::
Metrics
::
Transaction
.
new
}
before
do
before
do
allow
(
Gitlab
::
Metric
s
).
to
receive
(
:current_transaction
).
allow
(
described_clas
s
).
to
receive
(
:current_transaction
).
and_return
(
transaction
)
and_return
(
transaction
)
end
end
...
@@ -88,11 +88,11 @@ describe Gitlab::Metrics do
...
@@ -88,11 +88,11 @@ describe Gitlab::Metrics do
expect
(
transaction
).
to
receive
(
:increment
).
expect
(
transaction
).
to
receive
(
:increment
).
with
(
'foo_call_count'
,
1
)
with
(
'foo_call_count'
,
1
)
Gitlab
::
Metric
s
.
measure
(
:foo
)
{
10
}
described_clas
s
.
measure
(
:foo
)
{
10
}
end
end
it
'returns the return value of the block'
do
it
'returns the return value of the block'
do
val
=
Gitlab
::
Metric
s
.
measure
(
:foo
)
{
10
}
val
=
described_clas
s
.
measure
(
:foo
)
{
10
}
expect
(
val
).
to
eq
(
10
)
expect
(
val
).
to
eq
(
10
)
end
end
...
@@ -105,7 +105,7 @@ describe Gitlab::Metrics do
...
@@ -105,7 +105,7 @@ describe Gitlab::Metrics do
expect_any_instance_of
(
Gitlab
::
Metrics
::
Transaction
).
expect_any_instance_of
(
Gitlab
::
Metrics
::
Transaction
).
not_to
receive
(
:add_tag
)
not_to
receive
(
:add_tag
)
Gitlab
::
Metric
s
.
tag_transaction
(
:foo
,
'bar'
)
described_clas
s
.
tag_transaction
(
:foo
,
'bar'
)
end
end
end
end
...
@@ -113,13 +113,13 @@ describe Gitlab::Metrics do
...
@@ -113,13 +113,13 @@ describe Gitlab::Metrics do
let
(
:transaction
)
{
Gitlab
::
Metrics
::
Transaction
.
new
}
let
(
:transaction
)
{
Gitlab
::
Metrics
::
Transaction
.
new
}
it
'adds the tag to the transaction'
do
it
'adds the tag to the transaction'
do
expect
(
Gitlab
::
Metric
s
).
to
receive
(
:current_transaction
).
expect
(
described_clas
s
).
to
receive
(
:current_transaction
).
and_return
(
transaction
)
and_return
(
transaction
)
expect
(
transaction
).
to
receive
(
:add_tag
).
expect
(
transaction
).
to
receive
(
:add_tag
).
with
(
:foo
,
'bar'
)
with
(
:foo
,
'bar'
)
Gitlab
::
Metric
s
.
tag_transaction
(
:foo
,
'bar'
)
described_clas
s
.
tag_transaction
(
:foo
,
'bar'
)
end
end
end
end
end
end
...
@@ -130,7 +130,7 @@ describe Gitlab::Metrics do
...
@@ -130,7 +130,7 @@ describe Gitlab::Metrics do
expect_any_instance_of
(
Gitlab
::
Metrics
::
Transaction
).
expect_any_instance_of
(
Gitlab
::
Metrics
::
Transaction
).
not_to
receive
(
:action
=
)
not_to
receive
(
:action
=
)
Gitlab
::
Metric
s
.
action
=
'foo'
described_clas
s
.
action
=
'foo'
end
end
end
end
...
@@ -138,12 +138,12 @@ describe Gitlab::Metrics do
...
@@ -138,12 +138,12 @@ describe Gitlab::Metrics do
it
'sets the action of a transaction'
do
it
'sets the action of a transaction'
do
trans
=
Gitlab
::
Metrics
::
Transaction
.
new
trans
=
Gitlab
::
Metrics
::
Transaction
.
new
expect
(
Gitlab
::
Metric
s
).
to
receive
(
:current_transaction
).
expect
(
described_clas
s
).
to
receive
(
:current_transaction
).
and_return
(
trans
)
and_return
(
trans
)
expect
(
trans
).
to
receive
(
:action
=
).
with
(
'foo'
)
expect
(
trans
).
to
receive
(
:action
=
).
with
(
'foo'
)
Gitlab
::
Metric
s
.
action
=
'foo'
described_clas
s
.
action
=
'foo'
end
end
end
end
end
end
...
@@ -160,7 +160,7 @@ describe Gitlab::Metrics do
...
@@ -160,7 +160,7 @@ describe Gitlab::Metrics do
expect_any_instance_of
(
Gitlab
::
Metrics
::
Transaction
).
expect_any_instance_of
(
Gitlab
::
Metrics
::
Transaction
).
not_to
receive
(
:add_event
)
not_to
receive
(
:add_event
)
Gitlab
::
Metric
s
.
add_event
(
:meow
)
described_clas
s
.
add_event
(
:meow
)
end
end
end
end
...
@@ -170,10 +170,10 @@ describe Gitlab::Metrics do
...
@@ -170,10 +170,10 @@ describe Gitlab::Metrics do
expect
(
transaction
).
to
receive
(
:add_event
).
with
(
:meow
)
expect
(
transaction
).
to
receive
(
:add_event
).
with
(
:meow
)
expect
(
Gitlab
::
Metric
s
).
to
receive
(
:current_transaction
).
expect
(
described_clas
s
).
to
receive
(
:current_transaction
).
and_return
(
transaction
)
and_return
(
transaction
)
Gitlab
::
Metric
s
.
add_event
(
:meow
)
described_clas
s
.
add_event
(
:meow
)
end
end
end
end
end
end
...
...
spec/lib/gitlab/sidekiq_throttler_spec.rb
View file @
d4976829
...
@@ -13,14 +13,14 @@ describe Gitlab::SidekiqThrottler do
...
@@ -13,14 +13,14 @@ describe Gitlab::SidekiqThrottler do
describe
'#execute!'
do
describe
'#execute!'
do
it
'sets limits on the selected queues'
do
it
'sets limits on the selected queues'
do
Gitlab
::
SidekiqThrottler
.
execute!
described_class
.
execute!
expect
(
Sidekiq
::
Queue
[
'build'
].
limit
).
to
eq
4
expect
(
Sidekiq
::
Queue
[
'build'
].
limit
).
to
eq
4
expect
(
Sidekiq
::
Queue
[
'project_cache'
].
limit
).
to
eq
4
expect
(
Sidekiq
::
Queue
[
'project_cache'
].
limit
).
to
eq
4
end
end
it
'does not set limits on other queues'
do
it
'does not set limits on other queues'
do
Gitlab
::
SidekiqThrottler
.
execute!
described_class
.
execute!
expect
(
Sidekiq
::
Queue
[
'merge'
].
limit
).
to
be_nil
expect
(
Sidekiq
::
Queue
[
'merge'
].
limit
).
to
be_nil
end
end
...
...
spec/lib/gitlab/slash_commands/dsl_spec.rb
View file @
d4976829
...
@@ -3,7 +3,7 @@ require 'spec_helper'
...
@@ -3,7 +3,7 @@ require 'spec_helper'
describe
Gitlab
::
SlashCommands
::
Dsl
do
describe
Gitlab
::
SlashCommands
::
Dsl
do
before
:all
do
before
:all
do
DummyClass
=
Struct
.
new
(
:project
)
do
DummyClass
=
Struct
.
new
(
:project
)
do
include
Gitlab
::
SlashCommands
::
Dsl
include
Gitlab
::
SlashCommands
::
Dsl
# rubocop:disable RSpec/DescribedClass
desc
'A command with no args'
desc
'A command with no args'
command
:no_args
,
:none
do
command
:no_args
,
:none
do
...
...
spec/lib/gitlab/template/gitignore_template_spec.rb
View file @
d4976829
...
@@ -24,7 +24,7 @@ describe Gitlab::Template::GitignoreTemplate do
...
@@ -24,7 +24,7 @@ describe Gitlab::Template::GitignoreTemplate do
it
'returns the Gitignore object of a valid file'
do
it
'returns the Gitignore object of a valid file'
do
ruby
=
subject
.
find
(
'Ruby'
)
ruby
=
subject
.
find
(
'Ruby'
)
expect
(
ruby
).
to
be_a
Gitlab
::
Template
::
GitignoreTemplate
expect
(
ruby
).
to
be_a
described_class
expect
(
ruby
.
name
).
to
eq
(
'Ruby'
)
expect
(
ruby
.
name
).
to
eq
(
'Ruby'
)
end
end
end
end
...
...
spec/lib/gitlab/template/gitlab_ci_yml_template_spec.rb
View file @
d4976829
...
@@ -25,7 +25,7 @@ describe Gitlab::Template::GitlabCiYmlTemplate do
...
@@ -25,7 +25,7 @@ describe Gitlab::Template::GitlabCiYmlTemplate do
it
'returns the GitlabCiYml object of a valid file'
do
it
'returns the GitlabCiYml object of a valid file'
do
ruby
=
subject
.
find
(
'Ruby'
)
ruby
=
subject
.
find
(
'Ruby'
)
expect
(
ruby
).
to
be_a
Gitlab
::
Template
::
GitlabCiYmlTemplate
expect
(
ruby
).
to
be_a
described_class
expect
(
ruby
.
name
).
to
eq
(
'Ruby'
)
expect
(
ruby
.
name
).
to
eq
(
'Ruby'
)
end
end
end
end
...
...
spec/lib/gitlab/template/issue_template_spec.rb
View file @
d4976829
...
@@ -37,7 +37,7 @@ describe Gitlab::Template::IssueTemplate do
...
@@ -37,7 +37,7 @@ describe Gitlab::Template::IssueTemplate do
it
'returns the issue object of a valid file'
do
it
'returns the issue object of a valid file'
do
ruby
=
subject
.
find
(
'bug'
,
project
)
ruby
=
subject
.
find
(
'bug'
,
project
)
expect
(
ruby
).
to
be_a
Gitlab
::
Template
::
IssueTemplate
expect
(
ruby
).
to
be_a
described_class
expect
(
ruby
.
name
).
to
eq
(
'bug'
)
expect
(
ruby
.
name
).
to
eq
(
'bug'
)
end
end
end
end
...
...
spec/lib/gitlab/template/merge_request_template_spec.rb
View file @
d4976829
...
@@ -37,7 +37,7 @@ describe Gitlab::Template::MergeRequestTemplate do
...
@@ -37,7 +37,7 @@ describe Gitlab::Template::MergeRequestTemplate do
it
'returns the merge request object of a valid file'
do
it
'returns the merge request object of a valid file'
do
ruby
=
subject
.
find
(
'bug'
,
project
)
ruby
=
subject
.
find
(
'bug'
,
project
)
expect
(
ruby
).
to
be_a
Gitlab
::
Template
::
MergeRequestTemplate
expect
(
ruby
).
to
be_a
described_class
expect
(
ruby
.
name
).
to
eq
(
'bug'
)
expect
(
ruby
.
name
).
to
eq
(
'bug'
)
end
end
end
end
...
...
spec/lib/gitlab/usage_data_spec.rb
View file @
d4976829
...
@@ -6,7 +6,7 @@ describe Gitlab::UsageData do
...
@@ -6,7 +6,7 @@ describe Gitlab::UsageData do
let!
(
:board
)
{
create
(
:board
,
project:
project
)
}
let!
(
:board
)
{
create
(
:board
,
project:
project
)
}
describe
'#data'
do
describe
'#data'
do
subject
{
Gitlab
::
UsageData
.
data
}
subject
{
described_class
.
data
}
it
"gathers usage data"
do
it
"gathers usage data"
do
expect
(
subject
.
keys
).
to
match_array
(
%i(
expect
(
subject
.
keys
).
to
match_array
(
%i(
...
@@ -58,7 +58,7 @@ describe Gitlab::UsageData do
...
@@ -58,7 +58,7 @@ describe Gitlab::UsageData do
end
end
describe
'#license_usage_data'
do
describe
'#license_usage_data'
do
subject
{
Gitlab
::
UsageData
.
license_usage_data
}
subject
{
described_class
.
license_usage_data
}
it
"gathers license data"
do
it
"gathers license data"
do
expect
(
subject
[
:uuid
]).
to
eq
(
current_application_settings
.
uuid
)
expect
(
subject
[
:uuid
]).
to
eq
(
current_application_settings
.
uuid
)
...
...
spec/mailers/notify_spec.rb
View file @
d4976829
...
@@ -40,7 +40,7 @@ describe Notify do
...
@@ -40,7 +40,7 @@ describe Notify do
let
(
:issue_with_description
)
{
create
(
:issue
,
author:
current_user
,
assignee:
assignee
,
project:
project
,
description:
'My awesome description'
)
}
let
(
:issue_with_description
)
{
create
(
:issue
,
author:
current_user
,
assignee:
assignee
,
project:
project
,
description:
'My awesome description'
)
}
describe
'that are new'
do
describe
'that are new'
do
subject
{
Notify
.
new_issue_email
(
issue
.
assignee_id
,
issue
.
id
)
}
subject
{
described_class
.
new_issue_email
(
issue
.
assignee_id
,
issue
.
id
)
}
it_behaves_like
'an assignee email'
it_behaves_like
'an assignee email'
it_behaves_like
'an email starting a new thread with reply-by-email enabled'
do
it_behaves_like
'an email starting a new thread with reply-by-email enabled'
do
...
@@ -69,7 +69,7 @@ describe Notify do
...
@@ -69,7 +69,7 @@ describe Notify do
end
end
describe
'that are new with a description'
do
describe
'that are new with a description'
do
subject
{
Notify
.
new_issue_email
(
issue_with_description
.
assignee_id
,
issue_with_description
.
id
)
}
subject
{
described_class
.
new_issue_email
(
issue_with_description
.
assignee_id
,
issue_with_description
.
id
)
}
it_behaves_like
'it should show Gmail Actions View Issue link'
it_behaves_like
'it should show Gmail Actions View Issue link'
...
@@ -79,7 +79,7 @@ describe Notify do
...
@@ -79,7 +79,7 @@ describe Notify do
end
end
describe
'that have been reassigned'
do
describe
'that have been reassigned'
do
subject
{
Notify
.
reassigned_issue_email
(
recipient
.
id
,
issue
.
id
,
previous_assignee
.
id
,
current_user
.
id
)
}
subject
{
described_class
.
reassigned_issue_email
(
recipient
.
id
,
issue
.
id
,
previous_assignee
.
id
,
current_user
.
id
)
}
it_behaves_like
'a multiple recipients email'
it_behaves_like
'a multiple recipients email'
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -105,7 +105,7 @@ describe Notify do
...
@@ -105,7 +105,7 @@ describe Notify do
end
end
describe
'that have been relabeled'
do
describe
'that have been relabeled'
do
subject
{
Notify
.
relabeled_issue_email
(
recipient
.
id
,
issue
.
id
,
%w[foo bar baz]
,
current_user
.
id
)
}
subject
{
described_class
.
relabeled_issue_email
(
recipient
.
id
,
issue
.
id
,
%w[foo bar baz]
,
current_user
.
id
)
}
it_behaves_like
'a multiple recipients email'
it_behaves_like
'a multiple recipients email'
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -132,7 +132,7 @@ describe Notify do
...
@@ -132,7 +132,7 @@ describe Notify do
describe
'status changed'
do
describe
'status changed'
do
let
(
:status
)
{
'closed'
}
let
(
:status
)
{
'closed'
}
subject
{
Notify
.
issue_status_changed_email
(
recipient
.
id
,
issue
.
id
,
status
,
current_user
.
id
)
}
subject
{
described_class
.
issue_status_changed_email
(
recipient
.
id
,
issue
.
id
,
status
,
current_user
.
id
)
}
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
let
(
:model
)
{
issue
}
let
(
:model
)
{
issue
}
...
@@ -158,7 +158,7 @@ describe Notify do
...
@@ -158,7 +158,7 @@ describe Notify do
describe
'moved to another project'
do
describe
'moved to another project'
do
let
(
:new_issue
)
{
create
(
:issue
)
}
let
(
:new_issue
)
{
create
(
:issue
)
}
subject
{
Notify
.
issue_moved_email
(
recipient
,
issue
,
new_issue
,
current_user
)
}
subject
{
described_class
.
issue_moved_email
(
recipient
,
issue
,
new_issue
,
current_user
)
}
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
let
(
:model
)
{
issue
}
let
(
:model
)
{
issue
}
...
@@ -190,7 +190,7 @@ describe Notify do
...
@@ -190,7 +190,7 @@ describe Notify do
let
(
:merge_request_with_description
)
{
create
(
:merge_request
,
author:
current_user
,
assignee:
assignee
,
source_project:
project
,
target_project:
project
,
description:
'My awesome description'
)
}
let
(
:merge_request_with_description
)
{
create
(
:merge_request
,
author:
current_user
,
assignee:
assignee
,
source_project:
project
,
target_project:
project
,
description:
'My awesome description'
)
}
describe
'that are new'
do
describe
'that are new'
do
subject
{
Notify
.
new_merge_request_email
(
merge_request
.
assignee_id
,
merge_request
.
id
)
}
subject
{
described_class
.
new_merge_request_email
(
merge_request
.
assignee_id
,
merge_request
.
id
)
}
it_behaves_like
'an assignee email'
it_behaves_like
'an assignee email'
it_behaves_like
'an email starting a new thread with reply-by-email enabled'
do
it_behaves_like
'an email starting a new thread with reply-by-email enabled'
do
...
@@ -221,7 +221,7 @@ describe Notify do
...
@@ -221,7 +221,7 @@ describe Notify do
end
end
describe
'that are new with a description'
do
describe
'that are new with a description'
do
subject
{
Notify
.
new_merge_request_email
(
merge_request_with_description
.
assignee_id
,
merge_request_with_description
.
id
)
}
subject
{
described_class
.
new_merge_request_email
(
merge_request_with_description
.
assignee_id
,
merge_request_with_description
.
id
)
}
it_behaves_like
'it should show Gmail Actions View Merge request link'
it_behaves_like
'it should show Gmail Actions View Merge request link'
it_behaves_like
"an unsubscribeable thread"
it_behaves_like
"an unsubscribeable thread"
...
@@ -232,7 +232,7 @@ describe Notify do
...
@@ -232,7 +232,7 @@ describe Notify do
end
end
describe
'that are reassigned'
do
describe
'that are reassigned'
do
subject
{
Notify
.
reassigned_merge_request_email
(
recipient
.
id
,
merge_request
.
id
,
previous_assignee
.
id
,
current_user
.
id
)
}
subject
{
described_class
.
reassigned_merge_request_email
(
recipient
.
id
,
merge_request
.
id
,
previous_assignee
.
id
,
current_user
.
id
)
}
it_behaves_like
'a multiple recipients email'
it_behaves_like
'a multiple recipients email'
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -258,7 +258,7 @@ describe Notify do
...
@@ -258,7 +258,7 @@ describe Notify do
end
end
describe
'that have been relabeled'
do
describe
'that have been relabeled'
do
subject
{
Notify
.
relabeled_merge_request_email
(
recipient
.
id
,
merge_request
.
id
,
%w[foo bar baz]
,
current_user
.
id
)
}
subject
{
described_class
.
relabeled_merge_request_email
(
recipient
.
id
,
merge_request
.
id
,
%w[foo bar baz]
,
current_user
.
id
)
}
it_behaves_like
'a multiple recipients email'
it_behaves_like
'a multiple recipients email'
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -283,7 +283,7 @@ describe Notify do
...
@@ -283,7 +283,7 @@ describe Notify do
describe
'status changed'
do
describe
'status changed'
do
let
(
:status
)
{
'reopened'
}
let
(
:status
)
{
'reopened'
}
subject
{
Notify
.
merge_request_status_email
(
recipient
.
id
,
merge_request
.
id
,
status
,
current_user
.
id
)
}
subject
{
described_class
.
merge_request_status_email
(
recipient
.
id
,
merge_request
.
id
,
status
,
current_user
.
id
)
}
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
let
(
:model
)
{
merge_request
}
let
(
:model
)
{
merge_request
}
...
@@ -308,7 +308,7 @@ describe Notify do
...
@@ -308,7 +308,7 @@ describe Notify do
end
end
describe
'that are merged'
do
describe
'that are merged'
do
subject
{
Notify
.
merged_merge_request_email
(
recipient
.
id
,
merge_request
.
id
,
merge_author
.
id
)
}
subject
{
described_class
.
merged_merge_request_email
(
recipient
.
id
,
merge_request
.
id
,
merge_author
.
id
)
}
it_behaves_like
'a multiple recipients email'
it_behaves_like
'a multiple recipients email'
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -337,7 +337,7 @@ describe Notify do
...
@@ -337,7 +337,7 @@ describe Notify do
describe
'project was moved'
do
describe
'project was moved'
do
let
(
:project
)
{
create
(
:empty_project
)
}
let
(
:project
)
{
create
(
:empty_project
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
subject
{
Notify
.
project_was_moved_email
(
project
.
id
,
user
.
id
,
"gitlab/gitlab"
)
}
subject
{
described_class
.
project_was_moved_email
(
project
.
id
,
user
.
id
,
"gitlab/gitlab"
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -363,7 +363,7 @@ describe Notify do
...
@@ -363,7 +363,7 @@ describe Notify do
project
.
request_access
(
user
)
project
.
request_access
(
user
)
project
.
requesters
.
find_by
(
user_id:
user
.
id
)
project
.
requesters
.
find_by
(
user_id:
user
.
id
)
end
end
subject
{
Notify
.
member_access_requested_email
(
'project'
,
project_member
.
id
)
}
subject
{
described_class
.
member_access_requested_email
(
'project'
,
project_member
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -390,7 +390,7 @@ describe Notify do
...
@@ -390,7 +390,7 @@ describe Notify do
project
.
request_access
(
user
)
project
.
request_access
(
user
)
project
.
requesters
.
find_by
(
user_id:
user
.
id
)
project
.
requesters
.
find_by
(
user_id:
user
.
id
)
end
end
subject
{
Notify
.
member_access_requested_email
(
'project'
,
project_member
.
id
)
}
subject
{
described_class
.
member_access_requested_email
(
'project'
,
project_member
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -416,7 +416,7 @@ describe Notify do
...
@@ -416,7 +416,7 @@ describe Notify do
project
.
request_access
(
user
)
project
.
request_access
(
user
)
project
.
requesters
.
find_by
(
user_id:
user
.
id
)
project
.
requesters
.
find_by
(
user_id:
user
.
id
)
end
end
subject
{
Notify
.
member_access_denied_email
(
'project'
,
project
.
id
,
user
.
id
)
}
subject
{
described_class
.
member_access_denied_email
(
'project'
,
project
.
id
,
user
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -434,7 +434,7 @@ describe Notify do
...
@@ -434,7 +434,7 @@ describe Notify do
let
(
:project
)
{
create
(
:empty_project
,
:public
,
:access_requestable
,
namespace:
owner
.
namespace
)
}
let
(
:project
)
{
create
(
:empty_project
,
:public
,
:access_requestable
,
namespace:
owner
.
namespace
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:project_member
)
{
create
(
:project_member
,
project:
project
,
user:
user
)
}
let
(
:project_member
)
{
create
(
:project_member
,
project:
project
,
user:
user
)
}
subject
{
Notify
.
member_access_granted_email
(
'project'
,
project_member
.
id
)
}
subject
{
described_class
.
member_access_granted_email
(
'project'
,
project_member
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -465,7 +465,7 @@ describe Notify do
...
@@ -465,7 +465,7 @@ describe Notify do
let
(
:master
)
{
create
(
:user
).
tap
{
|
u
|
project
.
team
<<
[
u
,
:master
]
}
}
let
(
:master
)
{
create
(
:user
).
tap
{
|
u
|
project
.
team
<<
[
u
,
:master
]
}
}
let
(
:project_member
)
{
invite_to_project
(
project
,
inviter:
master
)
}
let
(
:project_member
)
{
invite_to_project
(
project
,
inviter:
master
)
}
subject
{
Notify
.
member_invited_email
(
'project'
,
project_member
.
id
,
project_member
.
invite_token
)
}
subject
{
described_class
.
member_invited_email
(
'project'
,
project_member
.
id
,
project_member
.
invite_token
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -490,7 +490,7 @@ describe Notify do
...
@@ -490,7 +490,7 @@ describe Notify do
invitee
invitee
end
end
subject
{
Notify
.
member_invite_accepted_email
(
'project'
,
project_member
.
id
)
}
subject
{
described_class
.
member_invite_accepted_email
(
'project'
,
project_member
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -514,7 +514,7 @@ describe Notify do
...
@@ -514,7 +514,7 @@ describe Notify do
invitee
invitee
end
end
subject
{
Notify
.
member_invite_declined_email
(
'project'
,
project
.
id
,
project_member
.
invite_email
,
master
.
id
)
}
subject
{
described_class
.
member_invite_declined_email
(
'project'
,
project
.
id
,
project_member
.
invite_email
,
master
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -574,7 +574,7 @@ describe Notify do
...
@@ -574,7 +574,7 @@ describe Notify do
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
commit
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
commit
)
}
subject
{
Notify
.
note_commit_email
(
recipient
.
id
,
note
.
id
)
}
subject
{
described_class
.
note_commit_email
(
recipient
.
id
,
note
.
id
)
}
it_behaves_like
'a note email'
it_behaves_like
'a note email'
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -596,7 +596,7 @@ describe Notify do
...
@@ -596,7 +596,7 @@ describe Notify do
let
(
:note_on_merge_request_path
)
{
namespace_project_merge_request_path
(
project
.
namespace
,
project
,
merge_request
,
anchor:
"note_
#{
note
.
id
}
"
)
}
let
(
:note_on_merge_request_path
)
{
namespace_project_merge_request_path
(
project
.
namespace
,
project
,
merge_request
,
anchor:
"note_
#{
note
.
id
}
"
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
merge_request
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
merge_request
)
}
subject
{
Notify
.
note_merge_request_email
(
recipient
.
id
,
note
.
id
)
}
subject
{
described_class
.
note_merge_request_email
(
recipient
.
id
,
note
.
id
)
}
it_behaves_like
'a note email'
it_behaves_like
'a note email'
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -618,7 +618,7 @@ describe Notify do
...
@@ -618,7 +618,7 @@ describe Notify do
let
(
:note_on_issue_path
)
{
namespace_project_issue_path
(
project
.
namespace
,
project
,
issue
,
anchor:
"note_
#{
note
.
id
}
"
)
}
let
(
:note_on_issue_path
)
{
namespace_project_issue_path
(
project
.
namespace
,
project
,
issue
,
anchor:
"note_
#{
note
.
id
}
"
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
issue
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
issue
)
}
subject
{
Notify
.
note_issue_email
(
recipient
.
id
,
note
.
id
)
}
subject
{
described_class
.
note_issue_email
(
recipient
.
id
,
note
.
id
)
}
it_behaves_like
'a note email'
it_behaves_like
'a note email'
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -680,7 +680,7 @@ describe Notify do
...
@@ -680,7 +680,7 @@ describe Notify do
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
commit
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
commit
)
}
subject
{
Notify
.
note_commit_email
(
recipient
.
id
,
note
.
id
)
}
subject
{
described_class
.
note_commit_email
(
recipient
.
id
,
note
.
id
)
}
it_behaves_like
'a discussion note email'
,
:discussion_note_on_commit
it_behaves_like
'a discussion note email'
,
:discussion_note_on_commit
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -704,7 +704,7 @@ describe Notify do
...
@@ -704,7 +704,7 @@ describe Notify do
let
(
:note_on_merge_request_path
)
{
namespace_project_merge_request_path
(
project
.
namespace
,
project
,
merge_request
,
anchor:
"note_
#{
note
.
id
}
"
)
}
let
(
:note_on_merge_request_path
)
{
namespace_project_merge_request_path
(
project
.
namespace
,
project
,
merge_request
,
anchor:
"note_
#{
note
.
id
}
"
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
merge_request
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
merge_request
)
}
subject
{
Notify
.
note_merge_request_email
(
recipient
.
id
,
note
.
id
)
}
subject
{
described_class
.
note_merge_request_email
(
recipient
.
id
,
note
.
id
)
}
it_behaves_like
'a discussion note email'
,
:discussion_note_on_merge_request
it_behaves_like
'a discussion note email'
,
:discussion_note_on_merge_request
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -728,7 +728,7 @@ describe Notify do
...
@@ -728,7 +728,7 @@ describe Notify do
let
(
:note_on_issue_path
)
{
namespace_project_issue_path
(
project
.
namespace
,
project
,
issue
,
anchor:
"note_
#{
note
.
id
}
"
)
}
let
(
:note_on_issue_path
)
{
namespace_project_issue_path
(
project
.
namespace
,
project
,
issue
,
anchor:
"note_
#{
note
.
id
}
"
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
issue
)
}
before
(
:each
)
{
allow
(
note
).
to
receive
(
:noteable
).
and_return
(
issue
)
}
subject
{
Notify
.
note_issue_email
(
recipient
.
id
,
note
.
id
)
}
subject
{
described_class
.
note_issue_email
(
recipient
.
id
,
note
.
id
)
}
it_behaves_like
'a discussion note email'
,
:discussion_note_on_issue
it_behaves_like
'a discussion note email'
,
:discussion_note_on_issue
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
it_behaves_like
'an answer to an existing thread with reply-by-email enabled'
do
...
@@ -798,7 +798,7 @@ describe Notify do
...
@@ -798,7 +798,7 @@ describe Notify do
let
(
:commit
)
{
project
.
commit
}
let
(
:commit
)
{
project
.
commit
}
let
(
:note
)
{
create
(
:diff_note_on_commit
)
}
let
(
:note
)
{
create
(
:diff_note_on_commit
)
}
subject
{
Notify
.
note_commit_email
(
recipient
.
id
,
note
.
id
)
}
subject
{
described_class
.
note_commit_email
(
recipient
.
id
,
note
.
id
)
}
it_behaves_like
'an email for a note on a diff discussion'
,
:diff_note_on_commit
it_behaves_like
'an email for a note on a diff discussion'
,
:diff_note_on_commit
it_behaves_like
'it should show Gmail Actions View Commit link'
it_behaves_like
'it should show Gmail Actions View Commit link'
...
@@ -809,7 +809,7 @@ describe Notify do
...
@@ -809,7 +809,7 @@ describe Notify do
let
(
:merge_request
)
{
create
(
:merge_request
,
source_project:
project
,
target_project:
project
)
}
let
(
:merge_request
)
{
create
(
:merge_request
,
source_project:
project
,
target_project:
project
)
}
let
(
:note
)
{
create
(
:diff_note_on_merge_request
)
}
let
(
:note
)
{
create
(
:diff_note_on_merge_request
)
}
subject
{
Notify
.
note_merge_request_email
(
recipient
.
id
,
note
.
id
)
}
subject
{
described_class
.
note_merge_request_email
(
recipient
.
id
,
note
.
id
)
}
it_behaves_like
'an email for a note on a diff discussion'
,
:diff_note_on_merge_request
it_behaves_like
'an email for a note on a diff discussion'
,
:diff_note_on_merge_request
it_behaves_like
'it should show Gmail Actions View Merge request link'
it_behaves_like
'it should show Gmail Actions View Merge request link'
...
@@ -826,7 +826,7 @@ describe Notify do
...
@@ -826,7 +826,7 @@ describe Notify do
group
.
request_access
(
user
)
group
.
request_access
(
user
)
group
.
requesters
.
find_by
(
user_id:
user
.
id
)
group
.
requesters
.
find_by
(
user_id:
user
.
id
)
end
end
subject
{
Notify
.
member_access_requested_email
(
'group'
,
group_member
.
id
)
}
subject
{
described_class
.
member_access_requested_email
(
'group'
,
group_member
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -847,7 +847,7 @@ describe Notify do
...
@@ -847,7 +847,7 @@ describe Notify do
group
.
request_access
(
user
)
group
.
request_access
(
user
)
group
.
requesters
.
find_by
(
user_id:
user
.
id
)
group
.
requesters
.
find_by
(
user_id:
user
.
id
)
end
end
subject
{
Notify
.
member_access_denied_email
(
'group'
,
group
.
id
,
user
.
id
)
}
subject
{
described_class
.
member_access_denied_email
(
'group'
,
group
.
id
,
user
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -865,7 +865,7 @@ describe Notify do
...
@@ -865,7 +865,7 @@ describe Notify do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:group_member
)
{
create
(
:group_member
,
group:
group
,
user:
user
)
}
let
(
:group_member
)
{
create
(
:group_member
,
group:
group
,
user:
user
)
}
subject
{
Notify
.
member_access_granted_email
(
'group'
,
group_member
.
id
)
}
subject
{
described_class
.
member_access_granted_email
(
'group'
,
group_member
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -896,7 +896,7 @@ describe Notify do
...
@@ -896,7 +896,7 @@ describe Notify do
let
(
:owner
)
{
create
(
:user
).
tap
{
|
u
|
group
.
add_user
(
u
,
Gitlab
::
Access
::
OWNER
)
}
}
let
(
:owner
)
{
create
(
:user
).
tap
{
|
u
|
group
.
add_user
(
u
,
Gitlab
::
Access
::
OWNER
)
}
}
let
(
:group_member
)
{
invite_to_group
(
group
,
inviter:
owner
)
}
let
(
:group_member
)
{
invite_to_group
(
group
,
inviter:
owner
)
}
subject
{
Notify
.
member_invited_email
(
'group'
,
group_member
.
id
,
group_member
.
invite_token
)
}
subject
{
described_class
.
member_invited_email
(
'group'
,
group_member
.
id
,
group_member
.
invite_token
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -921,7 +921,7 @@ describe Notify do
...
@@ -921,7 +921,7 @@ describe Notify do
invitee
invitee
end
end
subject
{
Notify
.
member_invite_accepted_email
(
'group'
,
group_member
.
id
)
}
subject
{
described_class
.
member_invite_accepted_email
(
'group'
,
group_member
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -945,7 +945,7 @@ describe Notify do
...
@@ -945,7 +945,7 @@ describe Notify do
invitee
invitee
end
end
subject
{
Notify
.
member_invite_declined_email
(
'group'
,
group
.
id
,
group_member
.
invite_email
,
owner
.
id
)
}
subject
{
described_class
.
member_invite_declined_email
(
'group'
,
group
.
id
,
group_member
.
invite_email
,
owner
.
id
)
}
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'an email sent from GitLab'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
...
@@ -994,7 +994,7 @@ describe Notify do
...
@@ -994,7 +994,7 @@ describe Notify do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:tree_path
)
{
namespace_project_tree_path
(
project
.
namespace
,
project
,
"empty-branch"
)
}
let
(
:tree_path
)
{
namespace_project_tree_path
(
project
.
namespace
,
project
,
"empty-branch"
)
}
subject
{
Notify
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/heads/empty-branch'
,
action: :create
)
}
subject
{
described_class
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/heads/empty-branch'
,
action: :create
)
}
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'a user cannot unsubscribe through footer link'
it_behaves_like
'a user cannot unsubscribe through footer link'
...
@@ -1020,7 +1020,7 @@ describe Notify do
...
@@ -1020,7 +1020,7 @@ describe Notify do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:tree_path
)
{
namespace_project_tree_path
(
project
.
namespace
,
project
,
"v1.0"
)
}
let
(
:tree_path
)
{
namespace_project_tree_path
(
project
.
namespace
,
project
,
"v1.0"
)
}
subject
{
Notify
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/tags/v1.0'
,
action: :create
)
}
subject
{
described_class
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/tags/v1.0'
,
action: :create
)
}
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
"a user cannot unsubscribe through footer link"
it_behaves_like
"a user cannot unsubscribe through footer link"
...
@@ -1045,7 +1045,7 @@ describe Notify do
...
@@ -1045,7 +1045,7 @@ describe Notify do
let
(
:example_site_path
)
{
root_path
}
let
(
:example_site_path
)
{
root_path
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
subject
{
Notify
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/heads/master'
,
action: :delete
)
}
subject
{
described_class
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/heads/master'
,
action: :delete
)
}
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'a user cannot unsubscribe through footer link'
it_behaves_like
'a user cannot unsubscribe through footer link'
...
@@ -1067,7 +1067,7 @@ describe Notify do
...
@@ -1067,7 +1067,7 @@ describe Notify do
let
(
:example_site_path
)
{
root_path
}
let
(
:example_site_path
)
{
root_path
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
subject
{
Notify
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/tags/v1.0'
,
action: :delete
)
}
subject
{
described_class
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/tags/v1.0'
,
action: :delete
)
}
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'a user cannot unsubscribe through footer link'
it_behaves_like
'a user cannot unsubscribe through footer link'
...
@@ -1096,7 +1096,7 @@ describe Notify do
...
@@ -1096,7 +1096,7 @@ describe Notify do
let
(
:send_from_committer_email
)
{
false
}
let
(
:send_from_committer_email
)
{
false
}
let
(
:diff_refs
)
{
Gitlab
::
Diff
::
DiffRefs
.
new
(
base_sha:
project
.
merge_base_commit
(
sample_image_commit
.
id
,
sample_commit
.
id
).
id
,
head_sha:
sample_commit
.
id
)
}
let
(
:diff_refs
)
{
Gitlab
::
Diff
::
DiffRefs
.
new
(
base_sha:
project
.
merge_base_commit
(
sample_image_commit
.
id
,
sample_commit
.
id
).
id
,
head_sha:
sample_commit
.
id
)
}
subject
{
Notify
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/heads/master'
,
action: :push
,
compare:
compare
,
reverse_compare:
false
,
diff_refs:
diff_refs
,
send_from_committer_email:
send_from_committer_email
)
}
subject
{
described_class
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/heads/master'
,
action: :push
,
compare:
compare
,
reverse_compare:
false
,
diff_refs:
diff_refs
,
send_from_committer_email:
send_from_committer_email
)
}
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'it should not have Gmail Actions links'
it_behaves_like
'a user cannot unsubscribe through footer link'
it_behaves_like
'a user cannot unsubscribe through footer link'
...
@@ -1189,7 +1189,7 @@ describe Notify do
...
@@ -1189,7 +1189,7 @@ describe Notify do
let
(
:diff_path
)
{
namespace_project_commit_path
(
project
.
namespace
,
project
,
commits
.
first
)
}
let
(
:diff_path
)
{
namespace_project_commit_path
(
project
.
namespace
,
project
,
commits
.
first
)
}
let
(
:diff_refs
)
{
Gitlab
::
Diff
::
DiffRefs
.
new
(
base_sha:
project
.
merge_base_commit
(
sample_image_commit
.
id
,
sample_commit
.
id
).
id
,
head_sha:
sample_commit
.
id
)
}
let
(
:diff_refs
)
{
Gitlab
::
Diff
::
DiffRefs
.
new
(
base_sha:
project
.
merge_base_commit
(
sample_image_commit
.
id
,
sample_commit
.
id
).
id
,
head_sha:
sample_commit
.
id
)
}
subject
{
Notify
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/heads/master'
,
action: :push
,
compare:
compare
,
diff_refs:
diff_refs
)
}
subject
{
described_class
.
repository_push_email
(
project
.
id
,
author_id:
user
.
id
,
ref:
'refs/heads/master'
,
action: :push
,
compare:
compare
,
diff_refs:
diff_refs
)
}
it_behaves_like
'it should show Gmail Actions View Commit link'
it_behaves_like
'it should show Gmail Actions View Commit link'
it_behaves_like
'a user cannot unsubscribe through footer link'
it_behaves_like
'a user cannot unsubscribe through footer link'
...
@@ -1215,7 +1215,7 @@ describe Notify do
...
@@ -1215,7 +1215,7 @@ describe Notify do
describe
'HTML emails setting'
do
describe
'HTML emails setting'
do
let
(
:project
)
{
create
(
:empty_project
)
}
let
(
:project
)
{
create
(
:empty_project
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:multipart_mail
)
{
Notify
.
project_was_moved_email
(
project
.
id
,
user
.
id
,
"gitlab/gitlab"
)
}
let
(
:multipart_mail
)
{
described_class
.
project_was_moved_email
(
project
.
id
,
user
.
id
,
"gitlab/gitlab"
)
}
context
'when disabled'
do
context
'when disabled'
do
it
'only sends the text template'
do
it
'only sends the text template'
do
...
...
spec/requests/api/helpers/internal_helpers_spec.rb
View file @
d4976829
require
'spec_helper'
require
'spec_helper'
describe
::
API
::
Helpers
::
InternalHelpers
do
describe
::
API
::
Helpers
::
InternalHelpers
do
include
::
API
::
Helpers
::
InternalHelper
s
include
described_clas
s
describe
'.clean_project_path'
do
describe
'.clean_project_path'
do
project
=
'namespace/project'
project
=
'namespace/project'
...
...
spec/requests/api/helpers_spec.rb
View file @
d4976829
...
@@ -2,7 +2,7 @@ require 'spec_helper'
...
@@ -2,7 +2,7 @@ require 'spec_helper'
describe
API
::
Helpers
do
describe
API
::
Helpers
do
include
API
::
APIGuard
::
HelperMethods
include
API
::
APIGuard
::
HelperMethods
include
API
::
Helper
s
include
described_clas
s
include
SentryHelper
include
SentryHelper
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
...
...
spec/services/merge_requests/get_urls_service_spec.rb
View file @
d4976829
...
@@ -2,7 +2,7 @@ require "spec_helper"
...
@@ -2,7 +2,7 @@ require "spec_helper"
describe
MergeRequests
::
GetUrlsService
do
describe
MergeRequests
::
GetUrlsService
do
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
let
(
:service
)
{
MergeRequests
::
GetUrlsService
.
new
(
project
)
}
let
(
:service
)
{
described_class
.
new
(
project
)
}
let
(
:source_branch
)
{
"my_branch"
}
let
(
:source_branch
)
{
"my_branch"
}
let
(
:new_merge_request_url
)
{
"http://
#{
Gitlab
.
config
.
gitlab
.
host
}
/
#{
project
.
namespace
.
name
}
/
#{
project
.
path
}
/merge_requests/new?merge_request%5Bsource_branch%5D=
#{
source_branch
}
"
}
let
(
:new_merge_request_url
)
{
"http://
#{
Gitlab
.
config
.
gitlab
.
host
}
/
#{
project
.
namespace
.
name
}
/
#{
project
.
path
}
/merge_requests/new?merge_request%5Bsource_branch%5D=
#{
source_branch
}
"
}
let
(
:show_merge_request_url
)
{
"http://
#{
Gitlab
.
config
.
gitlab
.
host
}
/
#{
project
.
namespace
.
name
}
/
#{
project
.
path
}
/merge_requests/
#{
merge_request
.
iid
}
"
}
let
(
:show_merge_request_url
)
{
"http://
#{
Gitlab
.
config
.
gitlab
.
host
}
/
#{
project
.
namespace
.
name
}
/
#{
project
.
path
}
/merge_requests/
#{
merge_request
.
iid
}
"
}
...
@@ -89,7 +89,7 @@ describe MergeRequests::GetUrlsService do
...
@@ -89,7 +89,7 @@ describe MergeRequests::GetUrlsService do
let!
(
:merge_request
)
{
create
(
:merge_request
,
source_project:
forked_project
,
target_project:
project
,
source_branch:
source_branch
)
}
let!
(
:merge_request
)
{
create
(
:merge_request
,
source_project:
forked_project
,
target_project:
project
,
source_branch:
source_branch
)
}
let
(
:changes
)
{
existing_branch_changes
}
let
(
:changes
)
{
existing_branch_changes
}
# Source project is now the forked one
# Source project is now the forked one
let
(
:service
)
{
MergeRequests
::
GetUrlsService
.
new
(
forked_project
)
}
let
(
:service
)
{
described_class
.
new
(
forked_project
)
}
before
do
before
do
allow
(
forked_project
).
to
receive
(
:empty_repo?
).
and_return
(
false
)
allow
(
forked_project
).
to
receive
(
:empty_repo?
).
and_return
(
false
)
...
...
spec/services/merge_requests/merge_request_diff_cache_service_spec.rb
View file @
d4976829
require
'spec_helper'
require
'spec_helper'
describe
MergeRequests
::
MergeRequestDiffCacheService
do
describe
MergeRequests
::
MergeRequestDiffCacheService
do
let
(
:subject
)
{
MergeRequests
::
MergeRequestDiffCacheService
.
new
}
let
(
:subject
)
{
described_class
.
new
}
describe
'#execute'
do
describe
'#execute'
do
it
'retrieves the diff files to cache the highlighted result'
do
it
'retrieves the diff files to cache the highlighted result'
do
...
...
spec/services/merge_requests/resolve_service_spec.rb
View file @
d4976829
...
@@ -50,7 +50,7 @@ describe MergeRequests::ResolveService do
...
@@ -50,7 +50,7 @@ describe MergeRequests::ResolveService do
context
'when the source and target project are the same'
do
context
'when the source and target project are the same'
do
before
do
before
do
MergeRequests
::
ResolveService
.
new
(
project
,
user
,
params
).
execute
(
merge_request
)
described_class
.
new
(
project
,
user
,
params
).
execute
(
merge_request
)
end
end
it
'creates a commit with the message'
do
it
'creates a commit with the message'
do
...
@@ -75,7 +75,7 @@ describe MergeRequests::ResolveService do
...
@@ -75,7 +75,7 @@ describe MergeRequests::ResolveService do
end
end
before
do
before
do
MergeRequests
::
ResolveService
.
new
(
fork_project
,
user
,
params
).
execute
(
merge_request_from_fork
)
described_class
.
new
(
fork_project
,
user
,
params
).
execute
(
merge_request_from_fork
)
end
end
it
'creates a commit with the message'
do
it
'creates a commit with the message'
do
...
@@ -115,7 +115,7 @@ describe MergeRequests::ResolveService do
...
@@ -115,7 +115,7 @@ describe MergeRequests::ResolveService do
end
end
before
do
before
do
MergeRequests
::
ResolveService
.
new
(
project
,
user
,
params
).
execute
(
merge_request
)
described_class
.
new
(
project
,
user
,
params
).
execute
(
merge_request
)
end
end
it
'creates a commit with the message'
do
it
'creates a commit with the message'
do
...
@@ -154,7 +154,7 @@ describe MergeRequests::ResolveService do
...
@@ -154,7 +154,7 @@ describe MergeRequests::ResolveService do
}
}
end
end
let
(
:service
)
{
MergeRequests
::
ResolveService
.
new
(
project
,
user
,
invalid_params
)
}
let
(
:service
)
{
described_class
.
new
(
project
,
user
,
invalid_params
)
}
it
'raises a MissingResolution error'
do
it
'raises a MissingResolution error'
do
expect
{
service
.
execute
(
merge_request
)
}.
expect
{
service
.
execute
(
merge_request
)
}.
...
@@ -180,7 +180,7 @@ describe MergeRequests::ResolveService do
...
@@ -180,7 +180,7 @@ describe MergeRequests::ResolveService do
}
}
end
end
let
(
:service
)
{
MergeRequests
::
ResolveService
.
new
(
project
,
user
,
invalid_params
)
}
let
(
:service
)
{
described_class
.
new
(
project
,
user
,
invalid_params
)
}
it
'raises a MissingResolution error'
do
it
'raises a MissingResolution error'
do
expect
{
service
.
execute
(
merge_request
)
}.
expect
{
service
.
execute
(
merge_request
)
}.
...
@@ -202,7 +202,7 @@ describe MergeRequests::ResolveService do
...
@@ -202,7 +202,7 @@ describe MergeRequests::ResolveService do
}
}
end
end
let
(
:service
)
{
MergeRequests
::
ResolveService
.
new
(
project
,
user
,
invalid_params
)
}
let
(
:service
)
{
described_class
.
new
(
project
,
user
,
invalid_params
)
}
it
'raises a MissingFiles error'
do
it
'raises a MissingFiles error'
do
expect
{
service
.
execute
(
merge_request
)
}.
expect
{
service
.
execute
(
merge_request
)
}.
...
...
spec/services/projects/housekeeping_service_spec.rb
View file @
d4976829
require
'spec_helper'
require
'spec_helper'
describe
Projects
::
HousekeepingService
do
describe
Projects
::
HousekeepingService
do
subject
{
Projects
::
HousekeepingService
.
new
(
project
)
}
subject
{
described_class
.
new
(
project
)
}
let
(
:project
)
{
create
(
:project
,
:repository
)
}
let
(
:project
)
{
create
(
:project
,
:repository
)
}
before
do
before
do
...
...
spec/tasks/config_lint_spec.rb
View file @
d4976829
...
@@ -5,11 +5,11 @@ describe ConfigLint do
...
@@ -5,11 +5,11 @@ describe ConfigLint do
let
(
:files
){
[
'lib/support/fake.sh'
]
}
let
(
:files
){
[
'lib/support/fake.sh'
]
}
it
'errors out if any bash scripts have errors'
do
it
'errors out if any bash scripts have errors'
do
expect
{
ConfigLint
.
run
(
files
){
system
(
'exit 1'
)
}
}.
to
raise_error
(
SystemExit
)
expect
{
described_class
.
run
(
files
){
system
(
'exit 1'
)
}
}.
to
raise_error
(
SystemExit
)
end
end
it
'passes if all scripts are fine'
do
it
'passes if all scripts are fine'
do
expect
{
ConfigLint
.
run
(
files
){
system
(
'exit 0'
)
}
}.
not_to
raise_error
expect
{
described_class
.
run
(
files
){
system
(
'exit 0'
)
}
}.
not_to
raise_error
end
end
end
end
...
...
spec/workers/delete_user_worker_spec.rb
View file @
d4976829
...
@@ -8,13 +8,13 @@ describe DeleteUserWorker do
...
@@ -8,13 +8,13 @@ describe DeleteUserWorker do
expect_any_instance_of
(
Users
::
DestroyService
).
to
receive
(
:execute
).
expect_any_instance_of
(
Users
::
DestroyService
).
to
receive
(
:execute
).
with
(
user
,
{})
with
(
user
,
{})
DeleteUserWorker
.
new
.
perform
(
current_user
.
id
,
user
.
id
)
described_class
.
new
.
perform
(
current_user
.
id
,
user
.
id
)
end
end
it
"uses symbolized keys"
do
it
"uses symbolized keys"
do
expect_any_instance_of
(
Users
::
DestroyService
).
to
receive
(
:execute
).
expect_any_instance_of
(
Users
::
DestroyService
).
to
receive
(
:execute
).
with
(
user
,
test:
"test"
)
with
(
user
,
test:
"test"
)
DeleteUserWorker
.
new
.
perform
(
current_user
.
id
,
user
.
id
,
"test"
=>
"test"
)
described_class
.
new
.
perform
(
current_user
.
id
,
user
.
id
,
"test"
=>
"test"
)
end
end
end
end
spec/workers/emails_on_push_worker_spec.rb
View file @
d4976829
...
@@ -12,7 +12,7 @@ describe EmailsOnPushWorker do
...
@@ -12,7 +12,7 @@ describe EmailsOnPushWorker do
let
(
:perform
)
{
subject
.
perform
(
project
.
id
,
recipients
,
data
.
stringify_keys
)
}
let
(
:perform
)
{
subject
.
perform
(
project
.
id
,
recipients
,
data
.
stringify_keys
)
}
let
(
:email
)
{
ActionMailer
::
Base
.
deliveries
.
last
}
let
(
:email
)
{
ActionMailer
::
Base
.
deliveries
.
last
}
subject
{
EmailsOnPushWorker
.
new
}
subject
{
described_class
.
new
}
describe
"#perform"
do
describe
"#perform"
do
context
"when push is a new branch"
do
context
"when push is a new branch"
do
...
...
spec/workers/git_garbage_collect_worker_spec.rb
View file @
d4976829
...
@@ -6,7 +6,7 @@ describe GitGarbageCollectWorker do
...
@@ -6,7 +6,7 @@ describe GitGarbageCollectWorker do
let
(
:project
)
{
create
(
:project
,
:repository
)
}
let
(
:project
)
{
create
(
:project
,
:repository
)
}
let
(
:shell
)
{
Gitlab
::
Shell
.
new
}
let
(
:shell
)
{
Gitlab
::
Shell
.
new
}
subject
{
GitGarbageCollectWorker
.
new
}
subject
{
described_class
.
new
}
describe
"#perform"
do
describe
"#perform"
do
it
"flushes ref caches when the task is 'gc'"
do
it
"flushes ref caches when the task is 'gc'"
do
...
...
spec/workers/gitlab_usage_ping_worker_spec.rb
View file @
d4976829
require
'spec_helper'
require
'spec_helper'
describe
GitlabUsagePingWorker
do
describe
GitlabUsagePingWorker
do
subject
{
GitlabUsagePingWorker
.
new
}
subject
{
described_class
.
new
}
it
"sends POST request"
do
it
"sends POST request"
do
stub_application_setting
(
usage_ping_enabled:
true
)
stub_application_setting
(
usage_ping_enabled:
true
)
...
...
spec/workers/group_destroy_worker_spec.rb
View file @
d4976829
...
@@ -5,7 +5,7 @@ describe GroupDestroyWorker do
...
@@ -5,7 +5,7 @@ describe GroupDestroyWorker do
let
(
:user
)
{
create
(
:admin
)
}
let
(
:user
)
{
create
(
:admin
)
}
let!
(
:project
)
{
create
(
:empty_project
,
namespace:
group
)
}
let!
(
:project
)
{
create
(
:empty_project
,
namespace:
group
)
}
subject
{
GroupDestroyWorker
.
new
}
subject
{
described_class
.
new
}
describe
"#perform"
do
describe
"#perform"
do
it
"deletes the project"
do
it
"deletes the project"
do
...
...
spec/workers/merge_worker_spec.rb
View file @
d4976829
...
@@ -15,7 +15,7 @@ describe MergeWorker do
...
@@ -15,7 +15,7 @@ describe MergeWorker do
it
'clears cache of source repo after removing source branch'
do
it
'clears cache of source repo after removing source branch'
do
expect
(
source_project
.
repository
.
branch_names
).
to
include
(
'markdown'
)
expect
(
source_project
.
repository
.
branch_names
).
to
include
(
'markdown'
)
MergeWorker
.
new
.
perform
(
described_class
.
new
.
perform
(
merge_request
.
id
,
merge_request
.
author_id
,
merge_request
.
id
,
merge_request
.
author_id
,
commit_message:
'wow such merge'
,
commit_message:
'wow such merge'
,
should_remove_source_branch:
true
)
should_remove_source_branch:
true
)
...
...
spec/workers/post_receive_spec.rb
View file @
d4976829
...
@@ -10,7 +10,7 @@ describe PostReceive do
...
@@ -10,7 +10,7 @@ describe PostReceive do
context
"as a resque worker"
do
context
"as a resque worker"
do
it
"reponds to #perform"
do
it
"reponds to #perform"
do
expect
(
PostReceive
.
new
).
to
respond_to
(
:perform
)
expect
(
described_class
.
new
).
to
respond_to
(
:perform
)
end
end
end
end
...
@@ -25,7 +25,7 @@ describe PostReceive do
...
@@ -25,7 +25,7 @@ describe PostReceive do
it
"calls GitTagPushService"
do
it
"calls GitTagPushService"
do
expect_any_instance_of
(
GitPushService
).
to
receive
(
:execute
).
and_return
(
true
)
expect_any_instance_of
(
GitPushService
).
to
receive
(
:execute
).
and_return
(
true
)
expect_any_instance_of
(
GitTagPushService
).
not_to
receive
(
:execute
)
expect_any_instance_of
(
GitTagPushService
).
not_to
receive
(
:execute
)
PostReceive
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
described_class
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
end
end
end
end
...
@@ -35,7 +35,7 @@ describe PostReceive do
...
@@ -35,7 +35,7 @@ describe PostReceive do
it
"calls GitTagPushService"
do
it
"calls GitTagPushService"
do
expect_any_instance_of
(
GitPushService
).
not_to
receive
(
:execute
)
expect_any_instance_of
(
GitPushService
).
not_to
receive
(
:execute
)
expect_any_instance_of
(
GitTagPushService
).
to
receive
(
:execute
).
and_return
(
true
)
expect_any_instance_of
(
GitTagPushService
).
to
receive
(
:execute
).
and_return
(
true
)
PostReceive
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
described_class
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
end
end
end
end
...
@@ -45,12 +45,12 @@ describe PostReceive do
...
@@ -45,12 +45,12 @@ describe PostReceive do
it
"does not call any of the services"
do
it
"does not call any of the services"
do
expect_any_instance_of
(
GitPushService
).
not_to
receive
(
:execute
)
expect_any_instance_of
(
GitPushService
).
not_to
receive
(
:execute
)
expect_any_instance_of
(
GitTagPushService
).
not_to
receive
(
:execute
)
expect_any_instance_of
(
GitTagPushService
).
not_to
receive
(
:execute
)
PostReceive
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
described_class
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
end
end
end
end
context
"gitlab-ci.yml"
do
context
"gitlab-ci.yml"
do
subject
{
PostReceive
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
}
subject
{
described_class
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
}
context
"creates a Ci::Pipeline for every change"
do
context
"creates a Ci::Pipeline for every change"
do
before
do
before
do
...
@@ -75,7 +75,7 @@ describe PostReceive do
...
@@ -75,7 +75,7 @@ describe PostReceive do
context
"webhook"
do
context
"webhook"
do
it
"fetches the correct project"
do
it
"fetches the correct project"
do
expect
(
Project
).
to
receive
(
:find_by_full_path
).
with
(
project
.
path_with_namespace
).
and_return
(
project
)
expect
(
Project
).
to
receive
(
:find_by_full_path
).
with
(
project
.
path_with_namespace
).
and_return
(
project
)
PostReceive
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
described_class
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
end
end
it
"does not run if the author is not in the project"
do
it
"does not run if the author is not in the project"
do
...
@@ -85,7 +85,7 @@ describe PostReceive do
...
@@ -85,7 +85,7 @@ describe PostReceive do
expect
(
project
).
not_to
receive
(
:execute_hooks
)
expect
(
project
).
not_to
receive
(
:execute_hooks
)
expect
(
PostReceive
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)).
to
be_falsey
expect
(
described_class
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)).
to
be_falsey
end
end
it
"asks the project to trigger all hooks"
do
it
"asks the project to trigger all hooks"
do
...
@@ -93,14 +93,14 @@ describe PostReceive do
...
@@ -93,14 +93,14 @@ describe PostReceive do
expect
(
project
).
to
receive
(
:execute_hooks
).
twice
expect
(
project
).
to
receive
(
:execute_hooks
).
twice
expect
(
project
).
to
receive
(
:execute_services
).
twice
expect
(
project
).
to
receive
(
:execute_services
).
twice
PostReceive
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
described_class
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
end
end
it
"enqueues a UpdateMergeRequestsWorker job"
do
it
"enqueues a UpdateMergeRequestsWorker job"
do
allow
(
Project
).
to
receive
(
:find_by_full_path
).
and_return
(
project
)
allow
(
Project
).
to
receive
(
:find_by_full_path
).
and_return
(
project
)
expect
(
UpdateMergeRequestsWorker
).
to
receive
(
:perform_async
).
with
(
project
.
id
,
project
.
owner
.
id
,
any_args
)
expect
(
UpdateMergeRequestsWorker
).
to
receive
(
:perform_async
).
with
(
project
.
id
,
project
.
owner
.
id
,
any_args
)
PostReceive
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
described_class
.
new
.
perform
(
pwd
(
project
),
key_id
,
base64_changes
)
end
end
end
end
...
...
spec/workers/project_destroy_worker_spec.rb
View file @
d4976829
...
@@ -4,7 +4,7 @@ describe ProjectDestroyWorker do
...
@@ -4,7 +4,7 @@ describe ProjectDestroyWorker do
let
(
:project
)
{
create
(
:project
,
:repository
)
}
let
(
:project
)
{
create
(
:project
,
:repository
)
}
let
(
:path
)
{
project
.
repository
.
path_to_repo
}
let
(
:path
)
{
project
.
repository
.
path_to_repo
}
subject
{
ProjectDestroyWorker
.
new
}
subject
{
described_class
.
new
}
describe
"#perform"
do
describe
"#perform"
do
it
"deletes the project"
do
it
"deletes the project"
do
...
...
spec/workers/remove_expired_members_worker_spec.rb
View file @
d4976829
require
'spec_helper'
require
'spec_helper'
describe
RemoveExpiredMembersWorker
do
describe
RemoveExpiredMembersWorker
do
let
(
:worker
)
{
RemoveExpiredMembersWorker
.
new
}
let
(
:worker
)
{
described_class
.
new
}
describe
'#perform'
do
describe
'#perform'
do
context
'project members'
do
context
'project members'
do
...
...
spec/workers/remove_unreferenced_lfs_objects_worker_spec.rb
View file @
d4976829
require
'spec_helper'
require
'spec_helper'
describe
RemoveUnreferencedLfsObjectsWorker
do
describe
RemoveUnreferencedLfsObjectsWorker
do
let
(
:worker
)
{
RemoveUnreferencedLfsObjectsWorker
.
new
}
let
(
:worker
)
{
described_class
.
new
}
describe
'#perform'
do
describe
'#perform'
do
let!
(
:unreferenced_lfs_object1
)
{
create
(
:lfs_object
,
oid:
'1'
)
}
let!
(
:unreferenced_lfs_object1
)
{
create
(
:lfs_object
,
oid:
'1'
)
}
...
...
spec/workers/repository_fork_worker_spec.rb
View file @
d4976829
...
@@ -5,7 +5,7 @@ describe RepositoryForkWorker do
...
@@ -5,7 +5,7 @@ describe RepositoryForkWorker do
let
(
:fork_project
)
{
create
(
:project
,
:repository
,
forked_from_project:
project
)
}
let
(
:fork_project
)
{
create
(
:project
,
:repository
,
forked_from_project:
project
)
}
let
(
:shell
)
{
Gitlab
::
Shell
.
new
}
let
(
:shell
)
{
Gitlab
::
Shell
.
new
}
subject
{
RepositoryForkWorker
.
new
}
subject
{
described_class
.
new
}
before
do
before
do
allow
(
subject
).
to
receive
(
:gitlab_shell
).
and_return
(
shell
)
allow
(
subject
).
to
receive
(
:gitlab_shell
).
and_return
(
shell
)
...
...
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