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
f99110a2
Commit
f99110a2
authored
Mar 30, 2021
by
Michael Lunøe
Committed by
Olena Horal-Koretska
Mar 30, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Feat(Purchase Flow): local resolver for step state
parent
e8906a60
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
212 additions
and
0 deletions
+212
-0
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/mutations/activate_next_step.mutation.graphql
...low/graphql/mutations/activate_next_step.mutation.graphql
+3
-0
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/mutations/update_active_step.mutation.graphql
...low/graphql/mutations/update_active_step.mutation.graphql
+3
-0
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/queries/active_step.query.graphql
...d/purchase_flow/graphql/queries/active_step.query.graphql
+5
-0
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/queries/step_list.query.graphql
...red/purchase_flow/graphql/queries/step_list.query.graphql
+5
-0
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/resolvers.js
...javascripts/vue_shared/purchase_flow/graphql/resolvers.js
+43
-0
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/typedefs.graphql
...scripts/vue_shared/purchase_flow/graphql/typedefs.graphql
+15
-0
ee/spec/frontend/vue_shared/purchase_flow/graphql/resolvers_spec.js
...ontend/vue_shared/purchase_flow/graphql/resolvers_spec.js
+134
-0
ee/spec/frontend/vue_shared/purchase_flow/mock_data.js
ee/spec/frontend/vue_shared/purchase_flow/mock_data.js
+4
-0
No files found.
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/mutations/activate_next_step.mutation.graphql
0 → 100644
View file @
f99110a2
mutation
activateNextStep
{
activateNextStep
@client
}
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/mutations/update_active_step.mutation.graphql
0 → 100644
View file @
f99110a2
mutation
updateActiveStep
(
$id
:
String
)
{
updateActiveStep
(
id
:
$id
)
@client
}
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/queries/active_step.query.graphql
0 → 100644
View file @
f99110a2
query
activeStep
{
activeStep
@client
{
id
}
}
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/queries/step_list.query.graphql
0 → 100644
View file @
f99110a2
query
stepList
{
stepList
@client
{
id
}
}
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/resolvers.js
0 → 100644
View file @
f99110a2
import
produce
from
'
immer
'
;
import
activeStepQuery
from
'
./queries/active_step.query.graphql
'
;
import
stepListQuery
from
'
./queries/step_list.query.graphql
'
;
function
updateActiveStep
(
_
,
{
id
},
{
cache
})
{
const
sourceData
=
cache
.
readQuery
({
query
:
activeStepQuery
});
const
{
stepList
}
=
cache
.
readQuery
({
query
:
stepListQuery
});
const
activeStep
=
stepList
.
find
((
step
)
=>
step
.
id
===
id
);
const
data
=
produce
(
sourceData
,
(
draftData
)
=>
{
draftData
.
activeStep
=
{
// eslint-disable-next-line @gitlab/require-i18n-strings
__typename
:
'
Step
'
,
id
:
activeStep
.
id
,
};
});
return
cache
.
writeQuery
({
query
:
activeStepQuery
,
data
});
}
function
activateNextStep
(
parent
,
_
,
{
cache
})
{
const
sourceData
=
cache
.
readQuery
({
query
:
activeStepQuery
});
const
{
stepList
}
=
cache
.
readQuery
({
query
:
stepListQuery
});
const
index
=
stepList
.
findIndex
((
step
)
=>
step
.
id
===
sourceData
.
activeStep
.
id
);
const
activeStep
=
stepList
[
index
+
1
];
const
data
=
produce
(
sourceData
,
(
draftData
)
=>
{
draftData
.
activeStep
=
{
// eslint-disable-next-line @gitlab/require-i18n-strings
__typename
:
'
Step
'
,
id
:
activeStep
.
id
,
};
});
return
cache
.
writeQuery
({
query
:
activeStepQuery
,
data
});
}
export
default
{
Mutation
:
{
updateActiveStep
,
activateNextStep
,
},
};
ee/app/assets/javascripts/vue_shared/purchase_flow/graphql/typedefs.graphql
0 → 100644
View file @
f99110a2
type
Step
{
id
:
ID
}
extend
type
Query
{
activeStep
:
Step
}
extend
type
Query
{
stepList
:
[
Step
]
}
extend
type
Mutation
{
updateActiveStep
(
id
:
ID
!):
Boolean
}
ee/spec/frontend/vue_shared/purchase_flow/graphql/resolvers_spec.js
0 → 100644
View file @
f99110a2
import
{
createMockClient
}
from
'
mock-apollo-client
'
;
import
activateNextStepMutation
from
'
ee/vue_shared/purchase_flow/graphql/mutations/activate_next_step.mutation.graphql
'
;
import
updateStepMutation
from
'
ee/vue_shared/purchase_flow/graphql/mutations/update_active_step.mutation.graphql
'
;
import
activeStepQuery
from
'
ee/vue_shared/purchase_flow/graphql/queries/active_step.query.graphql
'
;
import
stepListQuery
from
'
ee/vue_shared/purchase_flow/graphql/queries/step_list.query.graphql
'
;
import
resolvers
from
'
ee/vue_shared/purchase_flow/graphql/resolvers
'
;
import
typeDefs
from
'
ee/vue_shared/purchase_flow/graphql/typedefs.graphql
'
;
import
{
STEPS
}
from
'
../mock_data
'
;
describe
(
'
ee/vue_shared/purchase_flow/graphql/resolvers
'
,
()
=>
{
let
mockClient
;
beforeEach
(
async
()
=>
{
mockClient
=
createMockClient
({
resolvers
,
typeDefs
});
mockClient
.
cache
.
writeQuery
({
query
:
stepListQuery
,
data
:
{
stepList
:
STEPS
,
},
});
mockClient
.
cache
.
writeQuery
({
query
:
activeStepQuery
,
data
:
{
activeStep
:
STEPS
[
0
],
},
});
});
describe
(
'
Query
'
,
()
=>
{
describe
(
'
stepListQuery
'
,
()
=>
{
it
(
'
stores the stepList
'
,
async
()
=>
{
const
queryResult
=
await
mockClient
.
query
({
query
:
stepListQuery
});
expect
(
queryResult
.
data
.
stepList
).
toMatchObject
(
STEPS
.
map
(({
id
})
=>
{
return
{
id
};
}),
);
});
it
(
'
throws an error when cache is not initiated properly
'
,
async
()
=>
{
mockClient
.
clearStore
();
await
mockClient
.
query
({
query
:
stepListQuery
}).
catch
((
e
)
=>
{
expect
(
e
instanceof
Error
).
toBe
(
true
);
});
});
});
describe
(
'
activeStepQuery
'
,
()
=>
{
it
(
'
stores the activeStep
'
,
async
()
=>
{
const
queryResult
=
await
mockClient
.
query
({
query
:
activeStepQuery
});
expect
(
queryResult
.
data
.
activeStep
).
toMatchObject
({
id
:
STEPS
[
0
].
id
});
});
it
(
'
throws an error when cache is not initiated properly
'
,
async
()
=>
{
mockClient
.
clearStore
();
await
mockClient
.
query
({
query
:
activeStepQuery
}).
catch
((
e
)
=>
{
expect
(
e
instanceof
Error
).
toBe
(
true
);
});
});
});
});
describe
(
'
Mutation
'
,
()
=>
{
describe
(
'
updateActiveStep
'
,
()
=>
{
it
(
'
updates the active step
'
,
async
()
=>
{
await
mockClient
.
mutate
({
mutation
:
updateStepMutation
,
variables
:
{
id
:
STEPS
[
1
].
id
},
});
const
queryResult
=
await
mockClient
.
query
({
query
:
activeStepQuery
});
expect
(
queryResult
.
data
.
activeStep
).
toMatchObject
({
id
:
STEPS
[
1
].
id
});
});
it
(
'
throws an error when STEP is not present
'
,
async
()
=>
{
const
id
=
'
does not exist
'
;
await
mockClient
.
mutate
({
mutation
:
updateStepMutation
,
variables
:
{
id
},
})
.
catch
((
e
)
=>
{
expect
(
e
instanceof
Error
).
toBe
(
true
);
});
});
it
(
'
throws an error when cache is not initiated properly
'
,
async
()
=>
{
mockClient
.
clearStore
();
await
mockClient
.
mutate
({
mutation
:
updateStepMutation
,
variables
:
{
id
:
STEPS
[
1
].
id
},
})
.
catch
((
e
)
=>
{
expect
(
e
instanceof
Error
).
toBe
(
true
);
});
});
});
describe
(
'
activateNextStep
'
,
()
=>
{
it
(
'
updates the active step to the next
'
,
async
()
=>
{
await
mockClient
.
mutate
({
mutation
:
activateNextStepMutation
,
});
const
queryResult
=
await
mockClient
.
query
({
query
:
activeStepQuery
});
expect
(
queryResult
.
data
.
activeStep
).
toMatchObject
({
id
:
STEPS
[
1
].
id
});
});
it
(
'
throws an error when out of bounds
'
,
async
()
=>
{
await
mockClient
.
mutate
({
mutation
:
activateNextStepMutation
,
});
await
mockClient
.
mutate
({
mutation
:
activateNextStepMutation
,
})
.
catch
((
e
)
=>
{
expect
(
e
instanceof
Error
).
toBe
(
true
);
});
});
it
(
'
throws an error when cache is not initiated properly
'
,
async
()
=>
{
mockClient
.
clearStore
();
await
mockClient
.
mutate
({
mutation
:
activateNextStepMutation
,
})
.
catch
((
e
)
=>
{
expect
(
e
instanceof
Error
).
toBe
(
true
);
});
});
});
});
});
ee/spec/frontend/vue_shared/purchase_flow/mock_data.js
0 → 100644
View file @
f99110a2
export
const
STEPS
=
[
{
__typename
:
'
Step
'
,
id
:
'
firstStep
'
},
{
__typename
:
'
Step
'
,
id
:
'
secondStep
'
},
];
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