86166d2802
This splits the Markdown rendering and reference extraction phases into two distinct code bases. The reference extraction phase no longer relies on the html-pipeline Gem (and any related code) and allows for extracting of references from multiple HTML nodes in a single pass. This means that if you want to extract user references from 200 comments you no longer need to run 200 times N number of queries, instead only a handful of queries may be needed.
31 lines
910 B
Ruby
31 lines
910 B
Ruby
require 'spec_helper'
|
|
|
|
describe Banzai::ReferenceParser::MilestoneParser, lib: true do
|
|
include ReferenceParserHelpers
|
|
|
|
let(:project) { create(:empty_project, :public) }
|
|
let(:user) { create(:user) }
|
|
let(:milestone) { create(:milestone, project: project) }
|
|
subject { described_class.new(project, user) }
|
|
let(:link) { empty_html_link }
|
|
|
|
describe '#referenced_by' do
|
|
describe 'when the link has a data-milestone attribute' do
|
|
context 'using an existing milestone ID' do
|
|
it 'returns an Array of milestones' do
|
|
link['data-milestone'] = milestone.id.to_s
|
|
|
|
expect(subject.referenced_by([link])).to eq([milestone])
|
|
end
|
|
end
|
|
|
|
context 'using a non-existing milestone ID' do
|
|
it 'returns an empty Array' do
|
|
link['data-milestone'] = ''
|
|
|
|
expect(subject.referenced_by([link])).to eq([])
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|