Commit 8dd750e4 authored by Rémy Coutable's avatar Rémy Coutable

Fix the default branches sorting to actually be 'Last updated'

Signed-off-by: default avatarRémy Coutable <remy@rymai.me>
parent b83dcd3a
...@@ -9,7 +9,7 @@ class Projects::BranchesController < Projects::ApplicationController ...@@ -9,7 +9,7 @@ class Projects::BranchesController < Projects::ApplicationController
def index def index
@sort = params[:sort].presence || sort_value_recently_updated @sort = params[:sort].presence || sort_value_recently_updated
@branches = BranchesFinder.new(@repository, params).execute @branches = BranchesFinder.new(@repository, params.merge(sort: @sort)).execute
@branches = Kaminari.paginate_array(@branches).page(params[:page]) @branches = Kaminari.paginate_array(@branches).page(params[:page])
respond_to do |format| respond_to do |format|
......
---
title: Fix the default branches sorting to actually be 'Last updated'
merge_request: 14295
author:
type: fixed
...@@ -29,7 +29,7 @@ feature 'Download buttons in branches page' do ...@@ -29,7 +29,7 @@ feature 'Download buttons in branches page' do
describe 'when checking branches' do describe 'when checking branches' do
context 'with artifacts' do context 'with artifacts' do
before do before do
visit project_branches_path(project) visit project_branches_path(project, search: 'binary-encoding')
end end
scenario 'shows download artifacts button' do scenario 'shows download artifacts button' do
......
...@@ -5,12 +5,6 @@ describe 'Branches' do ...@@ -5,12 +5,6 @@ describe 'Branches' do
let(:project) { create(:project, :public, :repository) } let(:project) { create(:project, :public, :repository) }
let(:repository) { project.repository } let(:repository) { project.repository }
def set_protected_branch_name(branch_name)
find(".js-protected-branch-select").click
find(".dropdown-input-field").set(branch_name)
click_on("Create wildcard #{branch_name}")
end
context 'logged in as developer' do context 'logged in as developer' do
before do before do
sign_in(user) sign_in(user)
...@@ -18,12 +12,10 @@ describe 'Branches' do ...@@ -18,12 +12,10 @@ describe 'Branches' do
end end
describe 'Initial branches page' do describe 'Initial branches page' do
it 'shows all the branches' do it 'shows all the branches sorted by last updated by default' do
visit project_branches_path(project) visit project_branches_path(project)
repository.branches_sorted_by(:name).first(20).each do |branch| expect(page).to have_content(sorted_branches(repository, count: 20, sort_by: :updated_desc))
expect(page).to have_content("#{branch.name}")
end
end end
it 'sorts the branches by name' do it 'sorts the branches by name' do
...@@ -32,22 +24,7 @@ describe 'Branches' do ...@@ -32,22 +24,7 @@ describe 'Branches' do
click_button "Last updated" # Open sorting dropdown click_button "Last updated" # Open sorting dropdown
click_link "Name" click_link "Name"
sorted = repository.branches_sorted_by(:name).first(20).map do |branch| expect(page).to have_content(sorted_branches(repository, count: 20, sort_by: :name))
Regexp.escape(branch.name)
end
expect(page).to have_content(/#{sorted.join(".*")}/)
end
it 'sorts the branches by last updated' do
visit project_branches_path(project)
click_button "Last updated" # Open sorting dropdown
click_link "Last updated"
sorted = repository.branches_sorted_by(:updated_desc).first(20).map do |branch|
Regexp.escape(branch.name)
end
expect(page).to have_content(/#{sorted.join(".*")}/)
end end
it 'sorts the branches by oldest updated' do it 'sorts the branches by oldest updated' do
...@@ -56,10 +33,7 @@ describe 'Branches' do ...@@ -56,10 +33,7 @@ describe 'Branches' do
click_button "Last updated" # Open sorting dropdown click_button "Last updated" # Open sorting dropdown
click_link "Oldest updated" click_link "Oldest updated"
sorted = repository.branches_sorted_by(:updated_asc).first(20).map do |branch| expect(page).to have_content(sorted_branches(repository, count: 20, sort_by: :updated_asc))
Regexp.escape(branch.name)
end
expect(page).to have_content(/#{sorted.join(".*")}/)
end end
it 'avoids a N+1 query in branches index' do it 'avoids a N+1 query in branches index' do
...@@ -99,28 +73,6 @@ describe 'Branches' do ...@@ -99,28 +73,6 @@ describe 'Branches' do
expect(find('.all-branches')).to have_selector('li', count: 0) expect(find('.all-branches')).to have_selector('li', count: 0)
end end
end end
describe 'Delete protected branch' do
before do
project.add_user(user, :master)
visit project_protected_branches_path(project)
set_protected_branch_name('fix')
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content('fix') }
expect(ProtectedBranch.count).to eq(1)
project.add_user(user, :developer)
end
it 'does not allow devleoper to removes protected branch', js: true do
visit project_branches_path(project)
fill_in 'branch-search', with: 'fix'
find('#branch-search').native.send_keys(:enter)
expect(page).to have_css('.btn-remove.disabled')
end
end
end end
context 'logged in as master' do context 'logged in as master' do
...@@ -136,37 +88,6 @@ describe 'Branches' do ...@@ -136,37 +88,6 @@ describe 'Branches' do
expect(page).to have_content("Protected branches can be managed in project settings") expect(page).to have_content("Protected branches can be managed in project settings")
end end
end end
describe 'Delete protected branch' do
before do
visit project_protected_branches_path(project)
set_protected_branch_name('fix')
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content('fix') }
expect(ProtectedBranch.count).to eq(1)
end
it 'removes branch after modal confirmation', js: true do
visit project_branches_path(project)
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)
page.find('[data-target="#modal-delete-branch"]').trigger(:click)
expect(page).to have_css('.js-delete-branch[disabled]')
fill_in 'delete_branch_input', with: 'fix'
click_link 'Delete protected branch'
fill_in 'branch-search', with: 'fix'
find('#branch-search').native.send_keys(:enter)
expect(page).to have_content('No branches to show')
end
end
end end
context 'logged out' do context 'logged out' do
...@@ -180,4 +101,13 @@ describe 'Branches' do ...@@ -180,4 +101,13 @@ describe 'Branches' do
end end
end end
end end
def sorted_branches(repository, count:, sort_by:)
sorted_branches =
repository.branches_sorted_by(sort_by).first(count).map do |branch|
Regexp.escape(branch.name)
end
Regexp.new(sorted_branches.join('.*'))
end
end end
require 'spec_helper' require 'spec_helper'
feature 'Protected Branches', js: true do feature 'Protected Branches', :js do
let(:user) { create(:user, :admin) } let(:user) { create(:user) }
let(:admin) { create(:admin) }
let(:project) { create(:project, :repository) } let(:project) { create(:project, :repository) }
before do context 'logged in as developer' do
sign_in(user) before do
end project.add_developer(user)
sign_in(user)
end
def set_protected_branch_name(branch_name) describe 'Delete protected branch' do
find(".js-protected-branch-select").trigger('click') before do
find(".dropdown-input-field").set(branch_name) create(:protected_branch, project: project, name: 'fix')
click_on("Create wildcard #{branch_name}") expect(ProtectedBranch.count).to eq(1)
end end
it 'does not allow developer to removes protected branch' do
visit project_branches_path(project)
fill_in 'branch-search', with: 'fix'
find('#branch-search').native.send_keys(:enter)
describe "explicit protected branches" do expect(page).to have_css('.btn-remove.disabled')
it "allows creating explicit protected branches" do end
visit project_protected_branches_path(project) end
set_protected_branch_name('some-branch') end
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content('some-branch') } context 'logged in as master' do
expect(ProtectedBranch.count).to eq(1) before do
expect(ProtectedBranch.last.name).to eq('some-branch') project.add_master(user)
sign_in(user)
end end
it "displays the last commit on the matching branch if it exists" do describe 'Delete protected branch' do
commit = create(:commit, project: project) before do
project.repository.add_branch(user, 'some-branch', commit.id) create(:protected_branch, project: project, name: 'fix')
expect(ProtectedBranch.count).to eq(1)
end
visit project_protected_branches_path(project) it 'removes branch after modal confirmation' do
set_protected_branch_name('some-branch') visit project_branches_path(project)
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content(commit.id[0..7]) } fill_in 'branch-search', with: 'fix'
end find('#branch-search').native.send_keys(:enter)
it "displays an error message if the named branch does not exist" do expect(page).to have_content('fix')
visit project_protected_branches_path(project) expect(find('.all-branches')).to have_selector('li', count: 1)
set_protected_branch_name('some-branch') page.find('[data-target="#modal-delete-branch"]').trigger(:click)
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content('branch was removed') } expect(page).to have_css('.js-delete-branch[disabled]')
fill_in 'delete_branch_input', with: 'fix'
click_link 'Delete protected branch'
fill_in 'branch-search', with: 'fix'
find('#branch-search').native.send_keys(:enter)
expect(page).to have_content('No branches to show')
end
end end
end end
describe "wildcard protected branches" do context 'logged in as admin' do
it "allows creating protected branches with a wildcard" do before do
visit project_protected_branches_path(project) sign_in(admin)
set_protected_branch_name('*-stable')
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content('*-stable') }
expect(ProtectedBranch.count).to eq(1)
expect(ProtectedBranch.last.name).to eq('*-stable')
end end
it "displays the number of matching branches" do describe "explicit protected branches" do
project.repository.add_branch(user, 'production-stable', 'master') it "allows creating explicit protected branches" do
project.repository.add_branch(user, 'staging-stable', 'master') visit project_protected_branches_path(project)
set_protected_branch_name('some-branch')
click_on "Protect"
visit project_protected_branches_path(project) within(".protected-branches-list") { expect(page).to have_content('some-branch') }
set_protected_branch_name('*-stable') expect(ProtectedBranch.count).to eq(1)
click_on "Protect" expect(ProtectedBranch.last.name).to eq('some-branch')
end
within(".protected-branches-list") { expect(page).to have_content("2 matching branches") } it "displays the last commit on the matching branch if it exists" do
commit = create(:commit, project: project)
project.repository.add_branch(admin, 'some-branch', commit.id)
visit project_protected_branches_path(project)
set_protected_branch_name('some-branch')
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content(commit.id[0..7]) }
end
it "displays an error message if the named branch does not exist" do
visit project_protected_branches_path(project)
set_protected_branch_name('some-branch')
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content('branch was removed') }
end
end end
it "displays all the branches matching the wildcard" do describe "wildcard protected branches" do
project.repository.add_branch(user, 'production-stable', 'master') it "allows creating protected branches with a wildcard" do
project.repository.add_branch(user, 'staging-stable', 'master') visit project_protected_branches_path(project)
project.repository.add_branch(user, 'development', 'master') set_protected_branch_name('*-stable')
click_on "Protect"
within(".protected-branches-list") { expect(page).to have_content('*-stable') }
expect(ProtectedBranch.count).to eq(1)
expect(ProtectedBranch.last.name).to eq('*-stable')
end
visit project_protected_branches_path(project) it "displays the number of matching branches" do
set_protected_branch_name('*-stable') project.repository.add_branch(admin, 'production-stable', 'master')
click_on "Protect" project.repository.add_branch(admin, 'staging-stable', 'master')
visit project_protected_branches_path(project) visit project_protected_branches_path(project)
click_on "2 matching branches" set_protected_branch_name('*-stable')
click_on "Protect"
within(".protected-branches-list") do within(".protected-branches-list") { expect(page).to have_content("2 matching branches") }
expect(page).to have_content("production-stable")
expect(page).to have_content("staging-stable")
expect(page).not_to have_content("development")
end end
it "displays all the branches matching the wildcard" do
project.repository.add_branch(admin, 'production-stable', 'master')
project.repository.add_branch(admin, 'staging-stable', 'master')
project.repository.add_branch(admin, 'development', 'master')
visit project_protected_branches_path(project)
set_protected_branch_name('*-stable')
click_on "Protect"
visit project_protected_branches_path(project)
click_on "2 matching branches"
within(".protected-branches-list") do
expect(page).to have_content("production-stable")
expect(page).to have_content("staging-stable")
expect(page).not_to have_content("development")
end
end
end
describe "access control" do
include_examples "protected branches > access control > CE"
end end
end end
describe "access control" do def set_protected_branch_name(branch_name)
include_examples "protected branches > access control > CE" find(".js-protected-branch-select").trigger('click')
find(".dropdown-input-field").set(branch_name)
click_on("Create wildcard #{branch_name}")
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment