debian-mirror-gitlab/spec/models/resource_label_event_spec.rb

100 lines
2.8 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2019-12-04 20:38:33 +05:30
require 'spec_helper'
2018-11-18 11:00:15 +05:30
RSpec.describe ResourceLabelEvent, type: :model do
2018-11-20 20:47:30 +05:30
subject { build(:resource_label_event, issue: issue) }
2019-12-21 20:55:43 +05:30
2018-11-18 11:00:15 +05:30
let(:issue) { create(:issue) }
let(:merge_request) { create(:merge_request) }
2019-02-15 15:39:39 +05:30
it_behaves_like 'having unique enum values'
2020-04-08 14:13:33 +05:30
it_behaves_like 'a resource event'
it_behaves_like 'a resource event for issues'
it_behaves_like 'a resource event for merge requests'
2018-11-18 11:00:15 +05:30
describe 'associations' do
it { is_expected.to belong_to(:label) }
end
describe 'validations' do
it { is_expected.to be_valid }
describe 'Issuable validation' do
it 'is invalid if issue_id and merge_request_id are missing' do
subject.attributes = { issue: nil, merge_request: nil }
expect(subject).to be_invalid
end
it 'is invalid if issue_id and merge_request_id are set' do
subject.attributes = { issue: issue, merge_request: merge_request }
expect(subject).to be_invalid
end
it 'is valid if only issue_id is set' do
subject.attributes = { issue: issue, merge_request: nil }
expect(subject).to be_valid
end
it 'is valid if only merge_request_id is set' do
subject.attributes = { merge_request: merge_request, issue: nil }
expect(subject).to be_valid
end
end
end
2018-11-20 20:47:30 +05:30
describe '#expire_etag_cache' do
def expect_expiration(issue)
2020-01-01 13:55:28 +05:30
expect_next_instance_of(Gitlab::EtagCaching::Store) do |instance|
expect(instance).to receive(:touch)
.with("/#{issue.project.namespace.to_param}/#{issue.project.to_param}/noteable/issue/#{issue.id}/notes")
end
2018-11-20 20:47:30 +05:30
end
it 'expires resource note etag cache on event save' do
expect_expiration(subject.issuable)
subject.save!
end
it 'expires resource note etag cache on event destroy' do
subject.save!
expect_expiration(subject.issuable)
subject.destroy!
end
end
describe '#outdated_markdown?' do
it 'returns true if label is missing and reference is not empty' do
subject.attributes = { reference: 'ref', label_id: nil }
expect(subject.outdated_markdown?).to be true
end
it 'returns true if reference is not set yet' do
subject.attributes = { reference: nil }
expect(subject.outdated_markdown?).to be true
end
2019-03-02 22:35:43 +05:30
it 'returns true if markdown is outdated' do
2019-09-04 21:01:54 +05:30
subject.attributes = { cached_markdown_version: ((Gitlab::MarkdownCache::CACHE_COMMONMARK_VERSION - 1) << 16) | 0 }
2018-11-20 20:47:30 +05:30
expect(subject.outdated_markdown?).to be true
end
it 'returns false if label and reference are set' do
2019-09-04 21:01:54 +05:30
subject.attributes = { reference: 'whatever', cached_markdown_version: Gitlab::MarkdownCache::CACHE_COMMONMARK_VERSION << 16 }
2018-11-20 20:47:30 +05:30
expect(subject.outdated_markdown?).to be false
end
end
2018-11-18 11:00:15 +05:30
end