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
888 B
Ruby
31 lines
888 B
Ruby
require 'spec_helper'
|
|
|
|
describe Banzai::ReferenceParser::SnippetParser, lib: true do
|
|
include ReferenceParserHelpers
|
|
|
|
let(:project) { create(:empty_project, :public) }
|
|
let(:user) { create(:user) }
|
|
let(:snippet) { create(:snippet, project: project) }
|
|
subject { described_class.new(project, user) }
|
|
let(:link) { empty_html_link }
|
|
|
|
describe '#referenced_by' do
|
|
describe 'when the link has a data-snippet attribute' do
|
|
context 'using an existing snippet ID' do
|
|
it 'returns an Array of snippets' do
|
|
link['data-snippet'] = snippet.id.to_s
|
|
|
|
expect(subject.referenced_by([link])).to eq([snippet])
|
|
end
|
|
end
|
|
|
|
context 'using a non-existing snippet ID' do
|
|
it 'returns an empty Array' do
|
|
link['data-snippet'] = ''
|
|
|
|
expect(subject.referenced_by([link])).to eq([])
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|