diff options
author | Yorick Peterse <yorickpeterse@gmail.com> | 2016-12-22 13:22:07 +0000 |
---|---|---|
committer | Douglas Barbosa Alexandre <dbalexandre@gmail.com> | 2016-12-22 11:25:26 -0200 |
commit | 1c82d9984501743ee3ca86af62f1c2007ae28c95 (patch) | |
tree | 4e67385dbb952a8c37ef9f00e3d41b5359fcc4bb /spec | |
parent | 65cbcfa6ef6bf506dce0369d3efc37873e07c10e (diff) | |
download | gitlab-ce-1c82d9984501743ee3ca86af62f1c2007ae28c95.tar.gz |
Merge branch 'cache-last-commit-sha-for-path' into 'master'
Cache last commit id for path
See merge request !8098
Diffstat (limited to 'spec')
-rw-r--r-- | spec/models/repository_spec.rb | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/spec/models/repository_spec.rb b/spec/models/repository_spec.rb index b5a42edd192..af7e89eae05 100644 --- a/spec/models/repository_spec.rb +++ b/spec/models/repository_spec.rb @@ -139,6 +139,22 @@ describe Repository, models: true do it { is_expected.to eq('c1acaa58bbcbc3eafe538cb8274ba387047b69f8') } end + describe '#last_commit_id_for_path' do + subject { repository.last_commit_id_for_path(sample_commit.id, '.gitignore') } + + it "returns last commit id for a given path" do + is_expected.to eq('c1acaa58bbcbc3eafe538cb8274ba387047b69f8') + end + + it "caches last commit id for a given path" do + cache = repository.send(:cache) + key = "last_commit_id_for_path:#{sample_commit.id}:#{Digest::SHA1.hexdigest('.gitignore')}" + + expect(cache).to receive(:fetch).with(key).and_return('c1acaa5') + is_expected.to eq('c1acaa5') + end + end + describe '#find_commits_by_message' do it 'returns commits with messages containing a given string' do commit_ids = repository.find_commits_by_message('submodule').map(&:id) |