2eecfd8f9d
This allows using `CacheMarkdownField` for models that are not backed by ActiveRecord. When the including class inherits `ActiveRecord::Base` we include `Gitlab::MarkdownCache::ActiveRecord::Extension`. This will cause the markdown fields to be rendered and the generated HTML stored in a `<field>_html` attribute on the record. We also store the version used for generating the markdown. All other classes that include this model will include the `Gitlab::MarkdownCache::Redis::Extension`. This add the `<field>_html` attributes to that model and will generate the html in them. The generated HTML will be cached in redis under the key `markdown_cache:<class>:<id>`. The class this included in must therefore respond to `id`.
96 lines
2.7 KiB
Ruby
96 lines
2.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe ResourceLabelEvent, type: :model do
|
|
subject { build(:resource_label_event, issue: issue) }
|
|
let(:issue) { create(:issue) }
|
|
let(:merge_request) { create(:merge_request) }
|
|
|
|
it_behaves_like 'having unique enum values'
|
|
|
|
describe 'associations' do
|
|
it { is_expected.to belong_to(:user) }
|
|
it { is_expected.to belong_to(:issue) }
|
|
it { is_expected.to belong_to(:merge_request) }
|
|
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
|
|
|
|
describe '#expire_etag_cache' do
|
|
def expect_expiration(issue)
|
|
expect_any_instance_of(Gitlab::EtagCaching::Store)
|
|
.to receive(:touch)
|
|
.with("/#{issue.project.namespace.to_param}/#{issue.project.to_param}/noteable/issue/#{issue.id}/notes")
|
|
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
|
|
|
|
it 'returns true if markdown is outdated' do
|
|
subject.attributes = { cached_markdown_version: ((Gitlab::MarkdownCache::CACHE_COMMONMARK_VERSION - 1) << 16) | 0 }
|
|
|
|
expect(subject.outdated_markdown?).to be true
|
|
end
|
|
|
|
it 'returns false if label and reference are set' do
|
|
subject.attributes = { reference: 'whatever', cached_markdown_version: Gitlab::MarkdownCache::CACHE_COMMONMARK_VERSION << 16 }
|
|
|
|
expect(subject.outdated_markdown?).to be false
|
|
end
|
|
end
|
|
end
|