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
eb3ea747
Commit
eb3ea747
authored
Feb 25, 2021
by
Alex Kalderimis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve inline comments
parent
721d9b0b
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
41 additions
and
11 deletions
+41
-11
spec/support/helpers/graphql_helpers.rb
spec/support/helpers/graphql_helpers.rb
+41
-11
No files found.
spec/support/helpers/graphql_helpers.rb
View file @
eb3ea747
...
@@ -36,20 +36,49 @@ module GraphqlHelpers
...
@@ -36,20 +36,49 @@ module GraphqlHelpers
field_options
=
resolver_class
.
field_options
.
merge
(
name:
'value'
)
field_options
=
resolver_class
.
field_options
.
merge
(
name:
'value'
)
field
=
::
Types
::
BaseField
.
new
(
**
field_options
)
field
=
::
Types
::
BaseField
.
new
(
**
field_options
)
resolve_field
(
field
,
obj
,
args:
args
,
ctx:
ctx
,
schema:
schema
,
resolve_field
(
field
,
obj
,
parent_class:
resolver_parent
,
args:
args
,
ctx:
ctx
,
schema:
schema
,
object_type:
resolver_parent
,
extras:
{
parent:
parent
,
lookahead:
lookahead
})
extras:
{
parent:
parent
,
lookahead:
lookahead
})
end
end
# Resolve the value of a field on an object.
#
# Use this method to test individual fields within type specs.
#
# e.g.
#
# issue = create(:issue)
# user = issue.author
# project = issue.project
#
# resolve_field(:author, issue, current_user: user, object_type: ::Types::IssueType)
# resolve_field(:issue, project, args: { iid: issue.iid }, current_user: user, object_type: ::Types::ProjectType)
#
# The `object_type` defaults to the `described_class`, so when called from type specs,
# the above can be written as:
#
# # In project_type_spec.rb
# resolve_field(:author, issue, current_user: user)
#
# # In issue_type_spec.rb
# resolve_field(:issue, project, args: { iid: issue.iid }, current_user: user)
#
# NB: Arguments are passed from the client's perspective. If there is an argument
# `foo` aliased as `bar`, then we would pass `args: { bar: the_value }`, and
# types are checked before resolution.
def
resolve_field
(
def
resolve_field
(
field
,
# An instance of BaseField, or the name of a field on the current described_class
field
,
# An instance of `BaseField`, or the name of a field on the current described_class
object
,
# The current object of the BaseObject this field 'belongs' to
object
,
# The current object of the `BaseObject` this field 'belongs' to
ctx:
{},
# Context values (important ones are :current_user)
args:
{},
# Field arguments (keys will be fieldnamerized)
current_user: :not_given
,
# The current user (specified explicitly)
ctx:
{},
# Context values (important ones are :current_user)
args:
{},
# Field arguments (keys will be fieldnamerized)
extras:
{},
# Stub values for field extras (parent and lookahead)
extras:
{},
# Stub values for field extras (parent and lookahead)
current_user: :not_given
,
# The current user (specified explicitly, overrides ctx[:current_user])
schema:
GitlabSchema
,
# A specific schema instance
schema:
GitlabSchema
,
# A specific schema instance
parent_class:
described_class
)
object_type:
described_class
# The `BaseObject` type this field belongs to
)
field
=
to_base_field
(
field
)
field
=
to_base_field
(
field
)
ctx
[
:current_user
]
=
current_user
unless
current_user
==
:not_given
ctx
[
:current_user
]
=
current_user
unless
current_user
==
:not_given
query
=
GraphQL
::
Query
.
new
(
schema
,
context:
ctx
)
query
=
GraphQL
::
Query
.
new
(
schema
,
context:
ctx
)
...
@@ -59,7 +88,7 @@ module GraphqlHelpers
...
@@ -59,7 +88,7 @@ module GraphqlHelpers
mock_extras
(
query_ctx
,
**
extras
)
mock_extras
(
query_ctx
,
**
extras
)
parent
=
parent_class
.
authorized_new
(
object
,
query_ctx
)
parent
=
object_type
.
authorized_new
(
object
,
query_ctx
)
raise
UnauthorizedObject
unless
parent
raise
UnauthorizedObject
unless
parent
# TODO: This will need to change when we move to the interpreter:
# TODO: This will need to change when we move to the interpreter:
...
@@ -83,6 +112,7 @@ module GraphqlHelpers
...
@@ -83,6 +112,7 @@ module GraphqlHelpers
allow
(
context
).
to
receive
(
:lookahead
).
and_return
(
lookahead
)
unless
lookahead
==
:not_given
allow
(
context
).
to
receive
(
:lookahead
).
and_return
(
lookahead
)
unless
lookahead
==
:not_given
end
end
# a synthetic BaseObject type to be used in resolver specs. See `GraphqlHelpers#resolve`
def
resolver_parent
def
resolver_parent
@resolver_parent
||=
Class
.
new
(
::
Types
::
BaseObject
)
{
graphql_name
'ResolverParent'
}
@resolver_parent
||=
Class
.
new
(
::
Types
::
BaseObject
)
{
graphql_name
'ResolverParent'
}
end
end
...
...
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