blob: 71ef97b0448b534ff5113f87f29b94c136fb8311 (
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
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'shared/snippets/_snippet.html.haml' do
let_it_be(:snippet) { create(:snippet) }
before do
allow(view).to receive(:current_application_settings).and_return(Gitlab::CurrentSettings.current_application_settings)
allow(view).to receive(:can?) { true }
@noteable_meta_data = Class.new { include Gitlab::NoteableMetadata }.new.noteable_meta_data([snippet], 'Snippet')
end
context 'snippet with statistics' do
it 'renders correct file count and tooltip' do
snippet.statistics.file_count = 3
render 'shared/snippets/snippet', snippet: snippet
expect(rendered).to have_selector("span.file_count", text: '3')
expect(rendered).to have_selector("span.file_count[title=\"3 files\"]")
end
it 'renders correct file count and tooltip when file_count is 1' do
snippet.statistics.file_count = 1
render 'shared/snippets/snippet', snippet: snippet
expect(rendered).to have_selector("span.file_count", text: '1')
expect(rendered).to have_selector("span.file_count[title=\"1 file\"]")
end
it 'does not render file count when file count is 0' do
snippet.statistics.file_count = 0
render 'shared/snippets/snippet', snippet: snippet
expect(rendered).not_to have_selector('span.file_count')
end
end
context 'snippet without statistics' do
it 'does not render file count if statistics are not present' do
snippet.statistics = nil
render 'shared/snippets/snippet', snippet: snippet
expect(rendered).not_to have_selector('span.file_count')
end
end
context 'spam icon and tooltip', feature_category: :insider_threat do
context 'when the author of the snippet is not banned' do
before do
render 'shared/snippets/snippet', snippet: snippet
end
it 'does not render spam icon' do
expect(rendered).not_to have_css('[data-testid="spam-icon"]')
end
it 'does not render tooltip' do
expect(rendered).not_to have_selector("span.has-tooltip")
end
end
context 'when the author of the snippet is banned' do
let_it_be(:banned_user) { create(:user, :banned) }
let_it_be(:snippet) { create(:snippet, author: banned_user) }
before do
render 'shared/snippets/snippet', snippet: snippet
end
it 'renders spam icon' do
expect(rendered).to have_css('[data-testid="spam-icon"]')
end
it 'renders tooltip' do
expect(rendered).to have_selector("span.has-tooltip[title='This snippet is hidden because its author has been banned']")
end
end
end
end
|