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
09375740
Commit
09375740
authored
Jun 09, 2020
by
Himanshu Kapoor
Committed by
Kushal Pandya
Jun 09, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Migrate ee/operations to Jest
Closes
https://gitlab.com/gitlab-org/gitlab/-/issues/194299
parent
5a589a07
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
46 additions
and
62 deletions
+46
-62
ee/spec/frontend/operations/components/dashboard/dashboard_spec.js
...rontend/operations/components/dashboard/dashboard_spec.js
+45
-55
ee/spec/frontend/operations/components/dashboard/project_spec.js
.../frontend/operations/components/dashboard/project_spec.js
+1
-2
ee/spec/frontend/operations/helpers.js
ee/spec/frontend/operations/helpers.js
+0
-0
ee/spec/javascripts/operations/mock_data.js
ee/spec/javascripts/operations/mock_data.js
+0
-5
No files found.
ee/spec/
javascripts
/operations/components/dashboard/dashboard_spec.js
→
ee/spec/
frontend
/operations/components/dashboard/dashboard_spec.js
View file @
09375740
...
...
@@ -4,8 +4,8 @@ import Vuex from 'vuex';
import
Project
from
'
ee/operations/components/dashboard/project.vue
'
;
import
Dashboard
from
'
ee/operations/components/dashboard/dashboard.vue
'
;
import
createStore
from
'
ee/vue_shared/dashboards/store
'
;
import
timeoutPromise
from
'
spec/helpers/set_timeout_promise_helper
'
;
import
{
trimText
}
from
'
spec/
helpers/text_helper
'
;
import
waitForPromises
from
'
helpers/wait_for_promises
'
;
import
{
trimText
}
from
'
helpers/text_helper
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
{
mockProjectData
,
mockText
}
from
'
../../mock_data
'
;
...
...
@@ -15,13 +15,12 @@ localVue.use(Vuex);
describe
(
'
dashboard component
'
,
()
=>
{
const
mockAddEndpoint
=
'
mock-addPath
'
;
const
mockListEndpoint
=
'
mock-listPath
'
;
const
DashboardComponent
=
localVue
.
extend
(
Dashboard
);
const
store
=
createStore
();
let
wrapper
;
let
mockAxios
;
const
mountComponent
=
()
=>
mount
(
Dashboard
Component
,
{
mount
(
Dashboard
,
{
store
,
localVue
,
propsData
:
{
...
...
@@ -67,26 +66,25 @@ describe('dashboard component', () => {
});
describe
(
'
when a project is added
'
,
()
=>
{
it
(
'
immediately requests the project list again
'
,
done
=>
{
it
(
'
immediately requests the project list again
'
,
()
=>
{
mockAxios
.
reset
();
mockAxios
.
onGet
(
mockListEndpoint
).
replyOnce
(
200
,
{
projects
:
mockProjectData
(
2
)
});
mockAxios
.
onPost
(
mockAddEndpoint
).
replyOnce
(
200
,
{
added
:
[
1
],
invalid
:
[]
});
wrapper
.
vm
return
wrapper
.
vm
.
$nextTick
()
.
then
(()
=>
{
wrapper
.
vm
.
projectClicked
({
id
:
1
});
})
.
then
(
timeoutPromise
)
.
then
(
waitForPromises
)
.
then
(()
=>
{
wrapper
.
vm
.
onOk
();
})
.
then
(
timeoutPromise
)
.
then
(
waitForPromises
)
.
then
(()
=>
{
expect
(
store
.
state
.
projects
.
length
).
toEqual
(
2
);
expect
(
wrapper
.
findAll
(
Project
).
length
).
toEqual
(
2
);
done
();
})
.
catch
(
done
.
fail
);
});
});
});
});
...
...
@@ -104,7 +102,7 @@ describe('dashboard component', () => {
it
(
'
includes a dashboard project component for each project
'
,
()
=>
{
const
projectComponents
=
wrapper
.
findAll
(
Project
);
expect
(
projectComponents
.
length
).
toBe
(
projectCount
);
expect
(
projectComponents
).
toHaveLength
(
projectCount
);
});
it
(
'
passes each project to the dashboard project component
'
,
()
=>
{
...
...
@@ -115,7 +113,7 @@ describe('dashboard component', () => {
});
it
(
'
dispatches setProjects when projects changes
'
,
()
=>
{
const
dispatch
=
spyOn
(
wrapper
.
vm
.
$store
,
'
dispatch
'
);
const
dispatch
=
jest
.
spyOn
(
wrapper
.
vm
.
$store
,
'
dispatch
'
).
mockImplementation
(()
=>
{}
);
const
projects
=
mockProjectData
(
3
);
wrapper
.
vm
.
projects
=
projects
;
...
...
@@ -124,20 +122,17 @@ describe('dashboard component', () => {
});
describe
(
'
when a project is removed
'
,
()
=>
{
it
(
'
immediately requests the project list again
'
,
done
=>
{
it
(
'
immediately requests the project list again
'
,
()
=>
{
mockAxios
.
reset
();
mockAxios
.
onDelete
(
store
.
state
.
projects
[
0
].
remove_path
).
reply
(
200
);
mockAxios
.
onGet
(
mockListEndpoint
).
replyOnce
(
200
,
{
projects
:
[]
});
wrapper
.
find
(
'
button.js-remove-button
'
).
vm
.
$emit
(
'
click
'
);
timeoutPromise
()
.
then
(()
=>
{
return
waitForPromises
().
then
(()
=>
{
expect
(
store
.
state
.
projects
.
length
).
toEqual
(
0
);
expect
(
wrapper
.
findAll
(
Project
).
length
).
toEqual
(
0
);
done
();
})
.
catch
(
done
.
fail
);
});
});
});
});
...
...
@@ -148,69 +143,64 @@ describe('dashboard component', () => {
store
.
state
.
selectedProjects
=
mockProjectData
(
1
);
});
it
(
'
clears state when adding a valid project
'
,
done
=>
{
it
(
'
clears state when adding a valid project
'
,
()
=>
{
mockAxios
.
onPost
(
mockAddEndpoint
).
replyOnce
(
200
,
{
added
:
[
1
],
invalid
:
[]
});
wrapper
.
vm
return
wrapper
.
vm
.
$nextTick
()
.
then
(()
=>
{
wrapper
.
vm
.
onOk
();
})
.
then
(
timeoutPromise
)
.
then
(
waitForPromises
)
.
then
(()
=>
{
expect
(
store
.
state
.
projectSearchResults
.
length
).
toEqual
(
0
);
expect
(
store
.
state
.
selectedProjects
.
length
).
toEqual
(
0
);
done
();
})
.
catch
(
done
.
fail
);
expect
(
store
.
state
.
projectSearchResults
).
toHaveLength
(
0
);
expect
(
store
.
state
.
selectedProjects
).
toHaveLength
(
0
);
});
});
it
(
'
clears state when adding an invalid project
'
,
done
=>
{
it
(
'
clears state when adding an invalid project
'
,
()
=>
{
mockAxios
.
onPost
(
mockAddEndpoint
).
replyOnce
(
200
,
{
added
:
[],
invalid
:
[
1
]
});
wrapper
.
vm
return
wrapper
.
vm
.
$nextTick
()
.
then
(()
=>
{
wrapper
.
vm
.
onOk
();
})
.
then
(
timeoutPromise
)
.
then
(
waitForPromises
)
.
then
(()
=>
{
expect
(
store
.
state
.
projectSearchResults
.
length
).
toEqual
(
0
);
expect
(
store
.
state
.
selectedProjects
.
length
).
toEqual
(
0
);
done
();
})
.
catch
(
done
.
fail
);
expect
(
store
.
state
.
projectSearchResults
).
toHaveLength
(
0
);
expect
(
store
.
state
.
selectedProjects
).
toHaveLength
(
0
);
});
});
it
(
'
clears state when canceled
'
,
done
=>
{
wrapper
.
vm
it
(
'
clears state when canceled
'
,
()
=>
{
return
wrapper
.
vm
.
$nextTick
()
.
then
(()
=>
{
wrapper
.
vm
.
onCancel
();
})
.
then
(
timeoutPromise
)
.
then
(
waitForPromises
)
.
then
(()
=>
{
expect
(
store
.
state
.
projectSearchResults
.
length
).
toEqual
(
0
);
expect
(
store
.
state
.
selectedProjects
.
length
).
toEqual
(
0
);
done
();
})
.
catch
(
done
.
fail
);
expect
(
store
.
state
.
projectSearchResults
).
toHaveLength
(
0
);
expect
(
store
.
state
.
selectedProjects
).
toHaveLength
(
0
);
});
});
it
(
'
clears state on error
'
,
done
=>
{
it
(
'
clears state on error
'
,
()
=>
{
mockAxios
.
onPost
(
mockAddEndpoint
).
replyOnce
(
500
,
{});
wrapper
.
vm
return
wrapper
.
vm
.
$nextTick
()
.
then
(()
=>
{
expect
(
store
.
state
.
projectSearchResults
.
length
).
not
.
to
Equal
(
0
);
expect
(
store
.
state
.
selectedProjects
.
length
).
not
.
to
Equal
(
0
);
expect
(
store
.
state
.
projectSearchResults
.
length
).
not
.
to
Be
(
0
);
expect
(
store
.
state
.
selectedProjects
.
length
).
not
.
to
Be
(
0
);
wrapper
.
vm
.
onOk
();
})
.
then
(
timeoutPromise
)
.
then
(
waitForPromises
)
.
then
(()
=>
{
expect
(
store
.
state
.
projectSearchResults
.
length
).
toEqual
(
0
);
expect
(
store
.
state
.
selectedProjects
.
length
).
toEqual
(
0
);
done
();
})
.
catch
(
done
.
fail
);
expect
(
store
.
state
.
projectSearchResults
).
toHaveLength
(
0
);
expect
(
store
.
state
.
selectedProjects
).
toHaveLength
(
0
);
});
});
});
...
...
ee/spec/
javascripts
/operations/components/dashboard/project_spec.js
→
ee/spec/
frontend
/operations/components/dashboard/project_spec.js
View file @
09375740
...
...
@@ -11,11 +11,10 @@ const localVue = createLocalVue();
localVue
.
use
(
Vuex
);
describe
(
'
project component
'
,
()
=>
{
const
ProjectComponent
=
localVue
.
extend
(
Project
);
let
wrapper
;
const
createComponent
=
(
props
=
{})
=>
{
wrapper
=
shallowMount
(
Project
Component
,
{
wrapper
=
shallowMount
(
Project
,
{
store
,
localVue
,
propsData
:
{
...
...
ee/spec/
javascripts
/operations/helpers.js
→
ee/spec/
frontend
/operations/helpers.js
View file @
09375740
File moved
ee/spec/javascripts/operations/mock_data.js
deleted
100644 → 0
View file @
5a589a07
// No new code should be added to this file. Instead, modify the
// file this one re-exports from. For more detail about why, see:
// https://gitlab.com/gitlab-org/gitlab-foss/merge_requests/31349
export
*
from
'
../../frontend/operations/mock_data
'
;
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