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
40dd3938
Commit
40dd3938
authored
Nov 18, 2019
by
Utkarsh Gupta
Committed by
Phil Hughes
Nov 18, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove var from search_autocomplete_spec.js
parent
d4f9535a
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
25 additions
and
43 deletions
+25
-43
spec/javascripts/search_autocomplete_spec.js
spec/javascripts/search_autocomplete_spec.js
+25
-43
No files found.
spec/javascripts/search_autocomplete_spec.js
View file @
40dd3938
/* eslint-disable no-
var, one-var, no-unused-expressions, consistent-return, no-param-reassign, default-case, no-return-assign, vars-on-top
*/
/* eslint-disable no-
unused-expressions, consistent-return, no-param-reassign, default-case, no-return-assign
*/
import
$
from
'
jquery
'
;
import
$
from
'
jquery
'
;
import
'
~/gl_dropdown
'
;
import
'
~/gl_dropdown
'
;
...
@@ -6,41 +6,27 @@ import initSearchAutocomplete from '~/search_autocomplete';
...
@@ -6,41 +6,27 @@ import initSearchAutocomplete from '~/search_autocomplete';
import
'
~/lib/utils/common_utils
'
;
import
'
~/lib/utils/common_utils
'
;
describe
(
'
Search autocomplete dropdown
'
,
()
=>
{
describe
(
'
Search autocomplete dropdown
'
,
()
=>
{
var
assertLinks
,
let
widget
=
null
;
dashboardIssuesPath
,
dashboardMRsPath
,
groupIssuesPath
,
groupMRsPath
,
groupName
,
mockDashboardOptions
,
mockGroupOptions
,
mockProjectOptions
,
projectIssuesPath
,
projectMRsPath
,
projectName
,
userId
,
widget
;
var
userName
=
'
root
'
;
widget
=
null
;
const
userName
=
'
root
'
;
userId
=
1
;
const
userId
=
1
;
dashboardIssuesPath
=
'
/dashboard/issues
'
;
const
dashboardIssuesPath
=
'
/dashboard/issues
'
;
dashboardMRsPath
=
'
/dashboard/merge_requests
'
;
const
dashboardMRsPath
=
'
/dashboard/merge_requests
'
;
projectIssuesPath
=
'
/gitlab-org/gitlab-foss/issues
'
;
const
projectIssuesPath
=
'
/gitlab-org/gitlab-foss/issues
'
;
projectMRsPath
=
'
/gitlab-org/gitlab-foss/merge_requests
'
;
const
projectMRsPath
=
'
/gitlab-org/gitlab-foss/merge_requests
'
;
groupIssuesPath
=
'
/groups/gitlab-org/issues
'
;
const
groupIssuesPath
=
'
/groups/gitlab-org/issues
'
;
groupMRsPath
=
'
/groups/gitlab-org/merge_requests
'
;
const
groupMRsPath
=
'
/groups/gitlab-org/merge_requests
'
;
projectName
=
'
GitLab Community Edition
'
;
const
projectName
=
'
GitLab Community Edition
'
;
groupName
=
'
Gitlab Org
'
;
const
groupName
=
'
Gitlab Org
'
;
const
removeBodyAttributes
=
function
()
{
const
removeBodyAttributes
=
function
()
{
const
$body
=
$
(
'
body
'
);
const
$body
=
$
(
'
body
'
);
...
@@ -76,7 +62,7 @@ describe('Search autocomplete dropdown', () => {
...
@@ -76,7 +62,7 @@ describe('Search autocomplete dropdown', () => {
};
};
// Mock `gl` object in window for dashboard specific page. App code will need it.
// Mock `gl` object in window for dashboard specific page. App code will need it.
mockDashboardOptions
=
function
()
{
const
mockDashboardOptions
=
function
()
{
window
.
gl
||
(
window
.
gl
=
{});
window
.
gl
||
(
window
.
gl
=
{});
return
(
window
.
gl
.
dashboardOptions
=
{
return
(
window
.
gl
.
dashboardOptions
=
{
issuesPath
:
dashboardIssuesPath
,
issuesPath
:
dashboardIssuesPath
,
...
@@ -85,7 +71,7 @@ describe('Search autocomplete dropdown', () => {
...
@@ -85,7 +71,7 @@ describe('Search autocomplete dropdown', () => {
};
};
// Mock `gl` object in window for project specific page. App code will need it.
// Mock `gl` object in window for project specific page. App code will need it.
mockProjectOptions
=
function
()
{
const
mockProjectOptions
=
function
()
{
window
.
gl
||
(
window
.
gl
=
{});
window
.
gl
||
(
window
.
gl
=
{});
return
(
window
.
gl
.
projectOptions
=
{
return
(
window
.
gl
.
projectOptions
=
{
'
gitlab-ce
'
:
{
'
gitlab-ce
'
:
{
...
@@ -96,7 +82,7 @@ describe('Search autocomplete dropdown', () => {
...
@@ -96,7 +82,7 @@ describe('Search autocomplete dropdown', () => {
});
});
};
};
mockGroupOptions
=
function
()
{
const
mockGroupOptions
=
function
()
{
window
.
gl
||
(
window
.
gl
=
{});
window
.
gl
||
(
window
.
gl
=
{});
return
(
window
.
gl
.
groupOptions
=
{
return
(
window
.
gl
.
groupOptions
=
{
'
gitlab-org
'
:
{
'
gitlab-org
'
:
{
...
@@ -107,7 +93,7 @@ describe('Search autocomplete dropdown', () => {
...
@@ -107,7 +93,7 @@ describe('Search autocomplete dropdown', () => {
});
});
};
};
assertLinks
=
function
(
list
,
issuesPath
,
mrsPath
)
{
const
assertLinks
=
function
(
list
,
issuesPath
,
mrsPath
)
{
if
(
issuesPath
)
{
if
(
issuesPath
)
{
const
issuesAssignedToMeLink
=
`a[href="
${
issuesPath
}
/?assignee_username=
${
userName
}
"]`
;
const
issuesAssignedToMeLink
=
`a[href="
${
issuesPath
}
/?assignee_username=
${
userName
}
"]`
;
const
issuesIHaveCreatedLink
=
`a[href="
${
issuesPath
}
/?author_username=
${
userName
}
"]`
;
const
issuesIHaveCreatedLink
=
`a[href="
${
issuesPath
}
/?author_username=
${
userName
}
"]`
;
...
@@ -144,29 +130,26 @@ describe('Search autocomplete dropdown', () => {
...
@@ -144,29 +130,26 @@ describe('Search autocomplete dropdown', () => {
});
});
it
(
'
should show Dashboard specific dropdown menu
'
,
function
()
{
it
(
'
should show Dashboard specific dropdown menu
'
,
function
()
{
var
list
;
addBodyAttributes
();
addBodyAttributes
();
mockDashboardOptions
();
mockDashboardOptions
();
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
list
=
widget
.
wrap
.
find
(
'
.dropdown-menu
'
).
find
(
'
ul
'
);
const
list
=
widget
.
wrap
.
find
(
'
.dropdown-menu
'
).
find
(
'
ul
'
);
return
assertLinks
(
list
,
dashboardIssuesPath
,
dashboardMRsPath
);
return
assertLinks
(
list
,
dashboardIssuesPath
,
dashboardMRsPath
);
});
});
it
(
'
should show Group specific dropdown menu
'
,
function
()
{
it
(
'
should show Group specific dropdown menu
'
,
function
()
{
var
list
;
addBodyAttributes
(
'
group
'
);
addBodyAttributes
(
'
group
'
);
mockGroupOptions
();
mockGroupOptions
();
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
list
=
widget
.
wrap
.
find
(
'
.dropdown-menu
'
).
find
(
'
ul
'
);
const
list
=
widget
.
wrap
.
find
(
'
.dropdown-menu
'
).
find
(
'
ul
'
);
return
assertLinks
(
list
,
groupIssuesPath
,
groupMRsPath
);
return
assertLinks
(
list
,
groupIssuesPath
,
groupMRsPath
);
});
});
it
(
'
should show Project specific dropdown menu
'
,
function
()
{
it
(
'
should show Project specific dropdown menu
'
,
function
()
{
var
list
;
addBodyAttributes
(
'
project
'
);
addBodyAttributes
(
'
project
'
);
mockProjectOptions
();
mockProjectOptions
();
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
list
=
widget
.
wrap
.
find
(
'
.dropdown-menu
'
).
find
(
'
ul
'
);
const
list
=
widget
.
wrap
.
find
(
'
.dropdown-menu
'
).
find
(
'
ul
'
);
return
assertLinks
(
list
,
projectIssuesPath
,
projectMRsPath
);
return
assertLinks
(
list
,
projectIssuesPath
,
projectMRsPath
);
});
});
...
@@ -180,26 +163,25 @@ describe('Search autocomplete dropdown', () => {
...
@@ -180,26 +163,25 @@ describe('Search autocomplete dropdown', () => {
});
});
it
(
'
should not show category related menu if there is text in the input
'
,
function
()
{
it
(
'
should not show category related menu if there is text in the input
'
,
function
()
{
var
link
,
list
;
addBodyAttributes
(
'
project
'
);
addBodyAttributes
(
'
project
'
);
mockProjectOptions
();
mockProjectOptions
();
widget
.
searchInput
.
val
(
'
help
'
);
widget
.
searchInput
.
val
(
'
help
'
);
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
list
=
widget
.
wrap
.
find
(
'
.dropdown-menu
'
).
find
(
'
ul
'
);
const
list
=
widget
.
wrap
.
find
(
'
.dropdown-menu
'
).
find
(
'
ul
'
);
link
=
`a[href='
${
projectIssuesPath
}
/?assignee_username=
${
userName
}
']`
;
const
link
=
`a[href='
${
projectIssuesPath
}
/?assignee_username=
${
userName
}
']`
;
expect
(
list
.
find
(
link
).
length
).
toBe
(
0
);
expect
(
list
.
find
(
link
).
length
).
toBe
(
0
);
});
});
it
(
'
should not submit the search form when selecting an autocomplete row with the keyboard
'
,
function
()
{
it
(
'
should not submit the search form when selecting an autocomplete row with the keyboard
'
,
function
()
{
var
ENTER
=
13
;
const
ENTER
=
13
;
var
DOWN
=
40
;
const
DOWN
=
40
;
addBodyAttributes
();
addBodyAttributes
();
mockDashboardOptions
(
true
);
mockDashboardOptions
(
true
);
var
submitSpy
=
spyOnEvent
(
'
form
'
,
'
submit
'
);
const
submitSpy
=
spyOnEvent
(
'
form
'
,
'
submit
'
);
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
widget
.
searchInput
.
triggerHandler
(
'
focus
'
);
widget
.
wrap
.
trigger
(
$
.
Event
(
'
keydown
'
,
{
which
:
DOWN
}));
widget
.
wrap
.
trigger
(
$
.
Event
(
'
keydown
'
,
{
which
:
DOWN
}));
var
enterKeyEvent
=
$
.
Event
(
'
keydown
'
,
{
which
:
ENTER
});
const
enterKeyEvent
=
$
.
Event
(
'
keydown
'
,
{
which
:
ENTER
});
widget
.
searchInput
.
trigger
(
enterKeyEvent
);
widget
.
searchInput
.
trigger
(
enterKeyEvent
);
// This does not currently catch failing behavior. For security reasons,
// This does not currently catch failing behavior. For security reasons,
// browsers will not trigger default behavior (form submit, in this
// browsers will not trigger default behavior (form submit, in this
...
...
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