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
7f2e3d90
Commit
7f2e3d90
authored
Sep 07, 2020
by
Natalia Tepluhina
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Created a factory to mock Apollo Client
parent
9063dea6
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
121 additions
and
142 deletions
+121
-142
spec/frontend/design_management/pages/index_apollo_spec.js
spec/frontend/design_management/pages/index_apollo_spec.js
+0
-141
spec/frontend/design_management/pages/index_spec.js
spec/frontend/design_management/pages/index_spec.js
+121
-1
No files found.
spec/frontend/design_management/pages/index_apollo_spec.js
deleted
100644 → 0
View file @
9063dea6
import
{
shallowMount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
VueApollo
from
'
vue-apollo
'
;
import
VueRouter
from
'
vue-router
'
;
import
VueDraggable
from
'
vuedraggable
'
;
import
Design
from
'
~/design_management/components/list/item.vue
'
;
import
createRouter
from
'
~/design_management/router
'
;
import
getDesignListQuery
from
'
~/design_management/graphql/queries/get_design_list.query.graphql
'
;
import
permissionsQuery
from
'
~/design_management/graphql/queries/design_permissions.query.graphql
'
;
import
moveDesignMutation
from
'
~/design_management/graphql/mutations/move_design.mutation.graphql
'
;
import
{
deprecatedCreateFlash
as
createFlash
}
from
'
~/flash
'
;
import
createMockApollo
from
'
../../helpers/mock_apollo_helper
'
;
import
Index
from
'
~/design_management/pages/index.vue
'
;
import
{
designListQueryResponse
,
permissionsQueryResponse
,
moveDesignMutationResponse
,
reorderedDesigns
,
moveDesignMutationResponseWithErrors
,
}
from
'
../mock_data/apollo_mock
'
;
jest
.
mock
(
'
~/flash
'
);
const
localVue
=
createLocalVue
();
localVue
.
use
(
VueApollo
);
const
router
=
createRouter
();
localVue
.
use
(
VueRouter
);
const
designToMove
=
{
__typename
:
'
Design
'
,
id
:
'
2
'
,
event
:
'
NONE
'
,
filename
:
'
fox_2.jpg
'
,
notesCount
:
2
,
image
:
'
image-2
'
,
imageV432x230
:
'
image-2
'
,
};
describe
(
'
Design management index page with Apollo mock
'
,
()
=>
{
let
wrapper
;
let
fakeApollo
;
let
moveDesignHandler
;
async
function
moveDesigns
(
localWrapper
)
{
await
jest
.
runOnlyPendingTimers
();
await
localWrapper
.
vm
.
$nextTick
();
localWrapper
.
find
(
VueDraggable
).
vm
.
$emit
(
'
input
'
,
reorderedDesigns
);
localWrapper
.
find
(
VueDraggable
).
vm
.
$emit
(
'
change
'
,
{
moved
:
{
newIndex
:
0
,
element
:
designToMove
,
},
});
}
const
findDesigns
=
()
=>
wrapper
.
findAll
(
Design
);
function
createComponent
({
moveHandler
=
jest
.
fn
().
mockResolvedValue
(
moveDesignMutationResponse
),
})
{
moveDesignHandler
=
moveHandler
;
const
requestHandlers
=
[
[
getDesignListQuery
,
jest
.
fn
().
mockResolvedValue
(
designListQueryResponse
)],
[
permissionsQuery
,
jest
.
fn
().
mockResolvedValue
(
permissionsQueryResponse
)],
[
moveDesignMutation
,
moveDesignHandler
],
];
fakeApollo
=
createMockApollo
(
requestHandlers
);
wrapper
=
shallowMount
(
Index
,
{
localVue
,
apolloProvider
:
fakeApollo
,
router
,
stubs
:
{
VueDraggable
},
});
}
afterEach
(()
=>
{
wrapper
.
destroy
();
wrapper
=
null
;
});
it
(
'
has a design with id 1 as a first one
'
,
async
()
=>
{
createComponent
({});
await
jest
.
runOnlyPendingTimers
();
await
wrapper
.
vm
.
$nextTick
();
expect
(
findDesigns
()).
toHaveLength
(
3
);
expect
(
findDesigns
()
.
at
(
0
)
.
props
(
'
id
'
),
).
toBe
(
'
1
'
);
});
it
(
'
calls a mutation with correct parameters and reorders designs
'
,
async
()
=>
{
createComponent
({});
await
moveDesigns
(
wrapper
);
expect
(
moveDesignHandler
).
toHaveBeenCalled
();
await
wrapper
.
vm
.
$nextTick
();
expect
(
findDesigns
()
.
at
(
0
)
.
props
(
'
id
'
),
).
toBe
(
'
2
'
);
});
it
(
'
displays flash if mutation had a recoverable error
'
,
async
()
=>
{
createComponent
({
moveHandler
:
jest
.
fn
().
mockResolvedValue
(
moveDesignMutationResponseWithErrors
),
});
await
moveDesigns
(
wrapper
);
await
wrapper
.
vm
.
$nextTick
();
expect
(
createFlash
).
toHaveBeenCalledWith
(
'
Houston, we have a problem
'
);
});
it
(
'
displays flash if mutation had a non-recoverable error
'
,
async
()
=>
{
createComponent
({
moveHandler
:
jest
.
fn
().
mockRejectedValue
(
'
Error
'
),
});
await
moveDesigns
(
wrapper
);
await
wrapper
.
vm
.
$nextTick
();
// kick off the DOM update
await
jest
.
runOnlyPendingTimers
();
// kick off the mocked GQL stuff (promises)
await
wrapper
.
vm
.
$nextTick
();
// kick off the DOM update for flash
expect
(
createFlash
).
toHaveBeenCalledWith
(
'
Something went wrong when reordering designs. Please try again
'
,
);
});
});
spec/frontend/design_management/pages/index_spec.js
View file @
7f2e3d90
import
{
createLocalVue
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
createLocalVue
,
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
ApolloMutation
}
from
'
vue-apollo
'
;
import
VueApollo
,
{
ApolloMutation
}
from
'
vue-apollo
'
;
import
VueDraggable
from
'
vuedraggable
'
;
import
VueDraggable
from
'
vuedraggable
'
;
import
VueRouter
from
'
vue-router
'
;
import
VueRouter
from
'
vue-router
'
;
import
{
GlEmptyState
}
from
'
@gitlab/ui
'
;
import
{
GlEmptyState
}
from
'
@gitlab/ui
'
;
import
createMockApollo
from
'
jest/helpers/mock_apollo_helper
'
;
import
Index
from
'
~/design_management/pages/index.vue
'
;
import
Index
from
'
~/design_management/pages/index.vue
'
;
import
uploadDesignQuery
from
'
~/design_management/graphql/mutations/upload_design.mutation.graphql
'
;
import
uploadDesignQuery
from
'
~/design_management/graphql/mutations/upload_design.mutation.graphql
'
;
import
DesignDestroyer
from
'
~/design_management/components/design_destroyer.vue
'
;
import
DesignDestroyer
from
'
~/design_management/components/design_destroyer.vue
'
;
import
DesignDropzone
from
'
~/design_management/components/upload/design_dropzone.vue
'
;
import
DesignDropzone
from
'
~/design_management/components/upload/design_dropzone.vue
'
;
import
DeleteButton
from
'
~/design_management/components/delete_button.vue
'
;
import
DeleteButton
from
'
~/design_management/components/delete_button.vue
'
;
import
Design
from
'
~/design_management/components/list/item.vue
'
;
import
{
DESIGNS_ROUTE_NAME
}
from
'
~/design_management/router/constants
'
;
import
{
DESIGNS_ROUTE_NAME
}
from
'
~/design_management/router/constants
'
;
import
{
import
{
EXISTING_DESIGN_DROP_MANY_FILES_MESSAGE
,
EXISTING_DESIGN_DROP_MANY_FILES_MESSAGE
,
...
@@ -17,6 +19,16 @@ import { deprecatedCreateFlash as createFlash } from '~/flash';
...
@@ -17,6 +19,16 @@ import { deprecatedCreateFlash as createFlash } from '~/flash';
import
createRouter
from
'
~/design_management/router
'
;
import
createRouter
from
'
~/design_management/router
'
;
import
*
as
utils
from
'
~/design_management/utils/design_management_utils
'
;
import
*
as
utils
from
'
~/design_management/utils/design_management_utils
'
;
import
{
DESIGN_DETAIL_LAYOUT_CLASSLIST
}
from
'
~/design_management/constants
'
;
import
{
DESIGN_DETAIL_LAYOUT_CLASSLIST
}
from
'
~/design_management/constants
'
;
import
{
designListQueryResponse
,
permissionsQueryResponse
,
moveDesignMutationResponse
,
reorderedDesigns
,
moveDesignMutationResponseWithErrors
,
}
from
'
../mock_data/apollo_mock
'
;
import
getDesignListQuery
from
'
~/design_management/graphql/queries/get_design_list.query.graphql
'
;
import
permissionsQuery
from
'
~/design_management/graphql/queries/design_permissions.query.graphql
'
;
import
moveDesignMutation
from
'
~/design_management/graphql/mutations/move_design.mutation.graphql
'
;
jest
.
mock
(
'
~/flash.js
'
);
jest
.
mock
(
'
~/flash.js
'
);
const
mockPageEl
=
{
const
mockPageEl
=
{
...
@@ -61,9 +73,21 @@ const mockVersion = {
...
@@ -61,9 +73,21 @@ const mockVersion = {
id
:
'
gid://gitlab/DesignManagement::Version/1
'
,
id
:
'
gid://gitlab/DesignManagement::Version/1
'
,
};
};
const
designToMove
=
{
__typename
:
'
Design
'
,
id
:
'
2
'
,
event
:
'
NONE
'
,
filename
:
'
fox_2.jpg
'
,
notesCount
:
2
,
image
:
'
image-2
'
,
imageV432x230
:
'
image-2
'
,
};
describe
(
'
Design management index page
'
,
()
=>
{
describe
(
'
Design management index page
'
,
()
=>
{
let
mutate
;
let
mutate
;
let
wrapper
;
let
wrapper
;
let
fakeApollo
;
let
moveDesignHandler
;
const
findDesignCheckboxes
=
()
=>
wrapper
.
findAll
(
'
.design-checkbox
'
);
const
findDesignCheckboxes
=
()
=>
wrapper
.
findAll
(
'
.design-checkbox
'
);
const
findSelectAllButton
=
()
=>
wrapper
.
find
(
'
.js-select-all
'
);
const
findSelectAllButton
=
()
=>
wrapper
.
find
(
'
.js-select-all
'
);
...
@@ -74,6 +98,20 @@ describe('Design management index page', () => {
...
@@ -74,6 +98,20 @@ describe('Design management index page', () => {
const
findDropzoneWrapper
=
()
=>
wrapper
.
find
(
'
[data-testid="design-dropzone-wrapper"]
'
);
const
findDropzoneWrapper
=
()
=>
wrapper
.
find
(
'
[data-testid="design-dropzone-wrapper"]
'
);
const
findFirstDropzoneWithDesign
=
()
=>
wrapper
.
findAll
(
DesignDropzone
).
at
(
1
);
const
findFirstDropzoneWithDesign
=
()
=>
wrapper
.
findAll
(
DesignDropzone
).
at
(
1
);
const
findDesignsWrapper
=
()
=>
wrapper
.
find
(
'
[data-testid="designs-root"]
'
);
const
findDesignsWrapper
=
()
=>
wrapper
.
find
(
'
[data-testid="designs-root"]
'
);
const
findDesigns
=
()
=>
wrapper
.
findAll
(
Design
);
async
function
moveDesigns
(
localWrapper
)
{
await
jest
.
runOnlyPendingTimers
();
await
localWrapper
.
vm
.
$nextTick
();
localWrapper
.
find
(
VueDraggable
).
vm
.
$emit
(
'
input
'
,
reorderedDesigns
);
localWrapper
.
find
(
VueDraggable
).
vm
.
$emit
(
'
change
'
,
{
moved
:
{
newIndex
:
0
,
element
:
designToMove
,
},
});
}
function
createComponent
({
function
createComponent
({
loading
=
false
,
loading
=
false
,
...
@@ -118,8 +156,30 @@ describe('Design management index page', () => {
...
@@ -118,8 +156,30 @@ describe('Design management index page', () => {
});
});
}
}
function
createComponentWithApollo
({
moveHandler
=
jest
.
fn
().
mockResolvedValue
(
moveDesignMutationResponse
),
})
{
localVue
.
use
(
VueApollo
);
moveDesignHandler
=
moveHandler
;
const
requestHandlers
=
[
[
getDesignListQuery
,
jest
.
fn
().
mockResolvedValue
(
designListQueryResponse
)],
[
permissionsQuery
,
jest
.
fn
().
mockResolvedValue
(
permissionsQueryResponse
)],
[
moveDesignMutation
,
moveDesignHandler
],
];
fakeApollo
=
createMockApollo
(
requestHandlers
);
wrapper
=
shallowMount
(
Index
,
{
localVue
,
apolloProvider
:
fakeApollo
,
router
,
stubs
:
{
VueDraggable
},
});
}
afterEach
(()
=>
{
afterEach
(()
=>
{
wrapper
.
destroy
();
wrapper
.
destroy
();
wrapper
=
null
;
});
});
describe
(
'
designs
'
,
()
=>
{
describe
(
'
designs
'
,
()
=>
{
...
@@ -584,4 +644,64 @@ describe('Design management index page', () => {
...
@@ -584,4 +644,64 @@ describe('Design management index page', () => {
});
});
});
});
});
});
describe
(
'
with mocked Apollo client
'
,
()
=>
{
it
(
'
has a design with id 1 as a first one
'
,
async
()
=>
{
createComponentWithApollo
({});
await
jest
.
runOnlyPendingTimers
();
await
wrapper
.
vm
.
$nextTick
();
expect
(
findDesigns
()).
toHaveLength
(
3
);
expect
(
findDesigns
()
.
at
(
0
)
.
props
(
'
id
'
),
).
toBe
(
'
1
'
);
});
it
(
'
calls a mutation with correct parameters and reorders designs
'
,
async
()
=>
{
createComponentWithApollo
({});
await
moveDesigns
(
wrapper
);
expect
(
moveDesignHandler
).
toHaveBeenCalled
();
await
wrapper
.
vm
.
$nextTick
();
expect
(
findDesigns
()
.
at
(
0
)
.
props
(
'
id
'
),
).
toBe
(
'
2
'
);
});
it
(
'
displays flash if mutation had a recoverable error
'
,
async
()
=>
{
createComponentWithApollo
({
moveHandler
:
jest
.
fn
().
mockResolvedValue
(
moveDesignMutationResponseWithErrors
),
});
await
moveDesigns
(
wrapper
);
await
wrapper
.
vm
.
$nextTick
();
expect
(
createFlash
).
toHaveBeenCalledWith
(
'
Houston, we have a problem
'
);
});
it
(
'
displays flash if mutation had a non-recoverable error
'
,
async
()
=>
{
createComponentWithApollo
({
moveHandler
:
jest
.
fn
().
mockRejectedValue
(
'
Error
'
),
});
await
moveDesigns
(
wrapper
);
await
wrapper
.
vm
.
$nextTick
();
// kick off the DOM update
await
jest
.
runOnlyPendingTimers
();
// kick off the mocked GQL stuff (promises)
await
wrapper
.
vm
.
$nextTick
();
// kick off the DOM update for flash
expect
(
createFlash
).
toHaveBeenCalledWith
(
'
Something went wrong when reordering designs. Please try again
'
,
);
});
});
});
});
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