2019-12-21 20:55:43 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-23 00:09:42 +05:30
|
|
|
RSpec.describe BranchesFinder do
|
2016-08-24 12:49:21 +05:30
|
|
|
let(:user) { create(:user) }
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:project) { create(:project, :repository) }
|
2016-08-24 12:49:21 +05:30
|
|
|
let(:repository) { project.repository }
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
let(:branch_finder) { described_class.new(repository, params) }
|
|
|
|
let(:params) { {} }
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
describe '#execute' do
|
2020-07-28 23:09:34 +05:30
|
|
|
subject { branch_finder.execute }
|
|
|
|
|
2016-08-24 12:49:21 +05:30
|
|
|
context 'sort only' do
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by name' do
|
|
|
|
let(:params) { {} }
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'sorts' do
|
|
|
|
result = subject
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.first.name).to eq("'test'")
|
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by recently_updated' do
|
|
|
|
let(:params) { { sort: 'updated_desc' } }
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'sorts' do
|
|
|
|
result = subject
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
recently_updated_branch = repository.branches.max do |a, b|
|
|
|
|
repository.commit(a.dereferenced_target).committed_date <=> repository.commit(b.dereferenced_target).committed_date
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.first.name).to eq(recently_updated_branch.name)
|
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by last_updated' do
|
|
|
|
let(:params) { { sort: 'updated_asc' } }
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'sorts' do
|
|
|
|
result = subject
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.first.name).to eq('feature')
|
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'filter only' do
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by name' do
|
|
|
|
let(:params) { { search: 'fix' } }
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.first.name).to eq('fix')
|
|
|
|
expect(result.count).to eq(1)
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by name ignoring letter case' do
|
|
|
|
let(:params) { { search: 'FiX' } }
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.first.name).to eq('fix')
|
|
|
|
expect(result.count).to eq(1)
|
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'with an unknown name' do
|
|
|
|
let(:params) { { search: 'random' } }
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'does not find any branch' do
|
|
|
|
result = subject
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.count).to eq(0)
|
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
2019-09-30 21:07:59 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by provided names' do
|
|
|
|
let(:params) { { names: %w[fix csv lfs does-not-exist] } }
|
2019-09-30 21:07:59 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
2019-09-30 21:07:59 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.count).to eq(3)
|
|
|
|
expect(result.map(&:name)).to eq(%w{csv fix lfs})
|
|
|
|
end
|
2019-09-30 21:07:59 +05:30
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by name that begins with' do
|
|
|
|
let(:params) { { search: '^feature_' } }
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.first.name).to eq('feature_conflict')
|
|
|
|
expect(result.count).to eq(1)
|
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by name that ends with' do
|
|
|
|
let(:params) { { search: 'feature$' } }
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.first.name).to eq('feature')
|
|
|
|
expect(result.count).to eq(1)
|
|
|
|
end
|
2018-12-13 13:39:08 +05:30
|
|
|
end
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by nonexistent name that begins with' do
|
|
|
|
let(:params) { { search: '^nope' } }
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
2016-08-24 12:49:21 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.count).to eq(0)
|
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by nonexistent name that ends with' do
|
|
|
|
let(:params) { { search: 'nope$' } }
|
2019-12-26 22:10:19 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
2019-12-26 22:10:19 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.count).to eq(0)
|
|
|
|
end
|
2019-12-26 22:10:19 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'filter and sort' do
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by name and sorts by recently_updated' do
|
|
|
|
let(:params) { { sort: 'updated_desc', search: 'feat' } }
|
|
|
|
|
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.first.name).to eq('feature_conflict')
|
|
|
|
expect(result.count).to eq(2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'by name and sorts by recently_updated, with exact matches first' do
|
|
|
|
let(:params) { { sort: 'updated_desc', search: 'feature' } }
|
|
|
|
|
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.first.name).to eq('feature')
|
|
|
|
expect(result.second.name).to eq('feature_conflict')
|
|
|
|
expect(result.count).to eq(2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'by name and sorts by last_updated' do
|
|
|
|
let(:params) { { sort: 'updated_asc', search: 'feature' } }
|
|
|
|
|
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.first.name).to eq('feature')
|
|
|
|
expect(result.count).to eq(2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'with gitaly pagination' do
|
|
|
|
subject { branch_finder.execute(gitaly_pagination: true) }
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by page_token and per_page' do
|
|
|
|
let(:params) { { page_token: 'feature', per_page: 2 } }
|
|
|
|
|
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.map(&:name)).to eq(%w(feature_conflict fix))
|
|
|
|
end
|
2018-12-13 13:39:08 +05:30
|
|
|
end
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by next page_token and per_page' do
|
|
|
|
let(:params) { { page_token: 'fix', per_page: 2 } }
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
expect(result.map(&:name)).to eq(%w(flatten-dir gitattributes))
|
|
|
|
end
|
2019-12-26 22:10:19 +05:30
|
|
|
end
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by per_page only' do
|
|
|
|
let(:params) { { per_page: 2 } }
|
|
|
|
|
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.map(&:name)).to eq(["'test'", '2-mb-file'])
|
|
|
|
end
|
|
|
|
end
|
2019-12-26 22:10:19 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
context 'by page_token only' do
|
|
|
|
let(:params) { { page_token: 'feature' } }
|
2019-12-26 22:10:19 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
it 'returns nothing' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.count).to eq(0)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'pagination and sort' do
|
|
|
|
context 'by per_page' do
|
|
|
|
let(:params) { { sort: 'updated_asc', per_page: 5 } }
|
|
|
|
|
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.map(&:name)).to eq(%w(feature improve/awesome merge-test markdown feature_conflict))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'by page_token and per_page' do
|
|
|
|
let(:params) { { sort: 'updated_asc', page_token: 'improve/awesome', per_page: 2 } }
|
|
|
|
|
|
|
|
it 'filters branches' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.map(&:name)).to eq(%w(merge-test markdown))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'pagination and names' do
|
|
|
|
let(:params) { { page_token: 'fix', per_page: 2, names: %w[fix csv lfs does-not-exist] } }
|
|
|
|
|
|
|
|
it 'falls back to default execute and ignore paginations' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.count).to eq(3)
|
|
|
|
expect(result.map(&:name)).to eq(%w{csv fix lfs})
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'pagination and search' do
|
|
|
|
let(:params) { { page_token: 'feature', per_page: 2, search: '^f' } }
|
|
|
|
|
|
|
|
it 'falls back to default execute and ignore paginations' do
|
|
|
|
result = subject
|
|
|
|
|
|
|
|
expect(result.map(&:name)).to eq(%w(feature feature_conflict fix flatten-dir))
|
|
|
|
end
|
2018-12-13 13:39:08 +05:30
|
|
|
end
|
2016-08-24 12:49:21 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|