BigW Consortium Gitlab
Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
gitlab-ce
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Forest Godfrey
gitlab-ce
Commits
0b3df2f1
Commit
0b3df2f1
authored
Oct 29, 2012
by
Riyad Preukschas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add merge request note feature
parent
7971383d
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
139 additions
and
37 deletions
+139
-37
merge_requests.feature
features/project/merge_requests.feature
+27
-1
project_merge_requests.rb
features/steps/project/project_merge_requests.rb
+107
-36
paths.rb
features/steps/shared/paths.rb
+5
-0
No files found.
features/project/merge_requests.feature
View file @
0b3df2f1
...
...
@@ -35,8 +35,34 @@ Feature: Project Merge Requests
Then
I should see merge request
"Wiki Feature"
@javascript
Scenario
:
I
comment merge request
Scenario
:
I
comment
on a
merge request
Given
I visit merge request page
"Bug NS-04"
And
I leave a comment like
"XML attached"
Then
I should see comment
"XML attached"
@javascript
Scenario
:
I
comment on a merge request diff
Given
project
"Shop"
have
"Bug NS-05"
open merge request with diffs inside
And
I visit merge request page
"Bug NS-05"
And
I switch to the diff tab
And
I leave a comment like
"Line is wrong"
on line 185 of the first file
And
I switch to the merge request's comments tab
Then
I should see a discussion has started on line 185
@javascript
Scenario
:
I
comment on a line of a commit in merge request
Given
project
"Shop"
have
"Bug NS-05"
open merge request with diffs inside
And
I visit merge request page
"Bug NS-05"
And
I click on the first commit in the merge request
And
I leave a comment like
"Line is wrong"
on line 185 of the first file
And
I switch to the merge request's comments tab
Then I should see a discussion has started on commit bcf03b5de6c
:
L185
@javascript
Scenario
:
I
comment on a commit in merge request
Given
project
"Shop"
have
"Bug NS-05"
open merge request with diffs inside
And
I visit merge request page
"Bug NS-05"
And
I click on the first commit in the merge request
And
I leave a comment on the diff page
And
I switch to the merge request's comments tab
Then
I should see a discussion has started on commit bcf03b5de6c
features/steps/project/project_merge_requests.rb
View file @
0b3df2f1
...
...
@@ -4,77 +4,148 @@ class ProjectMergeRequests < Spinach::FeatureSteps
include
SharedNote
include
SharedPaths
Then
'I should see "Bug NS-04" in merge requests
'
do
page
.
should
have_content
"Bug NS-04
"
Given
'I click link "New Merge Request"
'
do
click_link
"New Merge Request
"
end
And
'I should not see "Feature NS-03" in merge requests'
do
page
.
should_not
have_content
"Feature NS-03"
Given
'I click link "Bug NS-04"'
do
click_link
"Bug NS-04"
end
Given
'I click link "All"'
do
click_link
"All"
end
Given
'I click link "Closed"'
do
click_link
"Closed"
end
Then
'I should see
"Feature NS-03" in merge requests
'
do
page
.
should
have_content
"
Feature NS-03
"
Then
'I should see
merge request "Wiki Feature"
'
do
page
.
should
have_content
"
Wiki Feature
"
end
And
'I should not see "Bug NS-04" in merge requests'
do
page
.
should_not
have_content
"Bug NS-04"
Then
'I should see closed merge request "Bug NS-04"'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-04"
)
mr
.
closed
.
should
be_true
page
.
should
have_content
"Closed by"
end
Given
'I click link "All
"'
do
click_link
"All
"
Then
'I should see merge request "Bug NS-04
"'
do
page
.
should
have_content
"Bug NS-04
"
end
Given
'I click link "Bug NS-04"
'
do
click_link
"Bug NS-04"
Then
'I should see "Bug NS-04" in merge requests
'
do
page
.
should
have_content
"Bug NS-04"
end
Then
'I should see
merge request "Bug NS-04"
'
do
page
.
should
have_content
"
Bug NS-04
"
Then
'I should see
"Feature NS-03" in merge requests
'
do
page
.
should
have_content
"
Feature NS-03
"
end
And
'I
click link "Close"
'
do
click_link
"Close
"
And
'I
should not see "Feature NS-03" in merge requests
'
do
page
.
should_not
have_content
"Feature NS-03
"
end
Then
'I should see closed merge request "Bug NS-04"'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-04"
)
mr
.
closed
.
should
be_true
page
.
should
have_content
"Closed by"
And
'I should not see "Bug NS-04" in merge requests'
do
page
.
should_not
have_content
"Bug NS-04"
end
Given
'I click link "New Merge Request
"'
do
click_link
"
New Merge Request
"
And
'I click link "Close
"'
do
click_link
"
Close
"
end
And
'I submit new merge request "Wiki Feature"'
do
fill_in
"merge_request_title"
,
:with
=>
"Wiki Feature"
select
"master"
,
:from
=>
"merge_request_source_branch"
select
"stable"
,
:from
=>
"merge_request_target_branch"
fill_in
"merge_request_title"
,
with:
"Wiki Feature"
select
"master"
,
from:
"merge_request_source_branch"
select
"stable"
,
from:
"merge_request_target_branch"
click_button
"Save"
end
Then
'I should see merge request "Wiki Feature"'
do
page
.
should
have_content
"Wiki Feature"
end
And
'project "Shop" have "Bug NS-04" open merge request'
do
project
=
Project
.
find_by_name
(
"Shop"
)
create
(
:merge_request
,
:title
=>
"Bug NS-04"
,
:project
=>
project
,
:author
=>
project
.
users
.
first
)
title:
"Bug NS-04"
,
project:
project
,
author:
project
.
users
.
first
)
end
And
'project "Shop" have "Bug NS-05" open merge request with diffs inside'
do
project
=
Project
.
find_by_name
(
"Shop"
)
create
(
:merge_request_with_diffs
,
title:
"Bug NS-05"
,
project:
project
,
author:
project
.
users
.
first
)
end
And
'project "Shop" have "Feature NS-03" closed merge request'
do
project
=
Project
.
find_by_name
(
"Shop"
)
create
(
:merge_request
,
:title
=>
"Feature NS-03"
,
:project
=>
project
,
:author
=>
project
.
users
.
first
,
:closed
=>
true
)
title:
"Feature NS-03"
,
project:
project
,
author:
project
.
users
.
first
,
closed:
true
)
end
And
'I switch to the diff tab'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-05"
)
visit
diffs_project_merge_request_path
(
mr
.
project
,
mr
)
end
And
'I switch to the merge request\'s comments tab'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-05"
)
visit
project_merge_request_path
(
mr
.
project
,
mr
)
end
And
'I click on the first commit in the merge request'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-05"
)
click_link
mr
.
commits
.
first
.
short_id
(
8
)
end
And
'I leave a comment on the diff page'
do
within
(
:xpath
,
"//div[@class='note-form-holder']"
)
do
fill_in
"note_note"
,
with:
"One comment to rule them all"
click_button
"Add Comment"
end
end
And
'I leave a comment like "Line is wrong" on line 185 of the first file'
do
within
(
:xpath
,
"//div[@class='diff_file'][1]"
)
do
click_link
"add-diff-line-note-0_185_185"
end
within
(
:xpath
,
"//div[@class='line-note-form-holder']"
)
do
fill_in
"note_note"
,
with:
"Line is wrong"
click_button
"Add Comment"
end
end
Then
'I should see a discussion has started on line 185'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-05"
)
first_commit
=
mr
.
commits
.
first
first_diff
=
mr
.
diffs
.
first
page
.
should
have_content
"
#{
current_user
.
name
}
started a discussion on this merge request diff"
page
.
should
have_content
"
#{
first_diff
.
b_path
}
:L185"
page
.
should
have_content
"Line is wrong"
end
Then
'I should see a discussion has started on commit bcf03b5de6c:L185'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-05"
)
first_commit
=
mr
.
commits
.
first
first_diff
=
mr
.
diffs
.
first
page
.
should
have_content
"
#{
current_user
.
name
}
started a discussion on commit"
page
.
should
have_content
first_commit
.
short_id
(
8
)
page
.
should
have_content
"
#{
first_diff
.
b_path
}
:L185"
page
.
should
have_content
"Line is wrong"
end
Then
'I should see a discussion has started on commit bcf03b5de6c'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-05"
)
first_commit
=
mr
.
st_commits
.
first
first_diff
=
mr
.
diffs
.
first
page
.
should
have_content
"
#{
current_user
.
name
}
started a discussion on commit"
page
.
should
have_content
first_commit
.
short_id
(
8
)
page
.
should
have_content
"One comment to rule them all"
page
.
should_not
have_content
"
#{
first_diff
.
b_path
}
:L185"
end
end
features/steps/shared/paths.rb
View file @
0b3df2f1
...
...
@@ -215,6 +215,11 @@ module SharedPaths
visit
project_merge_request_path
(
mr
.
project
,
mr
)
end
Given
'I visit merge request page "Bug NS-05"'
do
mr
=
MergeRequest
.
find_by_title
(
"Bug NS-05"
)
visit
project_merge_request_path
(
mr
.
project
,
mr
)
end
And
'I visit project "Shop" merge requests page'
do
visit
project_merge_requests_path
(
Project
.
find_by_name
(
"Shop"
))
end
...
...
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