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
766f9cf2
Commit
766f9cf2
authored
Jul 07, 2016
by
tiagonbotelho
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
implements the basic filter functionality
parent
81e57e78
Changes
9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
172 additions
and
11 deletions
+172
-11
CHANGELOG
CHANGELOG
+1
-0
app/controllers/projects/branches_controller.rb
app/controllers/projects/branches_controller.rb
+1
-2
app/finders/branches_finder.rb
app/finders/branches_finder.rb
+31
-0
app/helpers/branches_helper.rb
app/helpers/branches_helper.rb
+11
-0
app/models/repository.rb
app/models/repository.rb
+7
-0
app/views/projects/branches/index.html.haml
app/views/projects/branches/index.html.haml
+13
-8
db/schema.rb
db/schema.rb
+1
-1
spec/features/projects/branches_spec.rb
spec/features/projects/branches_spec.rb
+32
-0
spec/finders/branches_finder_spec.rb
spec/finders/branches_finder_spec.rb
+75
-0
No files found.
CHANGELOG
View file @
766f9cf2
...
@@ -8,6 +8,7 @@ v 8.10.0 (unreleased)
...
@@ -8,6 +8,7 @@ v 8.10.0 (unreleased)
- Add the functionality to be able to rename a file. !5049 (tiagonbotelho)
- Add the functionality to be able to rename a file. !5049 (tiagonbotelho)
- Disable PostgreSQL statement timeout during migrations
- Disable PostgreSQL statement timeout during migrations
- Fix projects dropdown loading performance with a simplified api cal. !5113 (tiagonbotelho)
- Fix projects dropdown loading performance with a simplified api cal. !5113 (tiagonbotelho)
- User can now filter branches by name on /branches page. !5144 (tiagonbotelho)
- Fix commit builds API, return all builds for all pipelines for given commit. !4849
- Fix commit builds API, return all builds for all pipelines for given commit. !4849
- Replace Haml with Hamlit to make view rendering faster. !3666
- Replace Haml with Hamlit to make view rendering faster. !3666
- Refresh the branch cache after `git gc` runs
- Refresh the branch cache after `git gc` runs
...
...
app/controllers/projects/branches_controller.rb
View file @
766f9cf2
...
@@ -6,8 +6,7 @@ class Projects::BranchesController < Projects::ApplicationController
...
@@ -6,8 +6,7 @@ class Projects::BranchesController < Projects::ApplicationController
before_action
:authorize_push_code!
,
only:
[
:new
,
:create
,
:destroy
]
before_action
:authorize_push_code!
,
only:
[
:new
,
:create
,
:destroy
]
def
index
def
index
@sort
=
params
[
:sort
]
||
'name'
@branches
=
BranchesFinder
.
new
(
@repository
,
params
).
execute
@branches
=
@repository
.
branches_sorted_by
(
@sort
)
@branches
=
Kaminari
.
paginate_array
(
@branches
).
page
(
params
[
:page
])
@branches
=
Kaminari
.
paginate_array
(
@branches
).
page
(
params
[
:page
])
@max_commits
=
@branches
.
reduce
(
0
)
do
|
memo
,
branch
|
@max_commits
=
@branches
.
reduce
(
0
)
do
|
memo
,
branch
|
...
...
app/finders/branches_finder.rb
0 → 100644
View file @
766f9cf2
class
BranchesFinder
def
initialize
(
repository
,
params
)
@repository
=
repository
@params
=
params
end
def
execute
branches
=
@repository
.
branches_sorted_by
(
sort
)
filter_by_name
(
branches
)
end
private
attr_reader
:repository
,
:params
def
search
@params
[
:search
].
presence
end
def
sort
@params
[
:sort
].
presence
||
'name'
end
def
filter_by_name
(
branches
)
if
search
branches
.
select
{
|
branch
|
branch
.
name
.
include?
(
search
)
}
else
branches
end
end
end
app/helpers/branches_helper.rb
View file @
766f9cf2
...
@@ -9,6 +9,17 @@ module BranchesHelper
...
@@ -9,6 +9,17 @@ module BranchesHelper
end
end
end
end
def
filter_branches_path
(
options
=
{})
exist_opts
=
{
search:
params
[
:search
],
sort:
params
[
:sort
]
}
options
=
exist_opts
.
merge
(
options
)
namespace_project_branches_path
(
@project
.
namespace
,
@project
,
@id
,
options
)
end
def
can_push_branch?
(
project
,
branch_name
)
def
can_push_branch?
(
project
,
branch_name
)
return
false
unless
project
.
repository
.
branch_exists?
(
branch_name
)
return
false
unless
project
.
repository
.
branch_exists?
(
branch_name
)
...
...
app/models/repository.rb
View file @
766f9cf2
...
@@ -125,6 +125,11 @@ class Repository
...
@@ -125,6 +125,11 @@ class Repository
commits
commits
end
end
def
find_similar_branches
(
search
)
raw_repository
.
branches
.
select
{
|
branch
|
branch
.
name
.
include?
(
search
)
}
end
def
find_branch
(
name
)
def
find_branch
(
name
)
raw_repository
.
branches
.
find
{
|
branch
|
branch
.
name
==
name
}
raw_repository
.
branches
.
find
{
|
branch
|
branch
.
name
==
name
}
end
end
...
@@ -606,6 +611,8 @@ class Repository
...
@@ -606,6 +611,8 @@ class Repository
# Remove archives older than 2 hours
# Remove archives older than 2 hours
def
branches_sorted_by
(
value
)
def
branches_sorted_by
(
value
)
case
value
case
value
when
'name'
branches
.
sort_by
(
&
:name
)
when
'recently_updated'
when
'recently_updated'
branches
.
sort
do
|
a
,
b
|
branches
.
sort
do
|
a
,
b
|
commit
(
b
.
target
).
committed_date
<=>
commit
(
a
.
target
).
committed_date
commit
(
b
.
target
).
committed_date
<=>
commit
(
a
.
target
).
committed_date
...
...
app/views/projects/branches/index.html.haml
View file @
766f9cf2
...
@@ -9,26 +9,31 @@
...
@@ -9,26 +9,31 @@
-
if
can?
current_user
,
:push_code
,
@project
-
if
can?
current_user
,
:push_code
,
@project
.nav-controls
.nav-controls
=
link_to
new_namespace_project_branch_path
(
@project
.
namespace
,
@project
),
class:
'btn btn-create'
do
=
form_tag
(
filter_branches_path
,
method: :get
)
do
New branch
=
search_field_tag
:search
,
params
[
:search
],
{
placeholder:
'Filter by branch name'
,
id:
'branch-search'
,
class:
'form-control search-text-input input-short'
,
spellcheck:
false
}
.dropdown.inline
.dropdown.inline
%button
.dropdown-toggle.btn
{
type:
'button'
,
'data-toggle'
=>
'dropdown'
}
%button
.dropdown-toggle.btn
{
type:
'button'
,
'data-toggle'
=>
'dropdown'
}
%span
.light
%span
.light
-
if
@sort
.
present?
-
if
params
[
:sort
]
.
present?
=
@sort
.
humanize
=
params
[
:sort
]
.
humanize
-
else
-
else
Name
Name
%b
.caret
%b
.caret
%ul
.dropdown-menu.dropdown-menu-align-right
%ul
.dropdown-menu.dropdown-menu-align-right
%li
%li
=
link_to
namespace_project
_branches_path
(
sort:
nil
)
do
=
link_to
filter
_branches_path
(
sort:
nil
)
do
N
ame
=
sort_title_n
ame
=
link_to
namespace_project
_branches_path
(
sort:
'recently_updated'
)
do
=
link_to
filter
_branches_path
(
sort:
'recently_updated'
)
do
=
sort_title_recently_updated
=
sort_title_recently_updated
=
link_to
namespace_project
_branches_path
(
sort:
'last_updated'
)
do
=
link_to
filter
_branches_path
(
sort:
'last_updated'
)
do
=
sort_title_oldest_updated
=
sort_title_oldest_updated
=
link_to
new_namespace_project_branch_path
(
@project
.
namespace
,
@project
),
class:
'btn btn-create'
do
New branch
-
if
@branches
.
any?
-
if
@branches
.
any?
%ul
.content-list.all-branches
%ul
.content-list.all-branches
-
@branches
.
each
do
|
branch
|
-
@branches
.
each
do
|
branch
|
=
render
"projects/branches/branch"
,
branch:
branch
=
render
"projects/branches/branch"
,
branch:
branch
=
paginate
@branches
,
theme:
'gitlab'
=
paginate
@branches
,
theme:
'gitlab'
-
else
.nothing-here-block
No branches to show
db/schema.rb
View file @
766f9cf2
...
@@ -84,10 +84,10 @@ ActiveRecord::Schema.define(version: 20160716115710) do
...
@@ -84,10 +84,10 @@ ActiveRecord::Schema.define(version: 20160716115710) do
t
.
string
"health_check_access_token"
t
.
string
"health_check_access_token"
t
.
boolean
"send_user_confirmation_email"
,
default:
false
t
.
boolean
"send_user_confirmation_email"
,
default:
false
t
.
integer
"container_registry_token_expire_delay"
,
default:
5
t
.
integer
"container_registry_token_expire_delay"
,
default:
5
t
.
boolean
"user_default_external"
,
default:
false
,
null:
false
t
.
text
"after_sign_up_text"
t
.
text
"after_sign_up_text"
t
.
string
"repository_storage"
,
default:
"default"
t
.
string
"repository_storage"
,
default:
"default"
t
.
string
"enabled_git_access_protocol"
t
.
string
"enabled_git_access_protocol"
t
.
boolean
"user_default_external"
,
default:
false
,
null:
false
end
end
create_table
"audit_events"
,
force: :cascade
do
|
t
|
create_table
"audit_events"
,
force: :cascade
do
|
t
|
...
...
spec/features/projects/branches_spec.rb
0 → 100644
View file @
766f9cf2
require
'spec_helper'
describe
'Branches'
,
feature:
true
do
let
(
:project
)
{
create
(
:project
)
}
let
(
:repository
)
{
project
.
repository
}
before
do
login_as
:user
project
.
team
<<
[
@user
,
:developer
]
end
describe
'Initial branches page'
do
it
'shows all the branches'
do
visit
namespace_project_branches_path
(
project
.
namespace
,
project
)
repository
.
branches
{
|
branch
|
expect
(
page
).
to
have_content
(
"
#{
branch
.
name
}
"
)
}
expect
(
page
).
to
have_content
(
"Protected branches can be managed in project settings"
)
end
end
describe
'Find branches'
do
it
'shows filtered branches'
,
js:
true
do
visit
namespace_project_branches_path
(
project
.
namespace
,
project
,
project
.
id
)
fill_in
'branch-search'
,
with:
'fix'
find
(
'#branch-search'
).
native
.
send_keys
(
:enter
)
expect
(
page
).
to
have_content
(
'fix'
)
expect
(
find
(
'.all-branches'
)).
to
have_selector
(
'li'
,
count:
1
)
end
end
end
spec/finders/branches_finder_spec.rb
0 → 100644
View file @
766f9cf2
require
'spec_helper'
describe
BranchesFinder
do
let
(
:user
)
{
create
(
:user
)
}
let
(
:project
)
{
create
(
:project
)
}
let
(
:repository
)
{
project
.
repository
}
describe
'#execute'
do
context
'sort only'
do
it
'sorts by name'
do
branches_finder
=
described_class
.
new
(
repository
,
{})
result
=
branches_finder
.
execute
expect
(
result
.
first
.
name
).
to
eq
(
"'test'"
)
end
it
'sorts by recently_updated'
do
branches_finder
=
described_class
.
new
(
repository
,
{
sort:
'recently_updated'
})
result
=
branches_finder
.
execute
expect
(
result
.
first
.
name
).
to
eq
(
'expand-collapse-lines'
)
end
it
'sorts by last_updated'
do
branches_finder
=
described_class
.
new
(
repository
,
{
sort:
'last_updated'
})
result
=
branches_finder
.
execute
expect
(
result
.
first
.
name
).
to
eq
(
'feature'
)
end
end
context
'filter only'
do
it
'filters branches by name'
do
branches_finder
=
described_class
.
new
(
repository
,
{
search:
'fix'
})
result
=
branches_finder
.
execute
expect
(
result
.
first
.
name
).
to
eq
(
'fix'
)
expect
(
result
.
count
).
to
eq
(
1
)
end
it
'does not find any branch with that name'
do
branches_finder
=
described_class
.
new
(
repository
,
{
search:
'random'
})
result
=
branches_finder
.
execute
expect
(
result
.
count
).
to
eq
(
0
)
end
end
context
'filter and sort'
do
it
'filters branches by name and sorts by recently_updated'
do
params
=
{
sort:
'recently_updated'
,
search:
'feature'
}
branches_finder
=
described_class
.
new
(
repository
,
params
)
result
=
branches_finder
.
execute
expect
(
result
.
first
.
name
).
to
eq
(
'feature_conflict'
)
expect
(
result
.
count
).
to
eq
(
2
)
end
it
'filters branches by name and sorts by last_updated'
do
params
=
{
sort:
'last_updated'
,
search:
'feature'
}
branches_finder
=
described_class
.
new
(
repository
,
params
)
result
=
branches_finder
.
execute
expect
(
result
.
first
.
name
).
to
eq
(
'feature'
)
expect
(
result
.
count
).
to
eq
(
2
)
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