blob: 861f3fffa8335ab8374c167e245a26b58d773a17 (
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'admin/application_settings/general.html.haml' do
let(:app_settings) { Gitlab::CurrentSettings.current_application_settings }
let(:user) { create(:admin) }
before do
assign(:application_setting, app_settings)
allow(view).to receive(:current_user).and_return(user)
end
describe 'sourcegraph integration' do
let(:sourcegraph_flag) { true }
before do
allow(Gitlab::Sourcegraph).to receive(:feature_available?).and_return(sourcegraph_flag)
end
context 'when sourcegraph feature is enabled' do
it 'show the form' do
render
expect(rendered).to have_field('application_setting_sourcegraph_enabled')
end
end
context 'when sourcegraph feature is disabled' do
let(:sourcegraph_flag) { false }
it 'show the form' do
render
expect(rendered).not_to have_field('application_setting_sourcegraph_enabled')
end
end
end
describe 'prompt user about registration features' do
context 'when service ping is enabled' do
before do
stub_application_setting(usage_ping_enabled: true)
end
it_behaves_like 'does not render registration features prompt', :application_setting_disabled_repository_size_limit
end
context 'with no license and service ping disabled', :without_license do
before do
stub_application_setting(usage_ping_enabled: false)
end
it_behaves_like 'renders registration features prompt', :application_setting_disabled_repository_size_limit
end
end
describe 'add license' do
before do
render
end
it 'does not show the Add License section' do
expect(rendered).not_to have_css('#js-add-license-toggle')
end
end
describe 'jira connect settings' do
it 'shows the jira connect settings section' do
render
expect(rendered).to have_css('#js-jira_connect-settings')
end
end
describe 'sign-up restrictions' do
it 'renders js-signup-form tag' do
render
expect(rendered).to match 'id="js-signup-form"'
expect(rendered).to match ' data-minimum-password-length='
end
end
describe 'error tracking integration' do
context 'with error tracking feature flag enabled' do
before do
stub_feature_flags(gitlab_error_tracking: true)
render
end
it 'expects error tracking settings to be available' do
expect(rendered).to have_field('application_setting_error_tracking_api_url')
end
it 'expects display token and reset token to be available' do
expect(rendered).to have_content(app_settings.error_tracking_access_token)
expect(rendered).to have_button('Reset error tracking access token')
end
end
context 'with error tracking feature flag disabled' do
it 'expects error tracking settings to not be avaiable' do
stub_feature_flags(gitlab_error_tracking: false)
render
expect(rendered).not_to have_field('application_setting_error_tracking_api_url')
end
end
end
describe 'instance-level code suggestions settings', feature_category: :code_suggestions do
before do
allow(::Gitlab).to receive(:org_or_com?).and_return(gitlab_org_or_com?)
render
end
context 'when on .com or .org' do
let(:gitlab_org_or_com?) { true }
it 'does not render the form' do
expect(rendered).not_to have_field('application_setting_instance_level_code_suggestions_enabled')
expect(rendered).not_to have_field('application_setting_ai_access_token')
end
end
context 'when not on .com and not on .org' do
let(:gitlab_org_or_com?) { false }
it 'renders the form' do
expect(rendered).to have_field('application_setting_instance_level_code_suggestions_enabled')
expect(rendered).to have_field('application_setting_ai_access_token')
end
end
end
end
|