blob: 44454385297443b0e6014a00c3eaac16d9e7e924 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
# frozen_string_literal: true
require 'spec_helper'
require 'nokogiri'
require 'gitlab/docs/page'
require 'gitlab/docs/link'
require 'gitlab/docs/element'
require 'gitlab/docs/document'
describe Gitlab::Docs::Page do
subject do
described_class.new('some/file.html')
end
context 'when file exists' do
before do
allow(File).to receive(:exist?)
.with('some/file.html')
.and_return(true)
allow(File).to receive(:read)
.with('some/file.html')
.and_return <<~HTML
<html>
<body>
<a href="../link.html#my-anchor">See external file</a>
<a href="#internal-anchor">See internal section</a>
<a href="#internal-anchor-2">See internal section broken</a>
<a href="#utf-8-id-✔">See utf-8 anchor</a>
<a href="#utf-8-id-%E2%9C%94">See utf-8 anchor 2</a>
<h1 id="internal-anchor">Some section</h1>
<h1 id="utf-8-id-✔">Some section 2</h1>
</body>
</html>
HTML
end
describe '#links' do
it 'collects links on a page' do
expect(subject.links.count).to eq 4
end
end
describe '#hrefs' do
it 'collects all hrefs' do
expect(subject.hrefs).to match_array %w[../link.html#my-anchor
#internal-anchor
#internal-anchor-2
#utf-8-id-✔]
end
end
describe '#ids' do
it 'collects all ids' do
expect(subject.ids).to match_array %w[internal-anchor
utf-8-id-✔]
end
end
describe '#has_anchor?' do
it 'returns true when anchor exists on a page' do
expect(subject).to have_anchor('internal-anchor')
end
it 'returns false when anchors does not exist' do
expect(subject).not_to have_anchor('internal-anchor-2')
end
it 'returns true when UTF-8 encoded anchors are compared' do
expect(subject).to have_anchor('utf-8-id-✔')
expect(subject).to have_anchor('utf-8-id-%E2%9C%94')
expect(subject).to have_anchor('utf-8-id-%e2%9c%94')
end
end
end
describe '#directory' do
it 'returns base directory of a file' do
expect(subject.directory).to eq 'some'
end
end
describe '.build' do
context 'when path does not lead to the HTML file' do
it 'builds an index.html page object' do
page = described_class.build('some/path')
expect(page.file).to eq 'some/path/index.html'
end
end
context 'when path leads to the HTML file' do
it 'builds an object representing that file' do
page = described_class.build('some/path/file.html')
expect(page.file).to eq 'some/path/file.html'
end
end
end
end
|