BigW Consortium Gitlab
Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
gitlab-ce
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Forest Godfrey
gitlab-ce
Commits
ab7b01aa
Commit
ab7b01aa
authored
Apr 24, 2018
by
Clement Ho
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'winh-mock-pager' into 'master'
Mock Pager in Karma tests See merge request gitlab-org/gitlab-ce!18556
parents
87cdd43b
92be3461
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
71 additions
and
51 deletions
+71
-51
activities_spec.js
spec/javascripts/activities_spec.js
+42
-33
commits_spec.js
spec/javascripts/commits_spec.js
+8
-4
pager_spec.js
spec/javascripts/pager_spec.js
+21
-14
No files found.
spec/javascripts/activities_spec.js
View file @
ab7b01aa
...
...
@@ -3,24 +3,30 @@
import
$
from
'jquery'
;
import
'vendor/jquery.endless-scroll'
;
import
Activities
from
'~/activities'
;
import
Pager
from
'~/pager'
;
(
()
=>
{
describe
(
'Activities'
,
()
=>
{
window
.
gon
||
(
window
.
gon
=
{});
const
fixtureTemplate
=
'static/event_filter.html.raw'
;
const
filters
=
[
{
id
:
'all'
,
},
{
},
{
id
:
'push'
,
name
:
'push events'
,
},
{
},
{
id
:
'merged'
,
name
:
'merge events'
,
},
{
},
{
id
:
'comments'
,
},
{
},
{
id
:
'team'
,
}];
},
];
function
getEventName
(
index
)
{
const
filter
=
filters
[
index
];
...
...
@@ -32,31 +38,34 @@ import Activities from '~/activities';
return
`#
${
filter
.
id
}
_event_filter`
;
}
describe
(
'Activities'
,
()
=>
{
beforeEach
(()
=>
{
loadFixtures
(
fixtureTemplate
);
new
Activities
();
});
for
(
let
i
=
0
;
i
<
filters
.
length
;
i
+=
1
)
{
((
i
)
=>
{
describe
(
`when selecting
${
getEventName
(
i
)}
`
,
()
=>
{
beforeEach
(()
=>
{
$
(
getSelector
(
i
)).
click
();
});
for
(
let
x
=
0
;
x
<
filters
.
length
;
x
+=
1
)
{
((
x
)
=>
{
const
shouldHighlight
=
i
===
x
;
const
testName
=
shouldHighlight
?
'should highlight'
:
'should not highlight'
;
it
(
`
${
testName
}
${
getEventName
(
x
)}
`
,
()
=>
{
expect
(
$
(
getSelector
(
x
)).
parent
().
hasClass
(
'active'
)).
toEqual
(
shouldHighlight
);
});
})(
x
);
}
});
})(
i
);
}
beforeEach
(()
=>
{
loadFixtures
(
fixtureTemplate
);
spyOn
(
Pager
,
'init'
).
and
.
stub
();
new
Activities
();
});
})();
for
(
let
i
=
0
;
i
<
filters
.
length
;
i
+=
1
)
{
(
i
=>
{
describe
(
`when selecting
${
getEventName
(
i
)}
`
,
()
=>
{
beforeEach
(()
=>
{
$
(
getSelector
(
i
)).
click
();
});
for
(
let
x
=
0
;
x
<
filters
.
length
;
x
+=
1
)
{
(
x
=>
{
const
shouldHighlight
=
i
===
x
;
const
testName
=
shouldHighlight
?
'should highlight'
:
'should not highlight'
;
it
(
`
${
testName
}
${
getEventName
(
x
)}
`
,
()
=>
{
expect
(
$
(
getSelector
(
x
))
.
parent
()
.
hasClass
(
'active'
),
).
toEqual
(
shouldHighlight
);
});
})(
x
);
}
});
})(
i
);
}
});
spec/javascripts/commits_spec.js
View file @
ab7b01aa
...
...
@@ -3,6 +3,7 @@ import 'vendor/jquery.endless-scroll';
import
MockAdapter
from
'axios-mock-adapter'
;
import
axios
from
'~/lib/utils/axios_utils'
;
import
CommitsList
from
'~/commits'
;
import
Pager
from
'~/pager'
;
describe
(
'Commits List'
,
()
=>
{
let
commitsList
;
...
...
@@ -14,6 +15,7 @@ describe('Commits List', () => {
</form>
<ol id="commits-list"></ol>
`
);
spyOn
(
Pager
,
'init'
).
and
.
stub
();
commitsList
=
new
CommitsList
(
25
);
});
...
...
@@ -68,9 +70,10 @@ describe('Commits List', () => {
mock
.
restore
();
});
it
(
'should save the last search string'
,
(
done
)
=>
{
it
(
'should save the last search string'
,
done
=>
{
commitsList
.
searchField
.
val
(
'GitLab'
);
commitsList
.
filterResults
()
commitsList
.
filterResults
()
.
then
(()
=>
{
expect
(
ajaxSpy
).
toHaveBeenCalled
();
expect
(
commitsList
.
lastSearch
).
toEqual
(
'GitLab'
);
...
...
@@ -80,8 +83,9 @@ describe('Commits List', () => {
.
catch
(
done
.
fail
);
});
it
(
'should not make ajax call if the input does not change'
,
(
done
)
=>
{
commitsList
.
filterResults
()
it
(
'should not make ajax call if the input does not change'
,
done
=>
{
commitsList
.
filterResults
()
.
then
(()
=>
{
expect
(
ajaxSpy
).
not
.
toHaveBeenCalled
();
expect
(
commitsList
.
lastSearch
).
toEqual
(
''
);
...
...
spec/javascripts/pager_spec.js
View file @
ab7b01aa
import
$
from
'jquery'
;
import
MockAdapter
from
'axios-mock-adapter'
;
import
axios
from
'~/lib/utils/axios_utils'
;
import
Pager
from
'~/pager'
;
describe
(
'pager'
,
()
=>
{
let
axiosMock
;
beforeEach
(()
=>
{
axiosMock
=
new
MockAdapter
(
axios
);
});
afterEach
(()
=>
{
axiosMock
.
restore
();
});
describe
(
'init'
,
()
=>
{
const
originalHref
=
window
.
location
.
href
;
beforeEach
(()
=>
{
setFixtures
(
'<div class="content_list"></div><div class="loading"></div>'
);
spyOn
(
$
.
fn
,
'endlessScroll'
).
and
.
stub
();
});
afterEach
(()
=>
{
...
...
@@ -46,33 +58,28 @@ describe('pager', () => {
describe
(
'getOld'
,
()
=>
{
const
urlRegex
=
/
(
.*
)
some_list
(
.*
)
$/
;
let
mock
;
function
mockSuccess
()
{
m
ock
.
onGet
(
urlRegex
).
reply
(
200
,
{
axiosM
ock
.
onGet
(
urlRegex
).
reply
(
200
,
{
count
:
0
,
html
:
''
,
});
}
function
mockError
()
{
m
ock
.
onGet
(
urlRegex
).
networkError
();
axiosM
ock
.
onGet
(
urlRegex
).
networkError
();
}
beforeEach
(()
=>
{
setFixtures
(
'<div class="content_list" data-href="/some_list"></div><div class="loading"></div>'
);
setFixtures
(
'<div class="content_list" data-href="/some_list"></div><div class="loading"></div>'
,
);
spyOn
(
axios
,
'get'
).
and
.
callThrough
();
mock
=
new
MockAdapter
(
axios
);
Pager
.
init
();
});
afterEach
(()
=>
{
mock
.
restore
();
});
it
(
'shows loader while loading next page'
,
(
done
)
=>
{
it
(
'shows loader while loading next page'
,
done
=>
{
mockSuccess
();
spyOn
(
Pager
.
loading
,
'show'
);
...
...
@@ -85,7 +92,7 @@ describe('pager', () => {
});
});
it
(
'hides loader on success'
,
(
done
)
=>
{
it
(
'hides loader on success'
,
done
=>
{
mockSuccess
();
spyOn
(
Pager
.
loading
,
'hide'
);
...
...
@@ -98,7 +105,7 @@ describe('pager', () => {
});
});
it
(
'hides loader on error'
,
(
done
)
=>
{
it
(
'hides loader on error'
,
done
=>
{
mockError
();
spyOn
(
Pager
.
loading
,
'hide'
);
...
...
@@ -111,7 +118,7 @@ describe('pager', () => {
});
});
it
(
'sends request to url with offset and limit params'
,
(
done
)
=>
{
it
(
'sends request to url with offset and limit params'
,
done
=>
{
Pager
.
offset
=
100
;
Pager
.
limit
=
20
;
Pager
.
getOld
();
...
...
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