Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
d60c6f46
Commit
d60c6f46
authored
Feb 01, 2022
by
Tom Quirk
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove vue_integration_form feature flag
Changelog: changed
parent
6cfa36b0
Changes
12
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
180 additions
and
349 deletions
+180
-349
app/assets/javascripts/integrations/constants.js
app/assets/javascripts/integrations/constants.js
+0
-2
app/assets/javascripts/integrations/edit/components/integration_form.vue
...scripts/integrations/edit/components/integration_form.vue
+20
-46
app/controllers/concerns/integrations/actions.rb
app/controllers/concerns/integrations/actions.rb
+0
-3
app/controllers/projects/services_controller.rb
app/controllers/projects/services_controller.rb
+0
-3
app/helpers/integrations_helper.rb
app/helpers/integrations_helper.rb
+0
-4
app/views/projects/services/_form.html.haml
app/views/projects/services/_form.html.haml
+1
-7
app/views/shared/integrations/_form.html.haml
app/views/shared/integrations/_form.html.haml
+0
-4
app/views/shared/integrations/edit.html.haml
app/views/shared/integrations/edit.html.haml
+1
-4
config/feature_flags/development/vue_integration_form.yml
config/feature_flags/development/vue_integration_form.yml
+0
-8
spec/features/admin/integrations/user_activates_mattermost_slash_command_spec.rb
...egrations/user_activates_mattermost_slash_command_spec.rb
+0
-15
spec/frontend/integrations/edit/components/integration_form_spec.js
...end/integrations/edit/components/integration_form_spec.js
+158
-201
spec/views/projects/services/_form.haml_spec.rb
spec/views/projects/services/_form.haml_spec.rb
+0
-52
No files found.
app/assets/javascripts/integrations/constants.js
View file @
d60c6f46
...
@@ -24,5 +24,3 @@ export const I18N_SUCCESSFUL_CONNECTION_MESSAGE = s__('Integrations|Connection s
...
@@ -24,5 +24,3 @@ export const I18N_SUCCESSFUL_CONNECTION_MESSAGE = s__('Integrations|Connection s
export
const
settingsTabTitle
=
__
(
'
Settings
'
);
export
const
settingsTabTitle
=
__
(
'
Settings
'
);
export
const
overridesTabTitle
=
s__
(
'
Integrations|Projects using custom settings
'
);
export
const
overridesTabTitle
=
s__
(
'
Integrations|Projects using custom settings
'
);
export
const
INTEGRATION_FORM_SELECTOR
=
'
.js-integration-settings-form
'
;
app/assets/javascripts/integrations/edit/components/integration_form.vue
View file @
d60c6f46
...
@@ -8,7 +8,6 @@ import {
...
@@ -8,7 +8,6 @@ import {
I18N_FETCH_TEST_SETTINGS_DEFAULT_ERROR_MESSAGE
,
I18N_FETCH_TEST_SETTINGS_DEFAULT_ERROR_MESSAGE
,
I18N_DEFAULT_ERROR_MESSAGE
,
I18N_DEFAULT_ERROR_MESSAGE
,
I18N_SUCCESSFUL_CONNECTION_MESSAGE
,
I18N_SUCCESSFUL_CONNECTION_MESSAGE
,
INTEGRATION_FORM_SELECTOR
,
integrationLevels
,
integrationLevels
,
}
from
'
~/integrations/constants
'
;
}
from
'
~/integrations/constants
'
;
import
{
refreshCurrentPage
}
from
'
~/lib/utils/url_utility
'
;
import
{
refreshCurrentPage
}
from
'
~/lib/utils/url_utility
'
;
...
@@ -82,28 +81,9 @@ export default {
...
@@ -82,28 +81,9 @@ export default {
disableButtons
()
{
disableButtons
()
{
return
Boolean
(
this
.
isSaving
||
this
.
isResetting
||
this
.
isTesting
);
return
Boolean
(
this
.
isSaving
||
this
.
isResetting
||
this
.
isTesting
);
},
},
useVueF
orm
()
{
f
orm
()
{
return
this
.
glFeatures
?.
vueIntegrationForm
;
return
this
.
$refs
.
integrationForm
.
$el
;
},
},
formContainerProps
()
{
return
this
.
useVueForm
?
{
ref
:
'
integrationForm
'
,
method
:
'
post
'
,
class
:
'
gl-mb-3 gl-show-field-errors integration-settings-form
'
,
action
:
this
.
propsSource
.
formPath
,
novalidate
:
!
this
.
integrationActive
,
}
:
{};
},
formContainer
()
{
return
this
.
useVueForm
?
GlForm
:
'
div
'
;
},
},
mounted
()
{
this
.
form
=
this
.
useVueForm
?
this
.
$refs
.
integrationForm
.
$el
:
document
.
querySelector
(
INTEGRATION_FORM_SELECTOR
);
},
},
methods
:
{
methods
:
{
...
mapActions
([
'
setOverride
'
,
'
requestJiraIssueTypes
'
]),
...
mapActions
([
'
setOverride
'
,
'
requestJiraIssueTypes
'
]),
...
@@ -122,13 +102,13 @@ export default {
...
@@ -122,13 +102,13 @@ export default {
this
.
form
.
submit
();
this
.
form
.
submit
();
},
},
onTestClick
()
{
onTestClick
()
{
this
.
isTesting
=
true
;
if
(
!
this
.
form
.
checkValidity
())
{
if
(
!
this
.
form
.
checkValidity
())
{
this
.
setIsValidated
();
this
.
setIsValidated
();
return
;
return
;
}
}
this
.
isTesting
=
true
;
testIntegrationSettings
(
this
.
propsSource
.
testPath
,
this
.
getFormData
())
testIntegrationSettings
(
this
.
propsSource
.
testPath
,
this
.
getFormData
())
.
then
(({
data
:
{
error
,
message
=
I18N_FETCH_TEST_SETTINGS_DEFAULT_ERROR_MESSAGE
}
})
=>
{
.
then
(({
data
:
{
error
,
message
=
I18N_FETCH_TEST_SETTINGS_DEFAULT_ERROR_MESSAGE
}
})
=>
{
if
(
error
)
{
if
(
error
)
{
...
@@ -171,16 +151,6 @@ export default {
...
@@ -171,16 +151,6 @@ export default {
},
},
onToggleIntegrationState
(
integrationActive
)
{
onToggleIntegrationState
(
integrationActive
)
{
this
.
integrationActive
=
integrationActive
;
this
.
integrationActive
=
integrationActive
;
if
(
!
this
.
form
||
this
.
useVueForm
)
{
return
;
}
// If integration will be active, enable form validation.
if
(
integrationActive
)
{
this
.
form
.
removeAttribute
(
'
novalidate
'
);
}
else
{
this
.
form
.
setAttribute
(
'
novalidate
'
,
true
);
}
},
},
},
},
helpHtmlConfig
:
{
helpHtmlConfig
:
{
...
@@ -193,17 +163,21 @@ export default {
...
@@ -193,17 +163,21 @@ export default {
</
script
>
</
script
>
<
template
>
<
template
>
<component
:is=
"formContainer"
v-bind=
"formContainerProps"
>
<gl-form
<template
v-if=
"useVueForm"
>
ref=
"integrationForm"
<input
type=
"hidden"
name=
"_method"
value=
"put"
/>
method=
"post"
<input
type=
"hidden"
name=
"authenticity_token"
:value=
"$options.csrf.token"
/>
class=
"gl-mb-3 gl-show-field-errors integration-settings-form"
<input
:action=
"propsSource.formPath"
type=
"hidden"
:novalidate=
"!integrationActive"
name=
"redirect_to"
>
:value=
"propsSource.redirectTo"
<input
type=
"hidden"
name=
"_method"
value=
"put"
/>
data-testid=
"redirect-to-field"
<input
type=
"hidden"
name=
"authenticity_token"
:value=
"$options.csrf.token"
/>
/>
<input
</
template
>
type=
"hidden"
name=
"redirect_to"
:value=
"propsSource.redirectTo"
data-testid=
"redirect-to-field"
/>
<override-dropdown
<override-dropdown
v-if=
"defaultState !== null"
v-if=
"defaultState !== null"
...
@@ -316,5 +290,5 @@ export default {
...
@@ -316,5 +290,5 @@ export default {
</div>
</div>
</div>
</div>
</div>
</div>
</
component
>
</
gl-form
>
</template>
</template>
app/controllers/concerns/integrations/actions.rb
View file @
d60c6f46
...
@@ -8,9 +8,6 @@ module Integrations::Actions
...
@@ -8,9 +8,6 @@ module Integrations::Actions
include
IntegrationsHelper
include
IntegrationsHelper
before_action
:integration
,
only:
[
:edit
,
:update
,
:overrides
,
:test
]
before_action
:integration
,
only:
[
:edit
,
:update
,
:overrides
,
:test
]
before_action
do
push_frontend_feature_flag
(
:vue_integration_form
,
current_user
,
default_enabled: :yaml
)
end
urgency
:low
,
[
:test
]
urgency
:low
,
[
:test
]
end
end
...
...
app/controllers/projects/services_controller.rb
View file @
d60c6f46
...
@@ -12,9 +12,6 @@ class Projects::ServicesController < Projects::ApplicationController
...
@@ -12,9 +12,6 @@ class Projects::ServicesController < Projects::ApplicationController
before_action
:web_hook_logs
,
only:
[
:edit
,
:update
]
before_action
:web_hook_logs
,
only:
[
:edit
,
:update
]
before_action
:set_deprecation_notice_for_prometheus_integration
,
only:
[
:edit
,
:update
]
before_action
:set_deprecation_notice_for_prometheus_integration
,
only:
[
:edit
,
:update
]
before_action
:redirect_deprecated_prometheus_integration
,
only:
[
:update
]
before_action
:redirect_deprecated_prometheus_integration
,
only:
[
:update
]
before_action
do
push_frontend_feature_flag
(
:vue_integration_form
,
current_user
,
default_enabled: :yaml
)
end
respond_to
:html
respond_to
:html
...
...
app/helpers/integrations_helper.rb
View file @
d60c6f46
...
@@ -228,10 +228,6 @@ module IntegrationsHelper
...
@@ -228,10 +228,6 @@ module IntegrationsHelper
name:
integration
.
to_param
name:
integration
.
to_param
}
}
end
end
def
vue_integration_form_enabled?
Feature
.
enabled?
(
:vue_integration_form
,
current_user
,
default_enabled: :yaml
)
end
end
end
IntegrationsHelper
.
prepend_mod_with
(
'IntegrationsHelper'
)
IntegrationsHelper
.
prepend_mod_with
(
'IntegrationsHelper'
)
...
...
app/views/projects/services/_form.html.haml
View file @
d60c6f46
...
@@ -6,13 +6,7 @@
...
@@ -6,13 +6,7 @@
-
if
integration
.
operating?
-
if
integration
.
operating?
=
sprite_icon
(
'check'
,
css_class:
'gl-text-green-500'
)
=
sprite_icon
(
'check'
,
css_class:
'gl-text-green-500'
)
-
if
vue_integration_form_enabled?
=
render
'shared/integration_settings'
,
integration:
integration
=
render
'shared/integration_settings'
,
integration:
integration
-
else
=
form_for
(
integration
,
as: :service
,
url:
scoped_integration_path
(
integration
,
project:
@project
,
group:
@group
),
method: :put
,
html:
{
class:
'gl-show-field-errors integration-settings-form js-integration-settings-form'
,
data:
{
'test-url'
=>
test_project_integration_path
(
@project
,
integration
),
testid:
'integration-form'
}
})
do
|
form
|
=
render
'shared/integration_settings'
,
form:
form
,
integration:
integration
%input
{
id:
'services_redirect_to'
,
type:
'hidden'
,
name:
'redirect_to'
,
value:
request
.
referer
}
-
if
lookup_context
.
template_exists?
(
'show'
,
"projects/services/
#{
integration
.
to_param
}
"
,
true
)
-
if
lookup_context
.
template_exists?
(
'show'
,
"projects/services/
#{
integration
.
to_param
}
"
,
true
)
%hr
%hr
=
render
"projects/services/
#{
integration
.
to_param
}
/show"
,
integration:
integration
=
render
"projects/services/
#{
integration
.
to_param
}
/show"
,
integration:
integration
app/views/shared/integrations/_form.html.haml
deleted
100644 → 0
View file @
6cfa36b0
-
integration
=
local_assigns
.
fetch
(
:integration
)
=
form_for
integration
,
as: :service
,
url:
scoped_integration_path
(
integration
,
group:
@group
),
method: :put
,
html:
{
class:
'gl-show-field-errors integration-settings-form js-integration-settings-form'
,
data:
{
'test-url'
=>
scoped_test_integration_path
(
integration
,
group:
@group
),
testid:
'integration-form'
}
}
do
|
form
|
=
render
'shared/integration_settings'
,
form:
form
,
integration:
integration
app/views/shared/integrations/edit.html.haml
View file @
d60c6f46
...
@@ -7,7 +7,4 @@
...
@@ -7,7 +7,4 @@
=
@integration
.
title
=
@integration
.
title
=
render
'shared/integrations/tabs'
,
integration:
@integration
,
active_tab:
'edit'
do
=
render
'shared/integrations/tabs'
,
integration:
@integration
,
active_tab:
'edit'
do
-
if
vue_integration_form_enabled?
=
render
'shared/integration_settings'
,
integration:
@integration
=
render
'shared/integration_settings'
,
integration:
@integration
-
else
=
render
'shared/integrations/form'
,
integration:
@integration
config/feature_flags/development/vue_integration_form.yml
deleted
100644 → 0
View file @
6cfa36b0
---
name
:
vue_integration_form
introduced_by_url
:
https://gitlab.com/gitlab-org/gitlab/-/merge_requests/77934
rollout_issue_url
:
https://gitlab.com/gitlab-org/gitlab/-/issues/350444
milestone
:
'
14.7'
type
:
development
group
:
group::integrations
default_enabled
:
false
spec/features/admin/integrations/user_activates_mattermost_slash_command_spec.rb
View file @
d60c6f46
...
@@ -19,19 +19,4 @@ RSpec.describe 'User activates the instance-level Mattermost Slash Command integ
...
@@ -19,19 +19,4 @@ RSpec.describe 'User activates the instance-level Mattermost Slash Command integ
expect
(
page
).
to
have_link
(
'Settings'
,
href:
edit_path
)
expect
(
page
).
to
have_link
(
'Settings'
,
href:
edit_path
)
expect
(
page
).
to
have_link
(
'Projects using custom settings'
,
href:
overrides_path
)
expect
(
page
).
to
have_link
(
'Projects using custom settings'
,
href:
overrides_path
)
end
end
it
'does not render integration form element'
do
expect
(
page
).
not_to
have_selector
(
'[data-testid="integration-form"]'
)
end
context
'when `vue_integration_form` feature flag is disabled'
do
before
do
stub_feature_flags
(
vue_integration_form:
false
)
visit_instance_integration
(
'Mattermost slash commands'
)
end
it
'renders integration form element'
do
expect
(
page
).
to
have_selector
(
'[data-testid="integration-form"]'
)
end
end
end
end
spec/frontend/integrations/edit/components/integration_form_spec.js
View file @
d60c6f46
This diff is collapsed.
Click to expand it.
spec/views/projects/services/_form.haml_spec.rb
deleted
100644 → 0
View file @
6cfa36b0
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
'projects/services/_form'
do
let
(
:project
)
{
create
(
:redmine_project
)
}
let
(
:user
)
{
create
(
:admin
)
}
before
do
assign
(
:project
,
project
)
allow
(
controller
).
to
receive
(
:current_user
).
and_return
(
user
)
allow
(
view
).
to
receive_messages
(
current_user:
user
,
can?:
true
,
current_application_settings:
Gitlab
::
CurrentSettings
.
current_application_settings
,
integration:
project
.
redmine_integration
,
request:
double
(
referer:
'/services'
)
)
end
context
'integrations form'
do
it
'does not render form element'
do
render
expect
(
rendered
).
not_to
have_selector
(
'[data-testid="integration-form"]'
)
end
context
'when vue_integration_form feature flag is disabled'
do
before
do
stub_feature_flags
(
vue_integration_form:
false
)
end
it
'renders form element'
do
render
expect
(
rendered
).
to
have_selector
(
'[data-testid="integration-form"]'
)
end
context
'commit_events and merge_request_events'
do
it
'display merge_request_events and commit_events descriptions'
do
allow
(
Integrations
::
Redmine
).
to
receive
(
:supported_events
).
and_return
(
%w(commit merge_request)
)
render
expect
(
rendered
).
to
have_css
(
"input[name='redirect_to'][value='/services']"
,
count:
1
,
visible:
false
)
end
end
end
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment