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
Jérome Perrin
gitlab-ce
Commits
ce7eb4e4
Commit
ce7eb4e4
authored
Aug 05, 2016
by
Sean McGivern
Committed by
Fatih Acet
Aug 12, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add more tests for conflicts
parent
f322c302
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
156 additions
and
32 deletions
+156
-32
app/controllers/projects/merge_requests_controller.rb
app/controllers/projects/merge_requests_controller.rb
+1
-1
lib/gitlab/conflict/file_collection.rb
lib/gitlab/conflict/file_collection.rb
+1
-1
spec/controllers/projects/merge_requests_controller_spec.rb
spec/controllers/projects/merge_requests_controller_spec.rb
+4
-4
spec/features/merge_requests/conflicts_spec.rb
spec/features/merge_requests/conflicts_spec.rb
+68
-0
spec/lib/gitlab/conflict/file_collection_spec.rb
spec/lib/gitlab/conflict/file_collection_spec.rb
+2
-2
spec/lib/gitlab/conflict/file_spec.rb
spec/lib/gitlab/conflict/file_spec.rb
+3
-3
spec/models/merge_request_spec.rb
spec/models/merge_request_spec.rb
+52
-0
spec/support/test_env.rb
spec/support/test_env.rb
+25
-21
No files found.
app/controllers/projects/merge_requests_controller.rb
View file @
ce7eb4e4
...
@@ -139,7 +139,7 @@ class Projects::MergeRequestsController < Projects::ApplicationController
...
@@ -139,7 +139,7 @@ class Projects::MergeRequestsController < Projects::ApplicationController
render
json:
@merge_request
.
conflicts
render
json:
@merge_request
.
conflicts
else
else
render
json:
{
render
json:
{
message:
'Unable to resolve conflicts in the web interface for this merge request'
,
message:
'Unable to resolve conflicts in the web interface for this merge request
.
'
,
type:
'error'
type:
'error'
}
}
end
end
...
...
lib/gitlab/conflict/file_collection.rb
View file @
ce7eb4e4
...
@@ -46,7 +46,7 @@ module Gitlab
...
@@ -46,7 +46,7 @@ module Gitlab
end
end
<<
EOM
.
chomp
<<
EOM
.
chomp
Merge branch '
#{
merge_request
.
source_branch
}
' into '
#{
merge_request
.
target
_branch
}
'
Merge branch '
#{
merge_request
.
target_branch
}
' into '
#{
merge_request
.
source
_branch
}
'
# Conflicts:
# Conflicts:
#{
conflict_filenames
.
join
(
"
\n
"
)
}
#{
conflict_filenames
.
join
(
"
\n
"
)
}
...
...
spec/controllers/projects/merge_requests_controller_spec.rb
View file @
ce7eb4e4
...
@@ -5,7 +5,7 @@ describe Projects::MergeRequestsController do
...
@@ -5,7 +5,7 @@ describe Projects::MergeRequestsController do
let
(
:user
)
{
create
(
:user
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:merge_request
)
{
create
(
:merge_request_with_diffs
,
target_project:
project
,
source_project:
project
)
}
let
(
:merge_request
)
{
create
(
:merge_request_with_diffs
,
target_project:
project
,
source_project:
project
)
}
let
(
:merge_request_with_conflicts
)
do
let
(
:merge_request_with_conflicts
)
do
create
(
:merge_request
,
source_branch:
'conflict-
a'
,
target_branch:
'conflict-b
'
,
source_project:
project
)
do
|
mr
|
create
(
:merge_request
,
source_branch:
'conflict-
resolvable'
,
target_branch:
'conflict-start
'
,
source_project:
project
)
do
|
mr
|
mr
.
mark_as_unmergeable
mr
.
mark_as_unmergeable
end
end
end
end
...
@@ -625,7 +625,7 @@ describe Projects::MergeRequestsController do
...
@@ -625,7 +625,7 @@ describe Projects::MergeRequestsController do
context
'with valid params'
do
context
'with valid params'
do
before
do
before
do
resolve_conflicts
(
'2f6fcd96b88b36ce98c38da085c795a27d92a3dd_
4_
4'
=>
'head'
,
resolve_conflicts
(
'2f6fcd96b88b36ce98c38da085c795a27d92a3dd_
14_1
4'
=>
'head'
,
'6eb14e00385d2fb284765eb1cd8d420d33d63fc9_9_9'
=>
'head'
,
'6eb14e00385d2fb284765eb1cd8d420d33d63fc9_9_9'
=>
'head'
,
'6eb14e00385d2fb284765eb1cd8d420d33d63fc9_21_21'
=>
'origin'
,
'6eb14e00385d2fb284765eb1cd8d420d33d63fc9_21_21'
=>
'origin'
,
'6eb14e00385d2fb284765eb1cd8d420d33d63fc9_49_49'
=>
'origin'
)
'6eb14e00385d2fb284765eb1cd8d420d33d63fc9_49_49'
=>
'origin'
)
...
@@ -636,14 +636,14 @@ describe Projects::MergeRequestsController do
...
@@ -636,14 +636,14 @@ describe Projects::MergeRequestsController do
expect
(
merge_request_with_conflicts
.
source_branch_head
.
message
).
to
include
(
'Commit message'
)
expect
(
merge_request_with_conflicts
.
source_branch_head
.
message
).
to
include
(
'Commit message'
)
end
end
it
'returns an OK respo
sn
e'
do
it
'returns an OK respo
ns
e'
do
expect
(
response
).
to
have_http_status
(
:ok
)
expect
(
response
).
to
have_http_status
(
:ok
)
end
end
end
end
context
'when sections are missing'
do
context
'when sections are missing'
do
before
do
before
do
resolve_conflicts
(
'2f6fcd96b88b36ce98c38da085c795a27d92a3dd_
4_
4'
=>
'head'
)
resolve_conflicts
(
'2f6fcd96b88b36ce98c38da085c795a27d92a3dd_
14_1
4'
=>
'head'
)
end
end
it
'returns a 400 error'
do
it
'returns a 400 error'
do
...
...
spec/features/merge_requests/conflicts_spec.rb
0 → 100644
View file @
ce7eb4e4
require
'spec_helper'
feature
'Merge request conflict resolution'
,
js:
true
,
feature:
true
do
include
WaitForAjax
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
create
(
:project
)
}
def
create_merge_request
(
source_branch
)
create
(
:merge_request
,
source_branch:
source_branch
,
target_branch:
'conflict-start'
,
source_project:
project
)
do
|
mr
|
mr
.
mark_as_unmergeable
end
end
context
'when a merge request can be resolved in the UI'
do
let
(
:merge_request
)
{
create_merge_request
(
'conflict-resolvable'
)
}
before
do
project
.
team
<<
[
user
,
:developer
]
login_as
(
user
)
visit
namespace_project_merge_request_path
(
project
.
namespace
,
project
,
merge_request
)
end
it
'shows a link to the conflict resolution page'
do
expect
(
page
).
to
have_link
(
'conflicts'
,
href:
/\/conflicts\Z/
)
end
context
'visiting the conflicts resolution page'
do
before
{
click_link
(
'conflicts'
,
href:
/\/conflicts\Z/
)
}
it
'shows the conflicts'
do
expect
(
find
(
'#conflicts'
)).
to
have_content
(
'popen.rb'
)
end
end
end
UNRESOLVABLE_CONFLICTS
=
{
'conflict-too-large'
=>
'when the conflicts contain a large file'
,
'conflict-binary-file'
=>
'when the conflicts contain a binary file'
,
'conflict-contains-conflict-markers'
=>
'when the conflicts contain a file with ambiguous conflict markers'
,
'conflict-missing-side'
=>
'when the conflicts contain a file edited in one branch and deleted in another'
}
UNRESOLVABLE_CONFLICTS
.
each
do
|
source_branch
,
description
|
context
description
do
let
(
:merge_request
)
{
create_merge_request
(
source_branch
)
}
before
do
project
.
team
<<
[
user
,
:developer
]
login_as
(
user
)
visit
namespace_project_merge_request_path
(
project
.
namespace
,
project
,
merge_request
)
end
it
'does not show a link to the conflict resolution page'
do
expect
(
page
).
not_to
have_link
(
'conflicts'
,
href:
/\/conflicts\Z/
)
end
it
'shows an error if the conflicts page is visited directly'
do
visit
current_url
+
'/conflicts'
wait_for_ajax
expect
(
find
(
'#conflicts'
)).
to
have_content
(
'Unable to resolve conflicts'
)
end
end
end
end
spec/lib/gitlab/conflict/file_collection_spec.rb
View file @
ce7eb4e4
require
'spec_helper'
require
'spec_helper'
describe
Gitlab
::
Conflict
::
FileCollection
,
lib:
true
do
describe
Gitlab
::
Conflict
::
FileCollection
,
lib:
true
do
let
(
:merge_request
)
{
create
(
:merge_request
,
source_branch:
'conflict-
a'
,
target_branch:
'conflict-b
'
)
}
let
(
:merge_request
)
{
create
(
:merge_request
,
source_branch:
'conflict-
resolvable'
,
target_branch:
'conflict-start
'
)
}
let
(
:file_collection
)
{
Gitlab
::
Conflict
::
FileCollection
.
new
(
merge_request
)
}
let
(
:file_collection
)
{
Gitlab
::
Conflict
::
FileCollection
.
new
(
merge_request
)
}
describe
'#files'
do
describe
'#files'
do
...
@@ -13,7 +13,7 @@ describe Gitlab::Conflict::FileCollection, lib: true do
...
@@ -13,7 +13,7 @@ describe Gitlab::Conflict::FileCollection, lib: true do
describe
'#default_commit_message'
do
describe
'#default_commit_message'
do
it
'matches the format of the git CLI commit message'
do
it
'matches the format of the git CLI commit message'
do
expect
(
file_collection
.
default_commit_message
).
to
eq
(
<<
EOM
.
chomp
)
expect
(
file_collection
.
default_commit_message
).
to
eq
(
<<
EOM
.
chomp
)
Merge branch 'conflict-
a' into 'conflict-b
'
Merge branch 'conflict-
start' into 'conflict-resolvable
'
# Conflicts:
# Conflicts:
# files/ruby/popen.rb
# files/ruby/popen.rb
...
...
spec/lib/gitlab/conflict/file_spec.rb
View file @
ce7eb4e4
...
@@ -4,9 +4,9 @@ describe Gitlab::Conflict::File, lib: true do
...
@@ -4,9 +4,9 @@ describe Gitlab::Conflict::File, lib: true do
let
(
:project
)
{
create
(
:project
)
}
let
(
:project
)
{
create
(
:project
)
}
let
(
:repository
)
{
project
.
repository
}
let
(
:repository
)
{
project
.
repository
}
let
(
:rugged
)
{
repository
.
rugged
}
let
(
:rugged
)
{
repository
.
rugged
}
let
(
:their_commit
)
{
rugged
.
branches
[
'conflict-
a
'
].
target
}
let
(
:their_commit
)
{
rugged
.
branches
[
'conflict-
start
'
].
target
}
let
(
:our_commit
)
{
rugged
.
branches
[
'conflict-
b
'
].
target
}
let
(
:our_commit
)
{
rugged
.
branches
[
'conflict-
resolvable
'
].
target
}
let
(
:merge_request
)
{
create
(
:merge_request
,
source_branch:
'conflict-
b'
,
target_branch:
'conflict-a
'
,
source_project:
project
)
}
let
(
:merge_request
)
{
create
(
:merge_request
,
source_branch:
'conflict-
resolvable'
,
target_branch:
'conflict-start
'
,
source_project:
project
)
}
let
(
:index
)
{
rugged
.
merge_commits
(
our_commit
,
their_commit
)
}
let
(
:index
)
{
rugged
.
merge_commits
(
our_commit
,
their_commit
)
}
let
(
:conflict
)
{
index
.
conflicts
.
last
}
let
(
:conflict
)
{
index
.
conflicts
.
last
}
let
(
:merge_file_result
)
{
index
.
merge_file
(
'files/ruby/regex.rb'
)
}
let
(
:merge_file_result
)
{
index
.
merge_file
(
'files/ruby/regex.rb'
)
}
...
...
spec/models/merge_request_spec.rb
View file @
ce7eb4e4
...
@@ -741,4 +741,56 @@ describe MergeRequest, models: true do
...
@@ -741,4 +741,56 @@ describe MergeRequest, models: true do
end
end
end
end
end
end
describe
'#can_resolve_conflicts_in_ui?'
do
def
create_merge_request
(
source_branch
)
create
(
:merge_request
,
source_branch:
source_branch
,
target_branch:
'conflict-start'
)
do
|
mr
|
mr
.
mark_as_unmergeable
end
end
it
'returns a falsey value when the MR can be merged without conflicts'
do
merge_request
=
create_merge_request
(
'master'
)
merge_request
.
mark_as_mergeable
expect
(
merge_request
.
can_resolve_conflicts_in_ui?
).
to
be_falsey
end
it
'returns a falsey value when the MR does not support new diff notes'
do
merge_request
=
create_merge_request
(
'conflict-resolvable'
)
merge_request
.
merge_request_diff
.
update_attributes
(
start_commit_sha:
nil
)
expect
(
merge_request
.
can_resolve_conflicts_in_ui?
).
to
be_falsey
end
it
'returns a falsey value when the conflicts contain a large file'
do
merge_request
=
create_merge_request
(
'conflict-too-large'
)
expect
(
merge_request
.
can_resolve_conflicts_in_ui?
).
to
be_falsey
end
it
'returns a falsey value when the conflicts contain a binary file'
do
merge_request
=
create_merge_request
(
'conflict-binary-file'
)
expect
(
merge_request
.
can_resolve_conflicts_in_ui?
).
to
be_falsey
end
it
'returns a falsey value when the conflicts contain a file with ambiguous conflict markers'
do
merge_request
=
create_merge_request
(
'conflict-contains-conflict-markers'
)
expect
(
merge_request
.
can_resolve_conflicts_in_ui?
).
to
be_falsey
end
it
'returns a falsey value when the conflicts contain a file edited in one branch and deleted in another'
do
merge_request
=
create_merge_request
(
'conflict-missing-side'
)
expect
(
merge_request
.
can_resolve_conflicts_in_ui?
).
to
be_falsey
end
it
'returns a truthy value when the conflicts are resolvable in the UI'
do
merge_request
=
create_merge_request
(
'conflict-resolvable'
)
expect
(
merge_request
.
can_resolve_conflicts_in_ui?
).
to
be_truthy
end
end
end
end
spec/support/test_env.rb
View file @
ce7eb4e4
...
@@ -19,13 +19,17 @@ module TestEnv
...
@@ -19,13 +19,17 @@ module TestEnv
'orphaned-branch'
=>
'45127a9'
,
'orphaned-branch'
=>
'45127a9'
,
'binary-encoding'
=>
'7b1cf43'
,
'binary-encoding'
=>
'7b1cf43'
,
'gitattributes'
=>
'5a62481'
,
'gitattributes'
=>
'5a62481'
,
'conflict-a'
=>
'dfdd207'
,
'conflict-b'
=>
'4e75a62'
,
'expand-collapse-diffs'
=>
'4842455'
,
'expand-collapse-diffs'
=>
'4842455'
,
'expand-collapse-files'
=>
'025db92'
,
'expand-collapse-files'
=>
'025db92'
,
'expand-collapse-lines'
=>
'238e82d'
,
'expand-collapse-lines'
=>
'238e82d'
,
'video'
=>
'8879059'
,
'video'
=>
'8879059'
,
'crlf-diff'
=>
'5938907'
'crlf-diff'
=>
'5938907'
,
'conflict-start'
=>
'14fa46b'
,
'conflict-resolvable'
=>
'1450cd6'
,
'conflict-binary-file'
=>
'259a6fb'
,
'conflict-contains-conflict-markers'
=>
'5e0964c'
,
'conflict-missing-side'
=>
'eb227b3'
,
'conflict-too-large'
=>
'39fa04f'
,
}
}
# gitlab-test-fork is a fork of gitlab-fork, but we don't necessarily
# gitlab-test-fork is a fork of gitlab-fork, but we don't necessarily
...
...
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