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
Léo-Paul Géneau
gitlab-ce
Commits
991a2953
Commit
991a2953
authored
Nov 11, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add latest changes from gitlab-org/gitlab@master
parent
71d998ca
Changes
27
Hide whitespace changes
Inline
Side-by-side
Showing
27 changed files
with
179 additions
and
28 deletions
+179
-28
app/controllers/projects/merge_requests/diffs_controller.rb
app/controllers/projects/merge_requests/diffs_controller.rb
+4
-1
app/serializers/diff_file_entity.rb
app/serializers/diff_file_entity.rb
+18
-2
app/services/error_tracking/list_issues_service.rb
app/services/error_tracking/list_issues_service.rb
+4
-4
spec/controllers/projects/merge_requests/diffs_controller_spec.rb
...trollers/projects/merge_requests/diffs_controller_spec.rb
+13
-1
spec/features/merge_request/maintainer_edits_fork_spec.rb
spec/features/merge_request/maintainer_edits_fork_spec.rb
+3
-1
spec/features/merge_request/user_comments_on_diff_spec.rb
spec/features/merge_request/user_comments_on_diff_spec.rb
+3
-0
spec/features/merge_request/user_creates_image_diff_notes_spec.rb
...tures/merge_request/user_creates_image_diff_notes_spec.rb
+3
-0
spec/features/merge_request/user_expands_diff_spec.rb
spec/features/merge_request/user_expands_diff_spec.rb
+4
-0
spec/features/merge_request/user_posts_diff_notes_spec.rb
spec/features/merge_request/user_posts_diff_notes_spec.rb
+3
-0
spec/features/merge_request/user_resolves_conflicts_spec.rb
spec/features/merge_request/user_resolves_conflicts_spec.rb
+4
-1
spec/features/merge_request/user_resolves_diff_notes_and_discussions_resolve_spec.rb
.../user_resolves_diff_notes_and_discussions_resolve_spec.rb
+6
-0
spec/features/merge_request/user_sees_avatar_on_diff_notes_spec.rb
...ures/merge_request/user_sees_avatar_on_diff_notes_spec.rb
+5
-2
spec/features/merge_request/user_sees_diff_spec.rb
spec/features/merge_request/user_sees_diff_spec.rb
+6
-0
spec/features/merge_request/user_sees_mr_with_deleted_source_branch_spec.rb
...e_request/user_sees_mr_with_deleted_source_branch_spec.rb
+3
-0
spec/features/merge_request/user_sees_versions_spec.rb
spec/features/merge_request/user_sees_versions_spec.rb
+4
-0
spec/features/merge_request/user_suggests_changes_on_diff_spec.rb
...tures/merge_request/user_suggests_changes_on_diff_spec.rb
+3
-0
spec/features/merge_request/user_toggles_whitespace_changes_spec.rb
...res/merge_request/user_toggles_whitespace_changes_spec.rb
+3
-0
spec/features/merge_request/user_views_diffs_spec.rb
spec/features/merge_request/user_views_diffs_spec.rb
+3
-0
spec/features/projects/blobs/edit_spec.rb
spec/features/projects/blobs/edit_spec.rb
+8
-6
spec/features/projects/view_on_env_spec.rb
spec/features/projects/view_on_env_spec.rb
+7
-3
spec/lib/gitlab/auth/ldap/auth_hash_spec.rb
spec/lib/gitlab/auth/ldap/auth_hash_spec.rb
+3
-1
spec/lib/gitlab/auth/ldap/person_spec.rb
spec/lib/gitlab/auth/ldap/person_spec.rb
+3
-1
spec/serializers/diff_file_entity_spec.rb
spec/serializers/diff_file_entity_spec.rb
+5
-2
spec/services/error_tracking/list_issues_service_spec.rb
spec/services/error_tracking/list_issues_service_spec.rb
+8
-0
spec/support/capybara.rb
spec/support/capybara.rb
+5
-1
spec/support/shared_examples/merge_requests_rendering_a_single_diff_version.rb
...xamples/merge_requests_rendering_a_single_diff_version.rb
+17
-0
spec/support/shared_examples/serializers/diff_file_entity_examples.rb
.../shared_examples/serializers/diff_file_entity_examples.rb
+31
-2
No files found.
app/controllers/projects/merge_requests/diffs_controller.rb
View file @
991a2953
...
@@ -31,6 +31,7 @@ class Projects::MergeRequests::DiffsController < Projects::MergeRequests::Applic
...
@@ -31,6 +31,7 @@ class Projects::MergeRequests::DiffsController < Projects::MergeRequests::Applic
options
=
{
options
=
{
merge_request:
@merge_request
,
merge_request:
@merge_request
,
diff_view:
diff_view
,
pagination_data:
diffs
.
pagination_data
pagination_data:
diffs
.
pagination_data
}
}
...
@@ -60,7 +61,9 @@ class Projects::MergeRequests::DiffsController < Projects::MergeRequests::Applic
...
@@ -60,7 +61,9 @@ class Projects::MergeRequests::DiffsController < Projects::MergeRequests::Applic
render:
->
(
partial
,
locals
)
{
view_to_html_string
(
partial
,
locals
)
}
render:
->
(
partial
,
locals
)
{
view_to_html_string
(
partial
,
locals
)
}
}
}
render
json:
DiffsSerializer
.
new
(
request
).
represent
(
@diffs
,
additional_attributes
)
options
=
additional_attributes
.
merge
(
diff_view:
diff_view
)
render
json:
DiffsSerializer
.
new
(
request
).
represent
(
@diffs
,
options
)
end
end
def
define_diff_vars
def
define_diff_vars
...
...
app/serializers/diff_file_entity.rb
View file @
991a2953
...
@@ -53,7 +53,7 @@ class DiffFileEntity < DiffFileBaseEntity
...
@@ -53,7 +53,7 @@ class DiffFileEntity < DiffFileBaseEntity
end
end
# Used for inline diffs
# Used for inline diffs
expose
:highlighted_diff_lines
,
using:
DiffLineEntity
,
if:
->
(
diff_file
,
_
)
{
diff_file
.
text?
}
do
|
diff_file
|
expose
:highlighted_diff_lines
,
using:
DiffLineEntity
,
if:
->
(
diff_file
,
options
)
{
inline_diff_view?
(
options
)
&&
diff_file
.
text?
}
do
|
diff_file
|
diff_file
.
diff_lines_for_serializer
diff_file
.
diff_lines_for_serializer
end
end
...
@@ -62,5 +62,21 @@ class DiffFileEntity < DiffFileBaseEntity
...
@@ -62,5 +62,21 @@ class DiffFileEntity < DiffFileBaseEntity
end
end
# Used for parallel diffs
# Used for parallel diffs
expose
:parallel_diff_lines
,
using:
DiffLineParallelEntity
,
if:
->
(
diff_file
,
_
)
{
diff_file
.
text?
}
expose
:parallel_diff_lines
,
using:
DiffLineParallelEntity
,
if:
->
(
diff_file
,
options
)
{
parallel_diff_view?
(
options
)
&&
diff_file
.
text?
}
private
def
parallel_diff_view?
(
options
)
return
true
unless
Feature
.
enabled?
(
:single_mr_diff_view
)
# If we're not rendering inline, we must be rendering parallel
!
inline_diff_view?
(
options
)
end
def
inline_diff_view?
(
options
)
return
true
unless
Feature
.
enabled?
(
:single_mr_diff_view
)
# If nothing is present, inline will be the default.
options
.
fetch
(
:diff_view
,
:inline
).
to_sym
==
:inline
end
end
end
app/services/error_tracking/list_issues_service.rb
View file @
991a2953
...
@@ -5,6 +5,10 @@ module ErrorTracking
...
@@ -5,6 +5,10 @@ module ErrorTracking
DEFAULT_ISSUE_STATUS
=
'unresolved'
DEFAULT_ISSUE_STATUS
=
'unresolved'
DEFAULT_LIMIT
=
20
DEFAULT_LIMIT
=
20
def
external_url
project_error_tracking_setting
&
.
sentry_external_url
end
private
private
def
fetch
def
fetch
...
@@ -15,10 +19,6 @@ module ErrorTracking
...
@@ -15,10 +19,6 @@ module ErrorTracking
{
issues:
response
[
:issues
]
}
{
issues:
response
[
:issues
]
}
end
end
def
external_url
project_error_tracking_setting
&
.
sentry_external_url
end
def
issue_status
def
issue_status
params
[
:issue_status
]
||
DEFAULT_ISSUE_STATUS
params
[
:issue_status
]
||
DEFAULT_ISSUE_STATUS
end
end
...
...
spec/controllers/projects/merge_requests/diffs_controller_spec.rb
View file @
991a2953
...
@@ -34,6 +34,16 @@ describe Projects::MergeRequests::DiffsController do
...
@@ -34,6 +34,16 @@ describe Projects::MergeRequests::DiffsController do
it
'saves the preferred diff view in a cookie'
do
it
'saves the preferred diff view in a cookie'
do
expect
(
response
.
cookies
[
'diff_view'
]).
to
eq
(
'parallel'
)
expect
(
response
.
cookies
[
'diff_view'
]).
to
eq
(
'parallel'
)
end
end
it
'only renders the required view'
,
:aggregate_failures
do
diff_files_without_deletions
=
json_response
[
'diff_files'
].
reject
{
|
f
|
f
[
'deleted_file'
]
}
have_no_inline_diff_lines
=
satisfy
(
'have no inline diff lines'
)
do
|
diff_file
|
!
diff_file
.
has_key?
(
'highlighted_diff_lines'
)
end
expect
(
diff_files_without_deletions
).
to
all
(
have_key
(
'parallel_diff_lines'
))
expect
(
diff_files_without_deletions
).
to
all
(
have_no_inline_diff_lines
)
end
end
end
context
'when the user cannot view the merge request'
do
context
'when the user cannot view the merge request'
do
...
@@ -259,7 +269,7 @@ describe Projects::MergeRequests::DiffsController do
...
@@ -259,7 +269,7 @@ describe Projects::MergeRequests::DiffsController do
it
'only renders the diffs for the path given'
do
it
'only renders the diffs for the path given'
do
diff_for_path
(
old_path:
existing_path
,
new_path:
existing_path
)
diff_for_path
(
old_path:
existing_path
,
new_path:
existing_path
)
paths
=
json_response
[
"diff_files"
].
map
{
|
file
|
file
[
'new_path'
]
}
paths
=
json_response
[
'diff_files'
].
map
{
|
file
|
file
[
'new_path'
]
}
expect
(
paths
).
to
include
(
existing_path
)
expect
(
paths
).
to
include
(
existing_path
)
end
end
...
@@ -344,6 +354,7 @@ describe Projects::MergeRequests::DiffsController do
...
@@ -344,6 +354,7 @@ describe Projects::MergeRequests::DiffsController do
let
(
:expected_options
)
do
let
(
:expected_options
)
do
{
{
merge_request:
merge_request
,
merge_request:
merge_request
,
diff_view: :inline
,
pagination_data:
{
pagination_data:
{
current_page:
1
,
current_page:
1
,
next_page:
nil
,
next_page:
nil
,
...
@@ -367,6 +378,7 @@ describe Projects::MergeRequests::DiffsController do
...
@@ -367,6 +378,7 @@ describe Projects::MergeRequests::DiffsController do
let
(
:expected_options
)
do
let
(
:expected_options
)
do
{
{
merge_request:
merge_request
,
merge_request:
merge_request
,
diff_view: :inline
,
pagination_data:
{
pagination_data:
{
current_page:
2
,
current_page:
2
,
next_page:
3
,
next_page:
3
,
...
...
spec/features/merge_request/maintainer_edits_fork_spec.rb
View file @
991a2953
...
@@ -20,7 +20,7 @@ describe 'a maintainer edits files on a source-branch of an MR from a fork', :js
...
@@ -20,7 +20,7 @@ describe 'a maintainer edits files on a source-branch of an MR from a fork', :js
end
end
before
do
before
do
stub_feature_flags
(
web_ide_default:
false
)
stub_feature_flags
(
web_ide_default:
false
,
single_mr_diff_view:
false
)
target_project
.
add_maintainer
(
user
)
target_project
.
add_maintainer
(
user
)
sign_in
(
user
)
sign_in
(
user
)
...
@@ -32,6 +32,8 @@ describe 'a maintainer edits files on a source-branch of an MR from a fork', :js
...
@@ -32,6 +32,8 @@ describe 'a maintainer edits files on a source-branch of an MR from a fork', :js
wait_for_requests
wait_for_requests
end
end
it_behaves_like
'rendering a single diff version'
it
'mentions commits will go to the source branch'
do
it
'mentions commits will go to the source branch'
do
expect
(
page
).
to
have_content
(
'Your changes can be committed to fix because a merge request is open.'
)
expect
(
page
).
to
have_content
(
'Your changes can be committed to fix because a merge request is open.'
)
end
end
...
...
spec/features/merge_request/user_comments_on_diff_spec.rb
View file @
991a2953
...
@@ -13,12 +13,15 @@ describe 'User comments on a diff', :js do
...
@@ -13,12 +13,15 @@ describe 'User comments on a diff', :js do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
sign_in
(
user
)
sign_in
(
user
)
visit
(
diffs_project_merge_request_path
(
project
,
merge_request
))
visit
(
diffs_project_merge_request_path
(
project
,
merge_request
))
end
end
it_behaves_like
'rendering a single diff version'
context
'when viewing comments'
do
context
'when viewing comments'
do
context
'when toggling inline comments'
do
context
'when toggling inline comments'
do
context
'in a single file'
do
context
'in a single file'
do
...
...
spec/features/merge_request/user_creates_image_diff_notes_spec.rb
View file @
991a2953
...
@@ -9,6 +9,7 @@ describe 'Merge request > User creates image diff notes', :js do
...
@@ -9,6 +9,7 @@ describe 'Merge request > User creates image diff notes', :js do
let
(
:user
)
{
project
.
creator
}
let
(
:user
)
{
project
.
creator
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
sign_in
(
user
)
sign_in
(
user
)
# Stub helper to return any blob file as image from public app folder.
# Stub helper to return any blob file as image from public app folder.
...
@@ -17,6 +18,8 @@ describe 'Merge request > User creates image diff notes', :js do
...
@@ -17,6 +18,8 @@ describe 'Merge request > User creates image diff notes', :js do
allow_any_instance_of
(
DiffHelper
).
to
receive
(
:diff_file_old_blob_raw_url
).
and_return
(
'/favicon.png'
)
allow_any_instance_of
(
DiffHelper
).
to
receive
(
:diff_file_old_blob_raw_url
).
and_return
(
'/favicon.png'
)
end
end
it_behaves_like
'rendering a single diff version'
context
'create commit diff notes'
do
context
'create commit diff notes'
do
commit_id
=
'2f63565e7aac07bcdadb654e253078b727143ec4'
commit_id
=
'2f63565e7aac07bcdadb654e253078b727143ec4'
...
...
spec/features/merge_request/user_expands_diff_spec.rb
View file @
991a2953
...
@@ -7,6 +7,8 @@ describe 'User expands diff', :js do
...
@@ -7,6 +7,8 @@ describe 'User expands diff', :js do
let
(
:merge_request
)
{
create
(
:merge_request
,
source_branch:
'expand-collapse-files'
,
source_project:
project
,
target_project:
project
)
}
let
(
:merge_request
)
{
create
(
:merge_request
,
source_branch:
'expand-collapse-files'
,
source_project:
project
,
target_project:
project
)
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
allow
(
Gitlab
::
Git
::
Diff
).
to
receive
(
:size_limit
).
and_return
(
100
.
kilobytes
)
allow
(
Gitlab
::
Git
::
Diff
).
to
receive
(
:size_limit
).
and_return
(
100
.
kilobytes
)
allow
(
Gitlab
::
Git
::
Diff
).
to
receive
(
:collapse_limit
).
and_return
(
10
.
kilobytes
)
allow
(
Gitlab
::
Git
::
Diff
).
to
receive
(
:collapse_limit
).
and_return
(
10
.
kilobytes
)
...
@@ -15,6 +17,8 @@ describe 'User expands diff', :js do
...
@@ -15,6 +17,8 @@ describe 'User expands diff', :js do
wait_for_requests
wait_for_requests
end
end
it_behaves_like
'rendering a single diff version'
it
'allows user to expand diff'
do
it
'allows user to expand diff'
do
page
.
within
find
(
'[id="2f6fcd96b88b36ce98c38da085c795a27d92a3dd"]'
)
do
page
.
within
find
(
'[id="2f6fcd96b88b36ce98c38da085c795a27d92a3dd"]'
)
do
click_link
'Click to expand it.'
click_link
'Click to expand it.'
...
...
spec/features/merge_request/user_posts_diff_notes_spec.rb
View file @
991a2953
...
@@ -14,12 +14,15 @@ describe 'Merge request > User posts diff notes', :js do
...
@@ -14,12 +14,15 @@ describe 'Merge request > User posts diff notes', :js do
let
(
:test_note_comment
)
{
'this is a test note!'
}
let
(
:test_note_comment
)
{
'this is a test note!'
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
set_cookie
(
'sidebar_collapsed'
,
'true'
)
set_cookie
(
'sidebar_collapsed'
,
'true'
)
project
.
add_developer
(
user
)
project
.
add_developer
(
user
)
sign_in
(
user
)
sign_in
(
user
)
end
end
it_behaves_like
'rendering a single diff version'
context
'when hovering over a parallel view diff file'
do
context
'when hovering over a parallel view diff file'
do
before
do
before
do
visit
diffs_project_merge_request_path
(
project
,
merge_request
,
view:
'parallel'
)
visit
diffs_project_merge_request_path
(
project
,
merge_request
,
view:
'parallel'
)
...
...
spec/features/merge_request/user_resolves_conflicts_spec.rb
View file @
991a2953
...
@@ -9,6 +9,7 @@ describe 'Merge request > User resolves conflicts', :js do
...
@@ -9,6 +9,7 @@ describe 'Merge request > User resolves conflicts', :js do
before
do
before
do
# In order to have the diffs collapsed, we need to disable the increase feature
# In order to have the diffs collapsed, we need to disable the increase feature
stub_feature_flags
(
gitlab_git_diff_size_limit_increase:
false
)
stub_feature_flags
(
gitlab_git_diff_size_limit_increase:
false
)
stub_feature_flags
(
single_mr_diff_view:
false
)
end
end
def
create_merge_request
(
source_branch
)
def
create_merge_request
(
source_branch
)
...
@@ -17,7 +18,9 @@ describe 'Merge request > User resolves conflicts', :js do
...
@@ -17,7 +18,9 @@ describe 'Merge request > User resolves conflicts', :js do
end
end
end
end
shared_examples
"conflicts are resolved in Interactive mode"
do
it_behaves_like
'rendering a single diff version'
shared_examples
'conflicts are resolved in Interactive mode'
do
it
'conflicts are resolved in Interactive mode'
do
it
'conflicts are resolved in Interactive mode'
do
within
find
(
'.files-wrapper .diff-file'
,
text:
'files/ruby/popen.rb'
)
do
within
find
(
'.files-wrapper .diff-file'
,
text:
'files/ruby/popen.rb'
)
do
click_button
'Use ours'
click_button
'Use ours'
...
...
spec/features/merge_request/user_resolves_diff_notes_and_discussions_resolve_spec.rb
View file @
991a2953
...
@@ -19,6 +19,12 @@ describe 'Merge request > User resolves diff notes and threads', :js do
...
@@ -19,6 +19,12 @@ describe 'Merge request > User resolves diff notes and threads', :js do
)
)
end
end
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
end
it_behaves_like
'rendering a single diff version'
context
'no threads'
do
context
'no threads'
do
before
do
before
do
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
...
...
spec/features/merge_request/user_sees_avatar_on_diff_notes_spec.rb
View file @
991a2953
...
@@ -7,8 +7,8 @@ describe 'Merge request > User sees avatars on diff notes', :js do
...
@@ -7,8 +7,8 @@ describe 'Merge request > User sees avatars on diff notes', :js do
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
let
(
:user
)
{
project
.
creator
}
let
(
:user
)
{
project
.
creator
}
let
(
:merge_request
)
{
create
(
:merge_request_with_diffs
,
source_project:
project
,
author:
user
,
title:
"Bug NS-04"
)
}
let
(
:merge_request
)
{
create
(
:merge_request_with_diffs
,
source_project:
project
,
author:
user
,
title:
'Bug NS-04'
)
}
let
(
:path
)
{
"files/ruby/popen.rb"
}
let
(
:path
)
{
'files/ruby/popen.rb'
}
let
(
:position
)
do
let
(
:position
)
do
Gitlab
::
Diff
::
Position
.
new
(
Gitlab
::
Diff
::
Position
.
new
(
old_path:
path
,
old_path:
path
,
...
@@ -21,12 +21,15 @@ describe 'Merge request > User sees avatars on diff notes', :js do
...
@@ -21,12 +21,15 @@ describe 'Merge request > User sees avatars on diff notes', :js do
let!
(
:note
)
{
create
(
:diff_note_on_merge_request
,
project:
project
,
noteable:
merge_request
,
position:
position
)
}
let!
(
:note
)
{
create
(
:diff_note_on_merge_request
,
project:
project
,
noteable:
merge_request
,
position:
position
)
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
sign_in
user
sign_in
user
set_cookie
(
'sidebar_collapsed'
,
'true'
)
set_cookie
(
'sidebar_collapsed'
,
'true'
)
end
end
it_behaves_like
'rendering a single diff version'
context
'discussion tab'
do
context
'discussion tab'
do
before
do
before
do
visit
project_merge_request_path
(
project
,
merge_request
)
visit
project_merge_request_path
(
project
,
merge_request
)
...
...
spec/features/merge_request/user_sees_diff_spec.rb
View file @
991a2953
...
@@ -9,6 +9,12 @@ describe 'Merge request > User sees diff', :js do
...
@@ -9,6 +9,12 @@ describe 'Merge request > User sees diff', :js do
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
let
(
:merge_request
)
{
create
(
:merge_request
,
source_project:
project
)
}
let
(
:merge_request
)
{
create
(
:merge_request
,
source_project:
project
)
}
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
end
it_behaves_like
'rendering a single diff version'
context
'when linking to note'
do
context
'when linking to note'
do
describe
'with unresolved note'
do
describe
'with unresolved note'
do
let
(
:note
)
{
create
:diff_note_on_merge_request
,
project:
project
,
noteable:
merge_request
}
let
(
:note
)
{
create
:diff_note_on_merge_request
,
project:
project
,
noteable:
merge_request
}
...
...
spec/features/merge_request/user_sees_mr_with_deleted_source_branch_spec.rb
View file @
991a2953
...
@@ -11,11 +11,14 @@ describe 'Merge request > User sees MR with deleted source branch', :js do
...
@@ -11,11 +11,14 @@ describe 'Merge request > User sees MR with deleted source branch', :js do
let
(
:user
)
{
project
.
creator
}
let
(
:user
)
{
project
.
creator
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
merge_request
.
update!
(
source_branch:
'this-branch-does-not-exist'
)
merge_request
.
update!
(
source_branch:
'this-branch-does-not-exist'
)
sign_in
(
user
)
sign_in
(
user
)
visit
project_merge_request_path
(
project
,
merge_request
)
visit
project_merge_request_path
(
project
,
merge_request
)
end
end
it_behaves_like
'rendering a single diff version'
it
'shows a message about missing source branch'
do
it
'shows a message about missing source branch'
do
expect
(
page
).
to
have_content
(
'Source branch does not exist.'
)
expect
(
page
).
to
have_content
(
'Source branch does not exist.'
)
end
end
...
...
spec/features/merge_request/user_sees_versions_spec.rb
View file @
991a2953
...
@@ -16,11 +16,15 @@ describe 'Merge request > User sees versions', :js do
...
@@ -16,11 +16,15 @@ describe 'Merge request > User sees versions', :js do
let!
(
:params
)
{
{}
}
let!
(
:params
)
{
{}
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
sign_in
(
user
)
sign_in
(
user
)
visit
diffs_project_merge_request_path
(
project
,
merge_request
,
params
)
visit
diffs_project_merge_request_path
(
project
,
merge_request
,
params
)
end
end
it_behaves_like
'rendering a single diff version'
shared_examples
'allows commenting'
do
|
file_id
:,
line_code
:,
comment
:|
shared_examples
'allows commenting'
do
|
file_id
:,
line_code
:,
comment
:|
it
do
it
do
diff_file_selector
=
".diff-file[id='
#{
file_id
}
']"
diff_file_selector
=
".diff-file[id='
#{
file_id
}
']"
...
...
spec/features/merge_request/user_suggests_changes_on_diff_spec.rb
View file @
991a2953
...
@@ -25,12 +25,15 @@ describe 'User comments on a diff', :js do
...
@@ -25,12 +25,15 @@ describe 'User comments on a diff', :js do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
sign_in
(
user
)
sign_in
(
user
)
visit
(
diffs_project_merge_request_path
(
project
,
merge_request
))
visit
(
diffs_project_merge_request_path
(
project
,
merge_request
))
end
end
it_behaves_like
'rendering a single diff version'
context
'single suggestion note'
do
context
'single suggestion note'
do
it
'hides suggestion popover'
do
it
'hides suggestion popover'
do
click_diff_line
(
find
(
"[id='
#{
sample_compare
.
changes
[
1
][
:line_code
]
}
']"
))
click_diff_line
(
find
(
"[id='
#{
sample_compare
.
changes
[
1
][
:line_code
]
}
']"
))
...
...
spec/features/merge_request/user_toggles_whitespace_changes_spec.rb
View file @
991a2953
...
@@ -8,6 +8,7 @@ describe 'Merge request > User toggles whitespace changes', :js do
...
@@ -8,6 +8,7 @@ describe 'Merge request > User toggles whitespace changes', :js do
let
(
:user
)
{
project
.
creator
}
let
(
:user
)
{
project
.
creator
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
sign_in
(
user
)
sign_in
(
user
)
visit
diffs_project_merge_request_path
(
project
,
merge_request
)
visit
diffs_project_merge_request_path
(
project
,
merge_request
)
...
@@ -15,6 +16,8 @@ describe 'Merge request > User toggles whitespace changes', :js do
...
@@ -15,6 +16,8 @@ describe 'Merge request > User toggles whitespace changes', :js do
find
(
'.js-show-diff-settings'
).
click
find
(
'.js-show-diff-settings'
).
click
end
end
it_behaves_like
'rendering a single diff version'
it
'has a button to toggle whitespace changes'
do
it
'has a button to toggle whitespace changes'
do
expect
(
page
).
to
have_content
'Show whitespace changes'
expect
(
page
).
to
have_content
'Show whitespace changes'
end
end
...
...
spec/features/merge_request/user_views_diffs_spec.rb
View file @
991a2953
...
@@ -9,6 +9,7 @@ describe 'User views diffs', :js do
...
@@ -9,6 +9,7 @@ describe 'User views diffs', :js do
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
let
(
:project
)
{
create
(
:project
,
:public
,
:repository
)
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
visit
(
diffs_project_merge_request_path
(
project
,
merge_request
))
visit
(
diffs_project_merge_request_path
(
project
,
merge_request
))
wait_for_requests
wait_for_requests
...
@@ -16,6 +17,8 @@ describe 'User views diffs', :js do
...
@@ -16,6 +17,8 @@ describe 'User views diffs', :js do
find
(
'.js-toggle-tree-list'
).
click
find
(
'.js-toggle-tree-list'
).
click
end
end
it_behaves_like
'rendering a single diff version'
shared_examples
'unfold diffs'
do
shared_examples
'unfold diffs'
do
it
'unfolds diffs upwards'
do
it
'unfolds diffs upwards'
do
first
(
'.js-unfold'
).
click
first
(
'.js-unfold'
).
click
...
...
spec/features/projects/blobs/edit_spec.rb
View file @
991a2953
...
@@ -12,9 +12,11 @@ describe 'Editing file blob', :js do
...
@@ -12,9 +12,11 @@ describe 'Editing file blob', :js do
let
(
:readme_file_path
)
{
'README.md'
}
let
(
:readme_file_path
)
{
'README.md'
}
before
do
before
do
stub_feature_flags
(
web_ide_default:
false
)
stub_feature_flags
(
web_ide_default:
false
,
single_mr_diff_view:
false
)
end
end
it_behaves_like
'rendering a single diff version'
context
'as a developer'
do
context
'as a developer'
do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:role
)
{
:developer
}
let
(
:role
)
{
:developer
}
...
@@ -27,14 +29,14 @@ describe 'Editing file blob', :js do
...
@@ -27,14 +29,14 @@ describe 'Editing file blob', :js do
def
edit_and_commit
(
commit_changes:
true
)
def
edit_and_commit
(
commit_changes:
true
)
wait_for_requests
wait_for_requests
find
(
'.js-edit-blob'
).
click
find
(
'.js-edit-blob'
).
click
fill_editor
(
content:
"class NextFeature
\\
nend
\\
n"
)
fill_editor
(
content:
'class NextFeature\\nend\\n'
)
if
commit_changes
if
commit_changes
click_button
'Commit changes'
click_button
'Commit changes'
end
end
end
end
def
fill_editor
(
content:
"class NextFeature
\\
nend
\\
n"
)
def
fill_editor
(
content:
'class NextFeature\\nend\\n'
)
wait_for_requests
wait_for_requests
find
(
'#editor'
)
find
(
'#editor'
)
execute_script
(
"ace.edit('editor').setValue('
#{
content
}
')"
)
execute_script
(
"ace.edit('editor').setValue('
#{
content
}
')"
)
...
@@ -95,13 +97,13 @@ describe 'Editing file blob', :js do
...
@@ -95,13 +97,13 @@ describe 'Editing file blob', :js do
context
'when rendering the preview'
do
context
'when rendering the preview'
do
it
'renders content with CommonMark'
do
it
'renders content with CommonMark'
do
visit
project_edit_blob_path
(
project
,
tree_join
(
branch
,
readme_file_path
))
visit
project_edit_blob_path
(
project
,
tree_join
(
branch
,
readme_file_path
))
fill_editor
(
content:
"1. one
\\
n - sublist
\\
n"
)
fill_editor
(
content:
'1. one\\n - sublist\\n'
)
click_link
'Preview'
click_link
'Preview'
wait_for_requests
wait_for_requests
# the above generates two separate lists (not embedded) in CommonMark
# the above generates two separate lists (not embedded) in CommonMark
expect
(
page
).
to
have_content
(
"sublist"
)
expect
(
page
).
to
have_content
(
'sublist'
)
expect
(
page
).
not_to
have_xpath
(
"//ol//li//ul"
)
expect
(
page
).
not_to
have_xpath
(
'//ol//li//ul'
)
end
end
end
end
end
end
...
...
spec/features/projects/view_on_env_spec.rb
View file @
991a2953
...
@@ -9,9 +9,13 @@ describe 'View on environment', :js do
...
@@ -9,9 +9,13 @@ describe 'View on environment', :js do
let
(
:user
)
{
project
.
creator
}
let
(
:user
)
{
project
.
creator
}
before
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
project
.
add_maintainer
(
user
)
project
.
add_maintainer
(
user
)
end
end
it_behaves_like
'rendering a single diff version'
context
'when the branch has a route map'
do
context
'when the branch has a route map'
do
let
(
:route_map
)
do
let
(
:route_map
)
do
<<-
MAP
.
strip_heredoc
<<-
MAP
.
strip_heredoc
...
@@ -26,7 +30,7 @@ describe 'View on environment', :js do
...
@@ -26,7 +30,7 @@ describe 'View on environment', :js do
user
,
user
,
start_branch:
branch_name
,
start_branch:
branch_name
,
branch_name:
branch_name
,
branch_name:
branch_name
,
commit_message:
"Add .gitlab/route-map.yml"
,
commit_message:
'Add .gitlab/route-map.yml'
,
file_path:
'.gitlab/route-map.yml'
,
file_path:
'.gitlab/route-map.yml'
,
file_content:
route_map
file_content:
route_map
).
execute
).
execute
...
@@ -37,9 +41,9 @@ describe 'View on environment', :js do
...
@@ -37,9 +41,9 @@ describe 'View on environment', :js do
user
,
user
,
start_branch:
branch_name
,
start_branch:
branch_name
,
branch_name:
branch_name
,
branch_name:
branch_name
,
commit_message:
"Update feature"
,
commit_message:
'Update feature'
,
file_path:
file_path
,
file_path:
file_path
,
file_content:
"# Noop"
file_content:
'# Noop'
).
execute
).
execute
end
end
...
...
spec/lib/gitlab/auth/ldap/auth_hash_spec.rb
View file @
991a2953
# frozen_string_literal: true
require
'spec_helper'
require
'spec_helper'
describe
Gitlab
::
Auth
::
LDAP
::
AuthHash
do
describe
Gitlab
::
Auth
::
LDAP
::
AuthHash
do
...
@@ -91,7 +93,7 @@ describe Gitlab::Auth::LDAP::AuthHash do
...
@@ -91,7 +93,7 @@ describe Gitlab::Auth::LDAP::AuthHash do
let
(
:given_uid
)
{
'uid=John Smith,ou=People,dc=example,dc=com'
}
let
(
:given_uid
)
{
'uid=John Smith,ou=People,dc=example,dc=com'
}
before
do
before
do
raw_info
[
:uid
]
=
[
'JOHN'
]
raw_info
[
:uid
]
=
[
+
'JOHN'
]
end
end
it
'enabled the username attribute is lower cased'
do
it
'enabled the username attribute is lower cased'
do
...
...
spec/lib/gitlab/auth/ldap/person_spec.rb
View file @
991a2953
# frozen_string_literal: true
require
'spec_helper'
require
'spec_helper'
describe
Gitlab
::
Auth
::
LDAP
::
Person
do
describe
Gitlab
::
Auth
::
LDAP
::
Person
do
...
@@ -135,7 +137,7 @@ describe Gitlab::Auth::LDAP::Person do
...
@@ -135,7 +137,7 @@ describe Gitlab::Auth::LDAP::Person do
let
(
:username_attribute
)
{
'uid'
}
let
(
:username_attribute
)
{
'uid'
}
before
do
before
do
entry
[
username_attribute
]
=
'JOHN'
entry
[
username_attribute
]
=
+
'JOHN'
@person
=
described_class
.
new
(
entry
,
'ldapmain'
)
@person
=
described_class
.
new
(
entry
,
'ldapmain'
)
end
end
...
...
spec/serializers/diff_file_entity_spec.rb
View file @
991a2953
...
@@ -11,7 +11,8 @@ describe DiffFileEntity do
...
@@ -11,7 +11,8 @@ describe DiffFileEntity do
let
(
:diff_refs
)
{
commit
.
diff_refs
}
let
(
:diff_refs
)
{
commit
.
diff_refs
}
let
(
:diff
)
{
commit
.
raw_diffs
.
first
}
let
(
:diff
)
{
commit
.
raw_diffs
.
first
}
let
(
:diff_file
)
{
Gitlab
::
Diff
::
File
.
new
(
diff
,
diff_refs:
diff_refs
,
repository:
repository
)
}
let
(
:diff_file
)
{
Gitlab
::
Diff
::
File
.
new
(
diff
,
diff_refs:
diff_refs
,
repository:
repository
)
}
let
(
:entity
)
{
described_class
.
new
(
diff_file
,
request:
{})
}
let
(
:options
)
{
{}
}
let
(
:entity
)
{
described_class
.
new
(
diff_file
,
options
.
reverse_merge
(
request:
{}))
}
subject
{
entity
.
as_json
}
subject
{
entity
.
as_json
}
...
@@ -23,7 +24,7 @@ describe DiffFileEntity do
...
@@ -23,7 +24,7 @@ describe DiffFileEntity do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:request
)
{
EntityRequest
.
new
(
project:
project
,
current_user:
user
)
}
let
(
:request
)
{
EntityRequest
.
new
(
project:
project
,
current_user:
user
)
}
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
(
:entity
)
{
described_class
.
new
(
diff_file
,
request:
request
,
merge_request:
merge_request
)
}
let
(
:entity
)
{
described_class
.
new
(
diff_file
,
options
.
merge
(
request:
request
,
merge_request:
merge_request
)
)
}
let
(
:exposed_urls
)
{
%i(edit_path view_path context_lines_path)
}
let
(
:exposed_urls
)
{
%i(edit_path view_path context_lines_path)
}
it_behaves_like
'diff file entity'
it_behaves_like
'diff file entity'
...
@@ -49,6 +50,8 @@ describe DiffFileEntity do
...
@@ -49,6 +50,8 @@ describe DiffFileEntity do
end
end
context
'#parallel_diff_lines'
do
context
'#parallel_diff_lines'
do
let
(
:options
)
{
{
diff_view: :parallel
}
}
it
'exposes parallel diff lines correctly'
do
it
'exposes parallel diff lines correctly'
do
response
=
subject
response
=
subject
...
...
spec/services/error_tracking/list_issues_service_spec.rb
View file @
991a2953
...
@@ -45,4 +45,12 @@ describe ErrorTracking::ListIssuesService do
...
@@ -45,4 +45,12 @@ describe ErrorTracking::ListIssuesService do
include_examples
'error tracking service unauthorized user'
include_examples
'error tracking service unauthorized user'
include_examples
'error tracking service disabled'
include_examples
'error tracking service disabled'
end
end
describe
'#external_url'
do
it
'calls the project setting sentry_external_url'
do
expect
(
error_tracking_setting
).
to
receive
(
:sentry_external_url
).
and_return
(
sentry_url
)
expect
(
subject
.
external_url
).
to
eql
sentry_url
end
end
end
end
spec/support/capybara.rb
View file @
991a2953
...
@@ -101,8 +101,12 @@ RSpec.configure do |config|
...
@@ -101,8 +101,12 @@ RSpec.configure do |config|
config
.
after
(
:example
,
:js
)
do
|
example
|
config
.
after
(
:example
,
:js
)
do
|
example
|
# when a test fails, display any messages in the browser's console
# when a test fails, display any messages in the browser's console
if
example
.
exception
# but fail don't add the message if the failure is a pending test that got
# fixed. If we raised the `JSException` the fixed test would be marked as
# failed again.
if
example
.
exception
&&
!
example
.
exception
.
is_a?
(
RSpec
::
Core
::
Pending
::
PendingExampleFixedError
)
console
=
page
.
driver
.
browser
.
manage
.
logs
.
get
(
:browser
)
&
.
reject
{
|
log
|
log
.
message
=~
JS_CONSOLE_FILTER
}
console
=
page
.
driver
.
browser
.
manage
.
logs
.
get
(
:browser
)
&
.
reject
{
|
log
|
log
.
message
=~
JS_CONSOLE_FILTER
}
if
console
.
present?
if
console
.
present?
message
=
"Unexpected browser console output:
\n
"
+
console
.
map
(
&
:message
).
join
(
"
\n
"
)
message
=
"Unexpected browser console output:
\n
"
+
console
.
map
(
&
:message
).
join
(
"
\n
"
)
raise
JSConsoleError
,
message
raise
JSConsoleError
,
message
...
...
spec/support/shared_examples/merge_requests_rendering_a_single_diff_version.rb
0 → 100644
View file @
991a2953
# frozen_string_literal: true
# This pending test can be removed when `single_mr_diff_view` is enabled by default
# disabling the feature flag above is then not needed anymore.
RSpec
.
shared_examples
'rendering a single diff version'
do
|
attribute
|
pending
'allows editing diff settings single_mr_diff_view is enabled'
do
project
=
create
(
:project
,
:repository
)
user
=
project
.
creator
merge_request
=
create
(
:merge_request
,
source_project:
project
)
stub_feature_flags
(
single_mr_diff_view:
true
)
sign_in
(
user
)
visit
(
diffs_project_merge_request_path
(
project
,
merge_request
))
expect
(
page
).
to
have_selector
(
'.js-show-diff-settings'
)
end
end
spec/support/shared_examples/serializers/diff_file_entity_examples.rb
View file @
991a2953
...
@@ -31,14 +31,43 @@ shared_examples 'diff file entity' do
...
@@ -31,14 +31,43 @@ shared_examples 'diff file entity' do
it
'exposes correct attributes'
do
it
'exposes correct attributes'
do
expect
(
subject
).
to
include
(
:added_lines
,
:removed_lines
,
expect
(
subject
).
to
include
(
:added_lines
,
:removed_lines
,
:context_lines_path
,
:highlighted_diff_lines
,
:context_lines_path
)
:parallel_diff_lines
)
end
end
it
'includes viewer'
do
it
'includes viewer'
do
expect
(
subject
[
:viewer
].
with_indifferent_access
)
expect
(
subject
[
:viewer
].
with_indifferent_access
)
.
to
match_schema
(
'entities/diff_viewer'
)
.
to
match_schema
(
'entities/diff_viewer'
)
end
end
context
'diff files'
do
context
'when diff_view is parallel'
do
let
(
:options
)
{
{
diff_view: :parallel
}
}
it
'contains only the parallel diff lines'
,
:aggregate_failures
do
expect
(
subject
).
to
include
(
:parallel_diff_lines
)
expect
(
subject
).
not_to
include
(
:highlighted_diff_lines
)
end
end
context
'when diff_view is parallel'
do
let
(
:options
)
{
{
diff_view: :inline
}
}
it
'contains only the inline diff lines'
,
:aggregate_failures
do
expect
(
subject
).
not_to
include
(
:parallel_diff_lines
)
expect
(
subject
).
to
include
(
:highlighted_diff_lines
)
end
end
context
'when the `single_mr_diff_view` feature is disabled'
do
before
do
stub_feature_flags
(
single_mr_diff_view:
false
)
end
it
'contains both kinds of diffs'
do
expect
(
subject
).
to
include
(
:highlighted_diff_lines
,
:parallel_diff_lines
)
end
end
end
end
end
shared_examples
'diff file discussion entity'
do
shared_examples
'diff file discussion entity'
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