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
de1567a7
Commit
de1567a7
authored
Jan 08, 2021
by
Tom Quirk
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use object param in integration_form_spec
parent
3663b86c
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
112 additions
and
50 deletions
+112
-50
app/assets/javascripts/integrations/edit/components/integration_form.vue
...scripts/integrations/edit/components/integration_form.vue
+3
-3
spec/features/projects/services/user_activates_slack_slash_command_spec.rb
...jects/services/user_activates_slack_slash_command_spec.rb
+4
-0
spec/frontend/integrations/edit/components/integration_form_spec.js
...end/integrations/edit/components/integration_form_spec.js
+105
-47
No files found.
app/assets/javascripts/integrations/edit/components/integration_form.vue
View file @
de1567a7
...
@@ -96,6 +96,9 @@ export default {
...
@@ -96,6 +96,9 @@ export default {
<
template
>
<
template
>
<div>
<div>
<!-- helpHtml is trusted input -->
<div
v-if=
"helpHtml"
v-safe-html:
[$
options.helpHtmlConfig]=
"helpHtml"
></div>
<override-dropdown
<override-dropdown
v-if=
"defaultState !== null"
v-if=
"defaultState !== null"
:inherit-from-id=
"defaultState.id"
:inherit-from-id=
"defaultState.id"
...
@@ -104,9 +107,6 @@ export default {
...
@@ -104,9 +107,6 @@ export default {
@
change=
"setOverride"
@
change=
"setOverride"
/>
/>
<!-- helpHtml is trusted input -->
<div
v-if=
"helpHtml"
v-safe-html:
[$
options.helpHtmlConfig]=
"helpHtml"
></div>
<active-checkbox
v-if=
"propsSource.showActive"
:key=
"`$
{currentKey}-active-checkbox`" />
<active-checkbox
v-if=
"propsSource.showActive"
:key=
"`$
{currentKey}-active-checkbox`" />
<jira-trigger-fields
<jira-trigger-fields
v-if=
"isJira"
v-if=
"isJira"
...
...
spec/features/projects/services/user_activates_slack_slash_command_spec.rb
View file @
de1567a7
...
@@ -40,4 +40,8 @@ RSpec.describe 'Slack slash commands', :js do
...
@@ -40,4 +40,8 @@ RSpec.describe 'Slack slash commands', :js do
value
=
find_field
(
'url'
).
value
value
=
find_field
(
'url'
).
value
expect
(
value
).
to
match
(
"api/v4/projects/
#{
project
.
id
}
/services/slack_slash_commands/trigger"
)
expect
(
value
).
to
match
(
"api/v4/projects/
#{
project
.
id
}
/services/slack_slash_commands/trigger"
)
end
end
it
'shows help content'
do
expect
(
page
).
to
have_content
(
'This service allows users to perform common operations on this project by entering slash commands in Slack.'
)
end
end
end
spec/frontend/integrations/edit/components/integration_form_spec.js
View file @
de1567a7
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
mockIntegrationProps
}
from
'
jest/integrations/edit/mock_data
'
;
import
{
mockIntegrationProps
}
from
'
jest/integrations/edit/mock_data
'
;
import
{
extendedWrapper
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
createStore
}
from
'
~/integrations/edit/store
'
;
import
{
createStore
}
from
'
~/integrations/edit/store
'
;
import
IntegrationForm
from
'
~/integrations/edit/components/integration_form.vue
'
;
import
IntegrationForm
from
'
~/integrations/edit/components/integration_form.vue
'
;
import
OverrideDropdown
from
'
~/integrations/edit/components/override_dropdown.vue
'
;
import
OverrideDropdown
from
'
~/integrations/edit/components/override_dropdown.vue
'
;
...
@@ -15,24 +16,31 @@ import { integrationLevels } from '~/integrations/edit/constants';
...
@@ -15,24 +16,31 @@ import { integrationLevels } from '~/integrations/edit/constants';
describe
(
'
IntegrationForm
'
,
()
=>
{
describe
(
'
IntegrationForm
'
,
()
=>
{
let
wrapper
;
let
wrapper
;
const
createComponent
=
(
customStateProps
=
{},
featureFlags
=
{},
initialState
=
{})
=>
{
const
createComponent
=
({
wrapper
=
shallowMount
(
IntegrationForm
,
{
customStateProps
=
{},
propsData
:
{},
featureFlags
=
{},
store
:
createStore
({
initialState
=
{},
customState
:
{
...
mockIntegrationProps
,
...
customStateProps
},
props
=
{},
...
initialState
,
}
=
{})
=>
{
wrapper
=
extendedWrapper
(
shallowMount
(
IntegrationForm
,
{
propsData
:
{
...
props
},
store
:
createStore
({
customState
:
{
...
mockIntegrationProps
,
...
customStateProps
},
...
initialState
,
}),
stubs
:
{
OverrideDropdown
,
ActiveCheckbox
,
ConfirmationModal
,
JiraTriggerFields
,
TriggerFields
,
},
provide
:
{
glFeatures
:
featureFlags
,
},
}),
}),
stubs
:
{
);
OverrideDropdown
,
ActiveCheckbox
,
ConfirmationModal
,
JiraTriggerFields
,
TriggerFields
,
},
provide
:
{
glFeatures
:
featureFlags
,
},
});
};
};
afterEach
(()
=>
{
afterEach
(()
=>
{
...
@@ -63,7 +71,9 @@ describe('IntegrationForm', () => {
...
@@ -63,7 +71,9 @@ describe('IntegrationForm', () => {
describe
(
'
showActive is false
'
,
()
=>
{
describe
(
'
showActive is false
'
,
()
=>
{
it
(
'
does not render ActiveCheckbox
'
,
()
=>
{
it
(
'
does not render ActiveCheckbox
'
,
()
=>
{
createComponent
({
createComponent
({
showActive
:
false
,
customStateProps
:
{
showActive
:
false
,
},
});
});
expect
(
findActiveCheckbox
().
exists
()).
toBe
(
false
);
expect
(
findActiveCheckbox
().
exists
()).
toBe
(
false
);
...
@@ -73,7 +83,9 @@ describe('IntegrationForm', () => {
...
@@ -73,7 +83,9 @@ describe('IntegrationForm', () => {
describe
(
'
integrationLevel is instance
'
,
()
=>
{
describe
(
'
integrationLevel is instance
'
,
()
=>
{
it
(
'
renders ConfirmationModal
'
,
()
=>
{
it
(
'
renders ConfirmationModal
'
,
()
=>
{
createComponent
({
createComponent
({
integrationLevel
:
integrationLevels
.
INSTANCE
,
customStateProps
:
{
integrationLevel
:
integrationLevels
.
INSTANCE
,
},
});
});
expect
(
findConfirmationModal
().
exists
()).
toBe
(
true
);
expect
(
findConfirmationModal
().
exists
()).
toBe
(
true
);
...
@@ -82,7 +94,9 @@ describe('IntegrationForm', () => {
...
@@ -82,7 +94,9 @@ describe('IntegrationForm', () => {
describe
(
'
resetPath is empty
'
,
()
=>
{
describe
(
'
resetPath is empty
'
,
()
=>
{
it
(
'
does not render ResetConfirmationModal and button
'
,
()
=>
{
it
(
'
does not render ResetConfirmationModal and button
'
,
()
=>
{
createComponent
({
createComponent
({
integrationLevel
:
integrationLevels
.
INSTANCE
,
customStateProps
:
{
integrationLevel
:
integrationLevels
.
INSTANCE
,
},
});
});
expect
(
findResetButton
().
exists
()).
toBe
(
false
);
expect
(
findResetButton
().
exists
()).
toBe
(
false
);
...
@@ -93,8 +107,10 @@ describe('IntegrationForm', () => {
...
@@ -93,8 +107,10 @@ describe('IntegrationForm', () => {
describe
(
'
resetPath is present
'
,
()
=>
{
describe
(
'
resetPath is present
'
,
()
=>
{
it
(
'
renders ResetConfirmationModal and button
'
,
()
=>
{
it
(
'
renders ResetConfirmationModal and button
'
,
()
=>
{
createComponent
({
createComponent
({
integrationLevel
:
integrationLevels
.
INSTANCE
,
customStateProps
:
{
resetPath
:
'
resetPath
'
,
integrationLevel
:
integrationLevels
.
INSTANCE
,
resetPath
:
'
resetPath
'
,
},
});
});
expect
(
findResetButton
().
exists
()).
toBe
(
true
);
expect
(
findResetButton
().
exists
()).
toBe
(
true
);
...
@@ -106,7 +122,9 @@ describe('IntegrationForm', () => {
...
@@ -106,7 +122,9 @@ describe('IntegrationForm', () => {
describe
(
'
integrationLevel is group
'
,
()
=>
{
describe
(
'
integrationLevel is group
'
,
()
=>
{
it
(
'
renders ConfirmationModal
'
,
()
=>
{
it
(
'
renders ConfirmationModal
'
,
()
=>
{
createComponent
({
createComponent
({
integrationLevel
:
integrationLevels
.
GROUP
,
customStateProps
:
{
integrationLevel
:
integrationLevels
.
GROUP
,
},
});
});
expect
(
findConfirmationModal
().
exists
()).
toBe
(
true
);
expect
(
findConfirmationModal
().
exists
()).
toBe
(
true
);
...
@@ -115,7 +133,9 @@ describe('IntegrationForm', () => {
...
@@ -115,7 +133,9 @@ describe('IntegrationForm', () => {
describe
(
'
resetPath is empty
'
,
()
=>
{
describe
(
'
resetPath is empty
'
,
()
=>
{
it
(
'
does not render ResetConfirmationModal and button
'
,
()
=>
{
it
(
'
does not render ResetConfirmationModal and button
'
,
()
=>
{
createComponent
({
createComponent
({
integrationLevel
:
integrationLevels
.
GROUP
,
customStateProps
:
{
integrationLevel
:
integrationLevels
.
GROUP
,
},
});
});
expect
(
findResetButton
().
exists
()).
toBe
(
false
);
expect
(
findResetButton
().
exists
()).
toBe
(
false
);
...
@@ -126,8 +146,10 @@ describe('IntegrationForm', () => {
...
@@ -126,8 +146,10 @@ describe('IntegrationForm', () => {
describe
(
'
resetPath is present
'
,
()
=>
{
describe
(
'
resetPath is present
'
,
()
=>
{
it
(
'
renders ResetConfirmationModal and button
'
,
()
=>
{
it
(
'
renders ResetConfirmationModal and button
'
,
()
=>
{
createComponent
({
createComponent
({
integrationLevel
:
integrationLevels
.
GROUP
,
customStateProps
:
{
resetPath
:
'
resetPath
'
,
integrationLevel
:
integrationLevels
.
GROUP
,
resetPath
:
'
resetPath
'
,
},
});
});
expect
(
findResetButton
().
exists
()).
toBe
(
true
);
expect
(
findResetButton
().
exists
()).
toBe
(
true
);
...
@@ -139,7 +161,9 @@ describe('IntegrationForm', () => {
...
@@ -139,7 +161,9 @@ describe('IntegrationForm', () => {
describe
(
'
integrationLevel is project
'
,
()
=>
{
describe
(
'
integrationLevel is project
'
,
()
=>
{
it
(
'
does not render ConfirmationModal
'
,
()
=>
{
it
(
'
does not render ConfirmationModal
'
,
()
=>
{
createComponent
({
createComponent
({
integrationLevel
:
'
project
'
,
customStateProps
:
{
integrationLevel
:
'
project
'
,
},
});
});
expect
(
findConfirmationModal
().
exists
()).
toBe
(
false
);
expect
(
findConfirmationModal
().
exists
()).
toBe
(
false
);
...
@@ -147,8 +171,10 @@ describe('IntegrationForm', () => {
...
@@ -147,8 +171,10 @@ describe('IntegrationForm', () => {
it
(
'
does not render ResetConfirmationModal and button
'
,
()
=>
{
it
(
'
does not render ResetConfirmationModal and button
'
,
()
=>
{
createComponent
({
createComponent
({
integrationLevel
:
'
project
'
,
customStateProps
:
{
resetPath
:
'
resetPath
'
,
integrationLevel
:
'
project
'
,
resetPath
:
'
resetPath
'
,
},
});
});
expect
(
findResetButton
().
exists
()).
toBe
(
false
);
expect
(
findResetButton
().
exists
()).
toBe
(
false
);
...
@@ -158,7 +184,9 @@ describe('IntegrationForm', () => {
...
@@ -158,7 +184,9 @@ describe('IntegrationForm', () => {
describe
(
'
type is "slack"
'
,
()
=>
{
describe
(
'
type is "slack"
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(()
=>
{
createComponent
({
type
:
'
slack
'
});
createComponent
({
customStateProps
:
{
type
:
'
slack
'
},
});
});
});
it
(
'
does not render JiraTriggerFields
'
,
()
=>
{
it
(
'
does not render JiraTriggerFields
'
,
()
=>
{
...
@@ -172,14 +200,19 @@ describe('IntegrationForm', () => {
...
@@ -172,14 +200,19 @@ describe('IntegrationForm', () => {
describe
(
'
type is "jira"
'
,
()
=>
{
describe
(
'
type is "jira"
'
,
()
=>
{
it
(
'
renders JiraTriggerFields
'
,
()
=>
{
it
(
'
renders JiraTriggerFields
'
,
()
=>
{
createComponent
({
type
:
'
jira
'
});
createComponent
({
customStateProps
:
{
type
:
'
jira
'
},
});
expect
(
findJiraTriggerFields
().
exists
()).
toBe
(
true
);
expect
(
findJiraTriggerFields
().
exists
()).
toBe
(
true
);
});
});
describe
(
'
featureFlag jiraIssuesIntegration is false
'
,
()
=>
{
describe
(
'
featureFlag jiraIssuesIntegration is false
'
,
()
=>
{
it
(
'
does not render JiraIssuesFields
'
,
()
=>
{
it
(
'
does not render JiraIssuesFields
'
,
()
=>
{
createComponent
({
type
:
'
jira
'
},
{
jiraIssuesIntegration
:
false
});
createComponent
({
customStateProps
:
{
type
:
'
jira
'
},
featureFlags
:
{
jiraIssuesIntegration
:
false
},
});
expect
(
findJiraIssuesFields
().
exists
()).
toBe
(
false
);
expect
(
findJiraIssuesFields
().
exists
()).
toBe
(
false
);
});
});
...
@@ -187,8 +220,10 @@ describe('IntegrationForm', () => {
...
@@ -187,8 +220,10 @@ describe('IntegrationForm', () => {
describe
(
'
featureFlag jiraIssuesIntegration is true
'
,
()
=>
{
describe
(
'
featureFlag jiraIssuesIntegration is true
'
,
()
=>
{
it
(
'
renders JiraIssuesFields
'
,
()
=>
{
it
(
'
renders JiraIssuesFields
'
,
()
=>
{
createComponent
({
type
:
'
jira
'
},
{
jiraIssuesIntegration
:
true
});
createComponent
({
customStateProps
:
{
type
:
'
jira
'
},
featureFlags
:
{
jiraIssuesIntegration
:
true
},
});
expect
(
findJiraIssuesFields
().
exists
()).
toBe
(
true
);
expect
(
findJiraIssuesFields
().
exists
()).
toBe
(
true
);
});
});
});
});
...
@@ -200,8 +235,10 @@ describe('IntegrationForm', () => {
...
@@ -200,8 +235,10 @@ describe('IntegrationForm', () => {
const
type
=
'
slack
'
;
const
type
=
'
slack
'
;
createComponent
({
createComponent
({
triggerEvents
:
events
,
customStateProps
:
{
type
,
triggerEvents
:
events
,
type
,
},
});
});
expect
(
findTriggerFields
().
exists
()).
toBe
(
true
);
expect
(
findTriggerFields
().
exists
()).
toBe
(
true
);
...
@@ -218,7 +255,9 @@ describe('IntegrationForm', () => {
...
@@ -218,7 +255,9 @@ describe('IntegrationForm', () => {
];
];
createComponent
({
createComponent
({
fields
,
customStateProps
:
{
fields
,
},
});
});
const
dynamicFields
=
wrapper
.
findAll
(
DynamicField
);
const
dynamicFields
=
wrapper
.
findAll
(
DynamicField
);
...
@@ -232,13 +271,11 @@ describe('IntegrationForm', () => {
...
@@ -232,13 +271,11 @@ describe('IntegrationForm', () => {
describe
(
'
defaultState state is null
'
,
()
=>
{
describe
(
'
defaultState state is null
'
,
()
=>
{
it
(
'
does not render OverrideDropdown
'
,
()
=>
{
it
(
'
does not render OverrideDropdown
'
,
()
=>
{
createComponent
(
createComponent
({
{},
initialState
:
{
{},
{
defaultState
:
null
,
defaultState
:
null
,
},
},
);
}
);
expect
(
findOverrideDropdown
().
exists
()).
toBe
(
false
);
expect
(
findOverrideDropdown
().
exists
()).
toBe
(
false
);
});
});
...
@@ -246,18 +283,39 @@ describe('IntegrationForm', () => {
...
@@ -246,18 +283,39 @@ describe('IntegrationForm', () => {
describe
(
'
defaultState state is an object
'
,
()
=>
{
describe
(
'
defaultState state is an object
'
,
()
=>
{
it
(
'
renders OverrideDropdown
'
,
()
=>
{
it
(
'
renders OverrideDropdown
'
,
()
=>
{
createComponent
(
createComponent
({
{},
initialState
:
{
{},
{
defaultState
:
{
defaultState
:
{
...
mockIntegrationProps
,
...
mockIntegrationProps
,
},
},
},
},
);
}
);
expect
(
findOverrideDropdown
().
exists
()).
toBe
(
true
);
expect
(
findOverrideDropdown
().
exists
()).
toBe
(
true
);
});
});
});
});
describe
(
'
with `helpHtml` prop
'
,
()
=>
{
const
mockTestId
=
'
jest-helpHtml-test
'
;
const
mockHelpHtml
=
document
.
createElement
(
'
div
'
);
mockHelpHtml
.
setAttribute
(
'
data-testid
'
,
mockTestId
);
mockHelpHtml
.
appendChild
(
document
.
createElement
(
'
svg
'
));
const
mockHelpHtmlContainer
=
document
.
createElement
(
'
div
'
);
mockHelpHtmlContainer
.
appendChild
(
mockHelpHtml
);
it
(
'
renders `helpHtml`
'
,
async
()
=>
{
createComponent
({
props
:
{
helpHtml
:
mockHelpHtmlContainer
.
innerHTML
,
},
});
const
helpHtml
=
wrapper
.
findByTestId
(
mockTestId
);
expect
(
helpHtml
.
isVisible
()).
toBe
(
true
);
expect
(
helpHtml
.
find
(
'
svg
'
).
isVisible
()).
toBe
(
true
);
});
});
});
});
});
});
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