Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
1565a370
Commit
1565a370
authored
Aug 19, 2016
by
Alfredo Sumaran
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixes failing specs
parent
7001c914
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
72 additions
and
58 deletions
+72
-58
spec/features/protected_branches_spec.rb
spec/features/protected_branches_spec.rb
+72
-58
No files found.
spec/features/protected_branches_spec.rb
View file @
1565a370
...
@@ -8,6 +8,13 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -8,6 +8,13 @@ feature 'Projected Branches', feature: true, js: true do
before
{
login_as
(
user
)
}
before
{
login_as
(
user
)
}
def
set_allowed_to
(
operation
,
option
=
'Masters'
)
find
(
".js-allowed-to-
#{
operation
}
"
).
click
wait_for_ajax
click_on
option
find
(
".js-allowed-to-
#{
operation
}
"
).
click
# needed to submit form in some cases
end
def
set_protected_branch_name
(
branch_name
)
def
set_protected_branch_name
(
branch_name
)
find
(
".js-protected-branch-select"
).
click
find
(
".js-protected-branch-select"
).
click
find
(
".dropdown-input-field"
).
set
(
branch_name
)
find
(
".dropdown-input-field"
).
set
(
branch_name
)
...
@@ -18,6 +25,8 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -18,6 +25,8 @@ feature 'Projected Branches', feature: true, js: true do
it
"allows creating explicit protected branches"
do
it
"allows creating explicit protected branches"
do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'some-branch'
)
set_protected_branch_name
(
'some-branch'
)
set_allowed_to
(
'merge'
)
set_allowed_to
(
'push'
)
click_on
"Protect"
click_on
"Protect"
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
'some-branch'
)
}
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
'some-branch'
)
}
...
@@ -31,6 +40,8 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -31,6 +40,8 @@ feature 'Projected Branches', feature: true, js: true do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'some-branch'
)
set_protected_branch_name
(
'some-branch'
)
set_allowed_to
(
'merge'
)
set_allowed_to
(
'push'
)
click_on
"Protect"
click_on
"Protect"
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
commit
.
id
[
0
..
7
])
}
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
commit
.
id
[
0
..
7
])
}
...
@@ -39,6 +50,8 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -39,6 +50,8 @@ feature 'Projected Branches', feature: true, js: true do
it
"displays an error message if the named branch does not exist"
do
it
"displays an error message if the named branch does not exist"
do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'some-branch'
)
set_protected_branch_name
(
'some-branch'
)
set_allowed_to
(
'merge'
)
set_allowed_to
(
'push'
)
click_on
"Protect"
click_on
"Protect"
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
'branch was removed'
)
}
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
'branch was removed'
)
}
...
@@ -49,6 +62,8 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -49,6 +62,8 @@ feature 'Projected Branches', feature: true, js: true do
it
"allows creating protected branches with a wildcard"
do
it
"allows creating protected branches with a wildcard"
do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'*-stable'
)
set_protected_branch_name
(
'*-stable'
)
set_allowed_to
(
'merge'
)
set_allowed_to
(
'push'
)
click_on
"Protect"
click_on
"Protect"
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
'*-stable'
)
}
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
'*-stable'
)
}
...
@@ -62,6 +77,8 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -62,6 +77,8 @@ feature 'Projected Branches', feature: true, js: true do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'*-stable'
)
set_protected_branch_name
(
'*-stable'
)
set_allowed_to
(
'merge'
)
set_allowed_to
(
'push'
)
click_on
"Protect"
click_on
"Protect"
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
"2 matching branches"
)
}
within
(
".protected-branches-list"
)
{
expect
(
page
).
to
have_content
(
"2 matching branches"
)
}
...
@@ -74,6 +91,8 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -74,6 +91,8 @@ feature 'Projected Branches', feature: true, js: true do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'*-stable'
)
set_protected_branch_name
(
'*-stable'
)
set_allowed_to
(
'merge'
)
set_allowed_to
(
'push'
)
click_on
"Protect"
click_on
"Protect"
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
...
@@ -92,14 +111,8 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -92,14 +111,8 @@ feature 'Projected Branches', feature: true, js: true do
it
"allows creating protected branches that
#{
access_type_name
}
can push to"
do
it
"allows creating protected branches that
#{
access_type_name
}
can push to"
do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'master'
)
set_protected_branch_name
(
'master'
)
within
(
'.new_protected_branch'
)
do
set_allowed_to
(
'merge'
)
allowed_to_push_button
=
find
(
".js-allowed-to-push"
)
set_allowed_to
(
'push'
,
access_type_name
)
unless
allowed_to_push_button
.
text
==
access_type_name
allowed_to_push_button
.
click
within
(
".dropdown.open .dropdown-menu"
)
{
click_on
access_type_name
}
end
end
click_on
"Protect"
click_on
"Protect"
expect
(
ProtectedBranch
.
count
).
to
eq
(
1
)
expect
(
ProtectedBranch
.
count
).
to
eq
(
1
)
...
@@ -107,20 +120,23 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -107,20 +120,23 @@ feature 'Projected Branches', feature: true, js: true do
end
end
it
"allows updating protected branches so that
#{
access_type_name
}
can push to them"
do
it
"allows updating protected branches so that
#{
access_type_name
}
can push to them"
do
authorized_user
=
create
(
:user
)
project
.
team
<<
[
authorized_user
,
:developer
]
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'master'
)
set_protected_branch_name
(
'master'
)
set_allowed_to
(
'merge'
)
set_allowed_to
(
'push'
,
authorized_user
.
name
)
click_on
"Protect"
click_on
"Protect"
expect
(
ProtectedBranch
.
count
).
to
eq
(
1
)
expect
(
ProtectedBranch
.
count
).
to
eq
(
1
)
within
(
".protected-branches-list"
)
{
click_on
"Settings"
}
within
(
".js-protected-branch-edit-form"
)
do
set_allowed_to
(
'push'
,
access_type_name
)
within
(
".allowed-to-push-container"
)
do
find
(
".allowed-to-push"
).
click
click_on
access_type_name
end
end
wait_for_ajax
wait_for_ajax
expect
(
ProtectedBranch
.
last
.
push_access_levels
.
map
(
&
:access_level
)).
to
include
(
access_type_id
)
expect
(
ProtectedBranch
.
last
.
push_access_levels
.
map
(
&
:access_level
)).
to
include
(
access_type_id
)
end
end
end
end
...
@@ -129,32 +145,28 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -129,32 +145,28 @@ feature 'Projected Branches', feature: true, js: true do
it
"allows creating protected branches that
#{
access_type_name
}
can merge to"
do
it
"allows creating protected branches that
#{
access_type_name
}
can merge to"
do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'master'
)
set_protected_branch_name
(
'master'
)
within
(
'.new_protected_branch'
)
do
set_allowed_to
(
'push'
)
allowed_to_merge_button
=
find
(
".js-allowed-to-merge"
)
set_allowed_to
(
'merge'
,
access_type_name
)
unless
allowed_to_merge_button
.
text
==
access_type_name
allowed_to_merge_button
.
click
within
(
".dropdown.open .dropdown-menu"
)
{
click_on
access_type_name
}
end
end
click_on
"Protect"
click_on
"Protect"
expect
(
ProtectedBranch
.
count
).
to
eq
(
1
)
expect
(
ProtectedBranch
.
count
).
to
eq
(
1
)
expect
(
ProtectedBranch
.
last
.
merge_access_levels
.
map
(
&
:access_level
)).
to
eq
([
access_type_id
])
expect
(
ProtectedBranch
.
last
.
merge_access_levels
.
map
(
&
:access_level
)).
to
eq
([
access_type_id
])
end
end
it
"allows updating protected branches so that
#{
access_type_name
}
can merge to them"
do
it
"allows updating protected branches so that
#{
access_type_name
}
can merge to them"
,
focus:
true
do
authorized_user
=
create
(
:user
)
project
.
team
<<
[
authorized_user
,
:developer
]
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'master'
)
set_protected_branch_name
(
'master'
)
set_allowed_to
(
'merge'
,
authorized_user
.
name
)
set_allowed_to
(
'push'
)
click_on
"Protect"
click_on
"Protect"
expect
(
ProtectedBranch
.
count
).
to
eq
(
1
)
expect
(
ProtectedBranch
.
count
).
to
eq
(
1
)
within
(
".protected-branches-list"
)
{
click_on
"Settings"
}
within
(
".js-protected-branch-edit-form"
)
do
set_allowed_to
(
'merge'
,
access_type_name
)
within
(
".allowed-to-merge-container"
)
do
find
(
".allowed-to-merge"
).
click
click_on
access_type_name
end
end
wait_for_ajax
wait_for_ajax
...
@@ -167,38 +179,44 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -167,38 +179,44 @@ feature 'Projected Branches', feature: true, js: true do
before
{
project
.
team
<<
[
authorized_user
,
:developer
]
}
before
{
project
.
team
<<
[
authorized_user
,
:developer
]
}
[
'push'
,
'merge'
].
each
do
|
git_operation_type
|
git_operations
=
[
'push'
,
'merge'
]
git_operations
.
each_with_index
do
|
git_operation_type
,
i
|
alt_git_operation
=
git_operations
[(
i
+
1
)
%
2
]
# Will return the next or previous operation
it
"allows creating protected branches that a specific user can
#{
git_operation_type
}
to"
do
it
"allows creating protected branches that a specific user can
#{
git_operation_type
}
to"
do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'master'
)
set_protected_branch_name
(
'master'
)
within
(
'.new_protected_branch'
)
do
within
(
'.new_protected_branch'
)
do
find
(
".allowed-to-
#{
git_operation_type
}
"
).
click
find
(
".
js-
allowed-to-
#{
git_operation_type
}
"
).
click
click_on
authorized_user
.
name
click_on
authorized_user
.
name
end
end
perform_enqueued_jobs
{
click_on
"Protect"
}
set_allowed_to
(
alt_git_operation
)
within
(
".protected-branches-list"
)
{
click_on
"Settings
"
}
perform_enqueued_jobs
{
click_on
"Protect
"
}
within
(
".protected-branch-
#{
git_operation_type
}
-access-list"
)
do
within
'.js-protected-branch-edit-form'
do
expect
(
page
).
to
have_content
(
authorized_user
.
name
)
find
(
".js-allowed-to-
#{
git_operation_type
}
"
).
click
wait_for_ajax
expect
(
page
).
to
have_selector
(
'a.is-active'
,
text:
authorized_user
.
name
)
end
end
end
end
it
"allows updating a protected branch so that a specific user can
#{
git_operation_type
}
to it"
do
it
"allows updating a protected branch so that a specific user can
#{
git_operation_type
}
to it"
do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'master'
)
set_protected_branch_name
(
'master'
)
set_allowed_to
(
'merge'
)
set_allowed_to
(
'push'
)
click_on
"Protect"
click_on
"Protect"
within
(
".protected-branches-list"
)
{
click_on
"Settings"
}
within
'.js-protected-branch-edit-form'
do
set_allowed_to
(
git_operation_type
,
authorized_user
.
name
)
within
(
".allowed-to-
#{
git_operation_type
}
-container"
)
do
find
(
".allowed-to-
#{
git_operation_type
}
"
).
click
perform_enqueued_jobs
{
click_on
authorized_user
.
name
}
end
end
within
(
".protected-branch-
#{
git_operation_type
}
-access-list"
)
do
wait_for_ajax
expect
(
page
).
to
have_content
(
authorized_user
.
name
)
end
access_levels
=
ProtectedBranch
.
first
.
send
(
"
#{
git_operation_type
}
_access_levels"
.
to_sym
)
expect
(
access_levels
.
last
.
user
).
to
eq
(
authorized_user
)
end
end
it
"allows deleting a user-specific access level"
do
it
"allows deleting a user-specific access level"
do
...
@@ -208,32 +226,28 @@ feature 'Projected Branches', feature: true, js: true do
...
@@ -208,32 +226,28 @@ feature 'Projected Branches', feature: true, js: true do
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
visit
namespace_project_protected_branches_path
(
project
.
namespace
,
project
)
set_protected_branch_name
(
'master'
)
set_protected_branch_name
(
'master'
)
# First authorized user has access
within
(
'.new_protected_branch'
)
do
within
(
'.new_protected_branch'
)
do
find
(
".allowed-to-
#{
git_operation_type
}
"
).
click
# First authorized user has access
click_on
authorized_user
.
name
set_allowed_to
(
git_operation_type
,
authorized_user
.
name
)
set_allowed_to
(
alt_git_operation
)
end
end
click_on
"Protect"
click_on
"Protect"
within
'.js-protected-branch-edit-form'
do
# Second authorized user has access
set_allowed_to
(
git_operation_type
,
other_authorized_user
.
name
)
within
(
".protected-branches-list"
)
{
click_on
"Settings"
}
# Remove first user's access
# Second authorized user has access
within
(
".allowed-to-
#{
git_operation_type
}
-container"
)
do
find
(
".js-allowed-to-
#{
git_operation_type
}
"
).
click
find
(
".js-allowed-to-
#{
git_operation_type
}
"
).
click
perform_enqueued_jobs
{
click_on
other_authorized_user
.
name
}
wait_for_ajax
click_on
other_authorized_user
.
name
find
(
".js-allowed-to-
#{
git_operation_type
}
"
).
click
# Close to submit the form
end
end
# Remove first user's access
within
(
".protected-branch-
#{
git_operation_type
}
-access-list"
)
do
perform_enqueued_jobs
{
click_link
"Delete"
,
match: :first
}
end
expect
(
page
).
to
have_content
(
"Successfully deleted."
)
access_levels
=
ProtectedBranch
.
first
.
send
(
"
#{
git_operation_type
}
_access_levels"
.
to_sym
)
access_levels
=
ProtectedBranch
.
first
.
send
(
"
#{
git_operation_type
}
_access_levels"
.
to_sym
)
expect
(
access_levels
.
count
).
to
eq
(
1
)
expect
(
access_levels
.
count
).
to
eq
(
2
)
expect
(
access_levels
.
fir
st
.
user
).
to
eq
(
other_authorized_user
)
expect
(
access_levels
.
la
st
.
user
).
to
eq
(
other_authorized_user
)
end
end
end
end
end
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