gitlab-org--gitlab-foss/spec/finders/repositories/tree_finder_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

96 lines
2.6 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require "spec_helper"
RSpec.describe Repositories::TreeFinder do
include RepoHelpers
let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project, :repository, creator: user) }
let(:repository) { project.repository }
let(:tree_finder) { described_class.new(project, params) }
let(:params) { {} }
let(:first_page_ids) { tree_finder.execute.map(&:id) }
let(:second_page_token) { first_page_ids.last }
describe "#execute" do
subject { tree_finder.execute(gitaly_pagination: true) }
it "returns an array" do
is_expected.to be_an(Array)
end
it "includes 20 items by default" do
expect(subject.size).to eq(20)
end
it "accepts a gitaly_pagination argument" do
expect(repository).to receive(:tree).with(anything, anything, recursive: nil, pagination_params: { limit: 20, page_token: nil }).and_call_original
expect(tree_finder.execute(gitaly_pagination: true)).to be_an(Array)
expect(repository).to receive(:tree).with(anything, anything, recursive: nil).and_call_original
expect(tree_finder.execute(gitaly_pagination: false)).to be_an(Array)
end
context "commit doesn't exist" do
let(:params) do
{ ref: "nonesuchref" }
end
it "raises an error" do
expect { subject }.to raise_error(described_class::CommitMissingError)
end
end
describe "pagination_params" do
let(:params) do
{ per_page: 5, page_token: nil }
end
it "has the per_page number of items" do
expect(subject.size).to eq(5)
end
it "doesn't include any of the first page records" do
first_page_ids = subject.map(&:id)
second_page = described_class.new(project, { per_page: 5, page_token: first_page_ids.last }).execute(gitaly_pagination: true)
expect(second_page.map(&:id)).not_to include(*first_page_ids)
end
end
end
describe "#total", :use_clean_rails_memory_store_caching do
subject { tree_finder.total }
it { is_expected.to be_an(Integer) }
it "only calculates the total once" do
expect(repository).to receive(:tree).once.and_call_original
2.times { tree_finder.total }
end
end
describe "#commit_exists?" do
subject { tree_finder.commit_exists? }
context "ref exists" do
let(:params) do
{ ref: project.default_branch }
end
it { is_expected.to be(true) }
end
context "ref is missing" do
let(:params) do
{ ref: "nonesuchref" }
end
it { is_expected.to be(false) }
end
end
end