blob: f781e2adf0748d9c2a30bf4971b2c1709baf07cd (
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
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'Admin browse spam logs', feature_category: :shared do
let!(:spam_log) { create(:spam_log, description: 'abcde ' * 20) }
let(:admin) { create(:admin) }
before do
sign_in(admin)
gitlab_enable_admin_mode_sign_in(admin)
end
it 'browse spam logs' do
visit admin_spam_logs_path
expect(page).to have_content('Spam Logs')
expect(page).to have_content(spam_log.source_ip)
expect(page).to have_content(spam_log.noteable_type)
expect(page).to have_content('N')
expect(page).to have_content(spam_log.title)
expect(page).to have_content("#{spam_log.description[0...97]}...")
expect(page).to have_link('Remove user')
expect(page).to have_link('Block user')
expect(page).to have_link('Trust user')
end
it 'does not perform N+1 queries' do
control_queries = ActiveRecord::QueryRecorder.new { visit admin_spam_logs_path }
create(:spam_log)
expect { visit admin_spam_logs_path }.not_to exceed_query_limit(control_queries)
end
context 'when user is trusted' do
before do
UserCustomAttribute.set_trusted_by(user: spam_log.user, trusted_by: admin)
end
it 'allows admin to untrust the user' do
visit admin_spam_logs_path
expect(page).to have_link('Untrust user')
end
end
end
|