Skip to content

Commit

Permalink
Merge pull request #5158 from rmosolgo/fix-mutation-typo
Browse files Browse the repository at this point in the history
Fix lazy mutation loading
  • Loading branch information
rmosolgo authored Nov 11, 2024
2 parents 0b49803 + 0072f69 commit 6adf39b
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 8 deletions.
13 changes: 10 additions & 3 deletions javascript_client/src/sync/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ function sync(options: SyncOptions) {
var verbose = !!options.verbose
var url = options.url
var dumpingPayload = "dumpPayload" in options
var dumpingToStdout = options.dumpPayload == true
if (!url && !dumpingPayload) {
logger.log("No URL; Generating artifacts without syncing them")
}
Expand Down Expand Up @@ -241,12 +242,18 @@ function sync(options: SyncOptions) {
operations: payload.operations,
generatedCode,
}
logger.log("Generating client module in " + logger.colorize("bright", outfile) + "...")
if (!dumpingToStdout) {
logger.log("Generating client module in " + logger.colorize("bright", outfile) + "...")
}
fs.writeFileSync(outfile, generatedCode, "utf8")
logger.log(logger.green("✓ Done!"))
if (!dumpingToStdout) {
logger.log(logger.green("✓ Done!"))
}
return finishedPayload
} else {
logger.log(logger.green("✓ Done!"))
if (!dumpingToStdout) {
logger.log(logger.green("✓ Done!"))
}
return payload
}
})
Expand Down
2 changes: 1 addition & 1 deletion lib/graphql/schema.rb
Original file line number Diff line number Diff line change
Expand Up @@ -492,7 +492,7 @@ def mutation(new_mutation_object = nil, &lazy_load_block)
nil
elsif @mutation_object.is_a?(Proc)
@mutation_object = @mutation_object.call
self.visibility&.mutation_configured(@query_object)
self.visibility&.mutation_configured(@mutation_object)
@mutation_object
else
@mutation_object || find_inherited_value(:mutation)
Expand Down
15 changes: 11 additions & 4 deletions spec/graphql/schema/visibility_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -133,9 +133,10 @@ class OrphanType < GraphQL::Schema::Object
end
end
# This one is added before `Visibility`
mutation(Mutation)
use GraphQL::Schema::Visibility, preload: true
subscription(Subscription)
use GraphQL::Schema::Visibility, preload: true
query { Query }
mutation { Mutation }
orphan_types(OrphanType)

module CustomIntrospection
Expand All @@ -150,9 +151,15 @@ class DynamicFields < GraphQL::Introspection::DynamicFields

it "still preloads" do
assert_equal [], NoProfileSchema::Query.all_field_definitions.first.extensions.map(&:class)
NoProfileSchema.query(NoProfileSchema::Query)
assert_equal [NoProfileSchema::ExampleExtension], NoProfileSchema::Query.all_field_definitions.first.extensions.map(&:class)
assert_equal [], NoProfileSchema::Mutation.all_field_definitions.first.extensions.map(&:class)
NoProfileSchema.mutation
assert_equal [NoProfileSchema::ExampleExtension], NoProfileSchema::Mutation.all_field_definitions.first.extensions.map(&:class)
# Didn't load this:
assert_equal [], NoProfileSchema::Query.all_field_definitions.first.extensions.map(&:class)

NoProfileSchema.query
assert_equal [NoProfileSchema::ExampleExtension], NoProfileSchema::Query.all_field_definitions.first.extensions.map(&:class)

assert_equal [NoProfileSchema::ExampleExtension], NoProfileSchema::Subscription.all_field_definitions.first.extensions.map(&:class)
assert_equal [NoProfileSchema::ExampleExtension, NoProfileSchema::OtherExampleExtension], NoProfileSchema::OrphanType.all_field_definitions.first.extensions.map(&:class)
custom_int_field = NoProfileSchema::CustomIntrospection::DynamicFields.all_field_definitions.find { |f| f.original_name == :__hello }
Expand Down

0 comments on commit 6adf39b

Please sign in to comment.