graphql 1.9.11 → 1.9.12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (286) hide show
  1. checksums.yaml +4 -4
  2. data/lib/graphql/analysis/ast/query_complexity.rb +0 -8
  3. data/lib/graphql/analysis/ast/query_depth.rb +0 -8
  4. data/lib/graphql/analysis/ast/visitor.rb +26 -24
  5. data/lib/graphql/execution.rb +1 -0
  6. data/lib/graphql/execution/errors.rb +60 -0
  7. data/lib/graphql/execution/interpreter/runtime.rb +21 -17
  8. data/lib/graphql/static_validation/rules/fields_will_merge.rb +15 -8
  9. data/lib/graphql/version.rb +1 -1
  10. metadata +5 -556
  11. data/spec/dummy/Gemfile +0 -12
  12. data/spec/dummy/README.md +0 -24
  13. data/spec/dummy/Rakefile +0 -7
  14. data/spec/dummy/app/assets/config/manifest.js +0 -1
  15. data/spec/dummy/app/assets/javascripts/application.js +0 -66
  16. data/spec/dummy/app/channels/application_cable/channel.rb +0 -5
  17. data/spec/dummy/app/channels/application_cable/connection.rb +0 -5
  18. data/spec/dummy/app/channels/graphql_channel.rb +0 -116
  19. data/spec/dummy/app/controllers/application_controller.rb +0 -4
  20. data/spec/dummy/app/controllers/pages_controller.rb +0 -5
  21. data/spec/dummy/app/helpers/application_helper.rb +0 -3
  22. data/spec/dummy/app/jobs/application_job.rb +0 -3
  23. data/spec/dummy/app/views/layouts/application.html.erb +0 -12
  24. data/spec/dummy/app/views/pages/show.html +0 -16
  25. data/spec/dummy/bin/bundle +0 -4
  26. data/spec/dummy/bin/rails +0 -5
  27. data/spec/dummy/bin/rake +0 -5
  28. data/spec/dummy/bin/setup +0 -31
  29. data/spec/dummy/bin/update +0 -27
  30. data/spec/dummy/bin/yarn +0 -12
  31. data/spec/dummy/config.ru +0 -6
  32. data/spec/dummy/config/application.rb +0 -30
  33. data/spec/dummy/config/boot.rb +0 -4
  34. data/spec/dummy/config/cable.yml +0 -10
  35. data/spec/dummy/config/environment.rb +0 -6
  36. data/spec/dummy/config/environments/development.rb +0 -40
  37. data/spec/dummy/config/environments/production.rb +0 -76
  38. data/spec/dummy/config/environments/test.rb +0 -37
  39. data/spec/dummy/config/initializers/application_controller_renderer.rb +0 -9
  40. data/spec/dummy/config/initializers/backtrace_silencers.rb +0 -8
  41. data/spec/dummy/config/initializers/cookies_serializer.rb +0 -6
  42. data/spec/dummy/config/initializers/filter_parameter_logging.rb +0 -5
  43. data/spec/dummy/config/initializers/inflections.rb +0 -17
  44. data/spec/dummy/config/initializers/mime_types.rb +0 -5
  45. data/spec/dummy/config/initializers/wrap_parameters.rb +0 -10
  46. data/spec/dummy/config/locales/en.yml +0 -33
  47. data/spec/dummy/config/puma.rb +0 -57
  48. data/spec/dummy/config/routes.rb +0 -4
  49. data/spec/dummy/config/secrets.yml +0 -32
  50. data/spec/dummy/package.json +0 -5
  51. data/spec/dummy/public/404.html +0 -67
  52. data/spec/dummy/public/422.html +0 -67
  53. data/spec/dummy/public/500.html +0 -66
  54. data/spec/dummy/public/apple-touch-icon-precomposed.png +0 -0
  55. data/spec/dummy/public/apple-touch-icon.png +0 -0
  56. data/spec/dummy/public/favicon.ico +0 -0
  57. data/spec/dummy/public/robots.txt +0 -1
  58. data/spec/dummy/test/application_system_test_case.rb +0 -6
  59. data/spec/dummy/test/system/action_cable_subscription_test.rb +0 -45
  60. data/spec/dummy/test/test_helper.rb +0 -4
  61. data/spec/fixtures/upgrader/account.original.rb +0 -19
  62. data/spec/fixtures/upgrader/account.transformed.rb +0 -20
  63. data/spec/fixtures/upgrader/blame_range.original.rb +0 -43
  64. data/spec/fixtures/upgrader/blame_range.transformed.rb +0 -30
  65. data/spec/fixtures/upgrader/date_time.original.rb +0 -24
  66. data/spec/fixtures/upgrader/date_time.transformed.rb +0 -23
  67. data/spec/fixtures/upgrader/delete_project.original.rb +0 -28
  68. data/spec/fixtures/upgrader/delete_project.transformed.rb +0 -27
  69. data/spec/fixtures/upgrader/gist_order_field.original.rb +0 -14
  70. data/spec/fixtures/upgrader/gist_order_field.transformed.rb +0 -13
  71. data/spec/fixtures/upgrader/increment_count.original.rb +0 -59
  72. data/spec/fixtures/upgrader/increment_count.transformed.rb +0 -50
  73. data/spec/fixtures/upgrader/mutation.original.rb +0 -28
  74. data/spec/fixtures/upgrader/mutation.transformed.rb +0 -28
  75. data/spec/fixtures/upgrader/photo.original.rb +0 -10
  76. data/spec/fixtures/upgrader/photo.transformed.rb +0 -12
  77. data/spec/fixtures/upgrader/release_order.original.rb +0 -15
  78. data/spec/fixtures/upgrader/release_order.transformed.rb +0 -14
  79. data/spec/fixtures/upgrader/starrable.original.rb +0 -49
  80. data/spec/fixtures/upgrader/starrable.transformed.rb +0 -46
  81. data/spec/fixtures/upgrader/subscribable.original.rb +0 -55
  82. data/spec/fixtures/upgrader/subscribable.transformed.rb +0 -51
  83. data/spec/fixtures/upgrader/type_x.original.rb +0 -65
  84. data/spec/fixtures/upgrader/type_x.transformed.rb +0 -56
  85. data/spec/graphql/analysis/analyze_query_spec.rb +0 -261
  86. data/spec/graphql/analysis/ast/field_usage_spec.rb +0 -51
  87. data/spec/graphql/analysis/ast/max_query_complexity_spec.rb +0 -120
  88. data/spec/graphql/analysis/ast/max_query_depth_spec.rb +0 -134
  89. data/spec/graphql/analysis/ast/query_complexity_spec.rb +0 -299
  90. data/spec/graphql/analysis/ast/query_depth_spec.rb +0 -108
  91. data/spec/graphql/analysis/ast_spec.rb +0 -296
  92. data/spec/graphql/analysis/field_usage_spec.rb +0 -62
  93. data/spec/graphql/analysis/max_query_complexity_spec.rb +0 -102
  94. data/spec/graphql/analysis/max_query_depth_spec.rb +0 -103
  95. data/spec/graphql/analysis/query_complexity_spec.rb +0 -301
  96. data/spec/graphql/analysis/query_depth_spec.rb +0 -81
  97. data/spec/graphql/argument_spec.rb +0 -159
  98. data/spec/graphql/authorization_spec.rb +0 -974
  99. data/spec/graphql/backtrace_spec.rb +0 -206
  100. data/spec/graphql/base_type_spec.rb +0 -171
  101. data/spec/graphql/boolean_type_spec.rb +0 -21
  102. data/spec/graphql/compatibility/execution_specification_spec.rb +0 -4
  103. data/spec/graphql/compatibility/lazy_execution_specification_spec.rb +0 -4
  104. data/spec/graphql/compatibility/query_parser_specification_spec.rb +0 -6
  105. data/spec/graphql/compatibility/schema_parser_specification_spec.rb +0 -6
  106. data/spec/graphql/define/assign_argument_spec.rb +0 -61
  107. data/spec/graphql/define/instance_definable_spec.rb +0 -203
  108. data/spec/graphql/directive/skip_directive_spec.rb +0 -9
  109. data/spec/graphql/directive_spec.rb +0 -295
  110. data/spec/graphql/enum_type_spec.rb +0 -158
  111. data/spec/graphql/execution/execute_spec.rb +0 -303
  112. data/spec/graphql/execution/instrumentation_spec.rb +0 -212
  113. data/spec/graphql/execution/interpreter_spec.rb +0 -485
  114. data/spec/graphql/execution/lazy/lazy_method_map_spec.rb +0 -57
  115. data/spec/graphql/execution/lazy_spec.rb +0 -247
  116. data/spec/graphql/execution/lookahead_spec.rb +0 -390
  117. data/spec/graphql/execution/multiplex_spec.rb +0 -222
  118. data/spec/graphql/execution/typecast_spec.rb +0 -47
  119. data/spec/graphql/execution_error_spec.rb +0 -329
  120. data/spec/graphql/field_spec.rb +0 -246
  121. data/spec/graphql/float_type_spec.rb +0 -16
  122. data/spec/graphql/function_spec.rb +0 -152
  123. data/spec/graphql/id_type_spec.rb +0 -33
  124. data/spec/graphql/input_object_type_spec.rb +0 -25
  125. data/spec/graphql/int_type_spec.rb +0 -35
  126. data/spec/graphql/interface_type_spec.rb +0 -196
  127. data/spec/graphql/internal_representation/print_spec.rb +0 -41
  128. data/spec/graphql/internal_representation/rewrite_spec.rb +0 -381
  129. data/spec/graphql/introspection/directive_type_spec.rb +0 -66
  130. data/spec/graphql/introspection/input_value_type_spec.rb +0 -144
  131. data/spec/graphql/introspection/introspection_query_spec.rb +0 -64
  132. data/spec/graphql/introspection/schema_type_spec.rb +0 -57
  133. data/spec/graphql/introspection/type_type_spec.rb +0 -155
  134. data/spec/graphql/language/block_string_spec.rb +0 -70
  135. data/spec/graphql/language/definition_slice_spec.rb +0 -226
  136. data/spec/graphql/language/document_from_schema_definition_spec.rb +0 -770
  137. data/spec/graphql/language/equality_spec.rb +0 -84
  138. data/spec/graphql/language/generation_spec.rb +0 -38
  139. data/spec/graphql/language/lexer_spec.rb +0 -153
  140. data/spec/graphql/language/nodes_spec.rb +0 -67
  141. data/spec/graphql/language/parser_spec.rb +0 -183
  142. data/spec/graphql/language/printer_spec.rb +0 -215
  143. data/spec/graphql/language/visitor_spec.rb +0 -419
  144. data/spec/graphql/list_type_spec.rb +0 -57
  145. data/spec/graphql/non_null_type_spec.rb +0 -48
  146. data/spec/graphql/object_type_spec.rb +0 -197
  147. data/spec/graphql/query/arguments_spec.rb +0 -346
  148. data/spec/graphql/query/context_spec.rb +0 -292
  149. data/spec/graphql/query/executor_spec.rb +0 -341
  150. data/spec/graphql/query/literal_input_spec.rb +0 -91
  151. data/spec/graphql/query/result_spec.rb +0 -29
  152. data/spec/graphql/query/serial_execution/value_resolution_spec.rb +0 -109
  153. data/spec/graphql/query_spec.rb +0 -803
  154. data/spec/graphql/rake_task_spec.rb +0 -59
  155. data/spec/graphql/scalar_type_spec.rb +0 -66
  156. data/spec/graphql/schema/argument_spec.rb +0 -186
  157. data/spec/graphql/schema/build_from_definition_spec.rb +0 -1197
  158. data/spec/graphql/schema/catchall_middleware_spec.rb +0 -32
  159. data/spec/graphql/schema/directive/feature_spec.rb +0 -81
  160. data/spec/graphql/schema/directive/transform_spec.rb +0 -39
  161. data/spec/graphql/schema/enum_spec.rb +0 -83
  162. data/spec/graphql/schema/enum_value_spec.rb +0 -24
  163. data/spec/graphql/schema/field_extension_spec.rb +0 -159
  164. data/spec/graphql/schema/field_spec.rb +0 -319
  165. data/spec/graphql/schema/finder_spec.rb +0 -135
  166. data/spec/graphql/schema/input_object_spec.rb +0 -421
  167. data/spec/graphql/schema/instrumentation_spec.rb +0 -43
  168. data/spec/graphql/schema/interface_spec.rb +0 -215
  169. data/spec/graphql/schema/introspection_system_spec.rb +0 -80
  170. data/spec/graphql/schema/list_spec.rb +0 -73
  171. data/spec/graphql/schema/loader_spec.rb +0 -350
  172. data/spec/graphql/schema/member/accepts_definition_spec.rb +0 -115
  173. data/spec/graphql/schema/member/build_type_spec.rb +0 -63
  174. data/spec/graphql/schema/member/scoped_spec.rb +0 -217
  175. data/spec/graphql/schema/member/type_system_helpers_spec.rb +0 -63
  176. data/spec/graphql/schema/middleware_chain_spec.rb +0 -57
  177. data/spec/graphql/schema/mutation_spec.rb +0 -150
  178. data/spec/graphql/schema/non_null_spec.rb +0 -46
  179. data/spec/graphql/schema/object_spec.rb +0 -355
  180. data/spec/graphql/schema/printer_spec.rb +0 -883
  181. data/spec/graphql/schema/relay_classic_mutation_spec.rb +0 -252
  182. data/spec/graphql/schema/rescue_middleware_spec.rb +0 -88
  183. data/spec/graphql/schema/resolver_spec.rb +0 -743
  184. data/spec/graphql/schema/scalar_spec.rb +0 -101
  185. data/spec/graphql/schema/subscription_spec.rb +0 -505
  186. data/spec/graphql/schema/timeout_middleware_spec.rb +0 -188
  187. data/spec/graphql/schema/timeout_spec.rb +0 -206
  188. data/spec/graphql/schema/traversal_spec.rb +0 -222
  189. data/spec/graphql/schema/type_expression_spec.rb +0 -39
  190. data/spec/graphql/schema/union_spec.rb +0 -72
  191. data/spec/graphql/schema/unique_within_type_spec.rb +0 -44
  192. data/spec/graphql/schema/validation_spec.rb +0 -355
  193. data/spec/graphql/schema/warden_spec.rb +0 -926
  194. data/spec/graphql/schema_spec.rb +0 -169
  195. data/spec/graphql/static_validation/rules/argument_literals_are_compatible_spec.rb +0 -466
  196. data/spec/graphql/static_validation/rules/argument_names_are_unique_spec.rb +0 -44
  197. data/spec/graphql/static_validation/rules/arguments_are_defined_spec.rb +0 -112
  198. data/spec/graphql/static_validation/rules/directives_are_defined_spec.rb +0 -35
  199. data/spec/graphql/static_validation/rules/directives_are_in_valid_locations_spec.rb +0 -42
  200. data/spec/graphql/static_validation/rules/fields_are_defined_on_type_spec.rb +0 -167
  201. data/spec/graphql/static_validation/rules/fields_have_appropriate_selections_spec.rb +0 -66
  202. data/spec/graphql/static_validation/rules/fields_will_merge_spec.rb +0 -740
  203. data/spec/graphql/static_validation/rules/fragment_names_are_unique_spec.rb +0 -28
  204. data/spec/graphql/static_validation/rules/fragment_spreads_are_possible_spec.rb +0 -52
  205. data/spec/graphql/static_validation/rules/fragment_types_exist_spec.rb +0 -42
  206. data/spec/graphql/static_validation/rules/fragments_are_finite_spec.rb +0 -123
  207. data/spec/graphql/static_validation/rules/fragments_are_named_spec.rb +0 -24
  208. data/spec/graphql/static_validation/rules/fragments_are_on_composite_types_spec.rb +0 -56
  209. data/spec/graphql/static_validation/rules/fragments_are_used_spec.rb +0 -61
  210. data/spec/graphql/static_validation/rules/mutation_root_exists_spec.rb +0 -39
  211. data/spec/graphql/static_validation/rules/no_definitions_are_present_spec.rb +0 -62
  212. data/spec/graphql/static_validation/rules/operation_names_are_valid_spec.rb +0 -82
  213. data/spec/graphql/static_validation/rules/required_arguments_are_present_spec.rb +0 -98
  214. data/spec/graphql/static_validation/rules/required_input_object_attributes_are_present_spec.rb +0 -86
  215. data/spec/graphql/static_validation/rules/subscription_root_exists_spec.rb +0 -34
  216. data/spec/graphql/static_validation/rules/unique_directives_per_location_spec.rb +0 -188
  217. data/spec/graphql/static_validation/rules/variable_default_values_are_correctly_typed_spec.rb +0 -196
  218. data/spec/graphql/static_validation/rules/variable_names_are_unique_spec.rb +0 -23
  219. data/spec/graphql/static_validation/rules/variable_usages_are_allowed_spec.rb +0 -236
  220. data/spec/graphql/static_validation/rules/variables_are_input_types_spec.rb +0 -78
  221. data/spec/graphql/static_validation/rules/variables_are_used_and_defined_spec.rb +0 -81
  222. data/spec/graphql/static_validation/type_stack_spec.rb +0 -29
  223. data/spec/graphql/static_validation/validator_spec.rb +0 -204
  224. data/spec/graphql/string_type_spec.rb +0 -80
  225. data/spec/graphql/subscriptions/serialize_spec.rb +0 -49
  226. data/spec/graphql/subscriptions_spec.rb +0 -540
  227. data/spec/graphql/tracing/new_relic_tracing_spec.rb +0 -84
  228. data/spec/graphql/tracing/platform_tracing_spec.rb +0 -141
  229. data/spec/graphql/tracing/prometheus_tracing_spec.rb +0 -42
  230. data/spec/graphql/tracing/scout_tracing_spec.rb +0 -17
  231. data/spec/graphql/tracing/skylight_tracing_spec.rb +0 -63
  232. data/spec/graphql/tracing_spec.rb +0 -52
  233. data/spec/graphql/types/big_int_spec.rb +0 -24
  234. data/spec/graphql/types/iso_8601_date_time_spec.rb +0 -137
  235. data/spec/graphql/types/relay/base_edge_spec.rb +0 -33
  236. data/spec/graphql/union_type_spec.rb +0 -211
  237. data/spec/graphql/upgrader/member_spec.rb +0 -583
  238. data/spec/graphql/upgrader/schema_spec.rb +0 -82
  239. data/spec/integration/mongoid/graphql/relay/mongo_relation_connection_spec.rb +0 -528
  240. data/spec/integration/mongoid/spec_helper.rb +0 -2
  241. data/spec/integration/mongoid/star_trek/data.rb +0 -126
  242. data/spec/integration/mongoid/star_trek/schema.rb +0 -424
  243. data/spec/integration/rails/data.rb +0 -110
  244. data/spec/integration/rails/generators/base_generator_test.rb +0 -7
  245. data/spec/integration/rails/generators/graphql/enum_generator_spec.rb +0 -30
  246. data/spec/integration/rails/generators/graphql/install_generator_spec.rb +0 -238
  247. data/spec/integration/rails/generators/graphql/interface_generator_spec.rb +0 -34
  248. data/spec/integration/rails/generators/graphql/loader_generator_spec.rb +0 -59
  249. data/spec/integration/rails/generators/graphql/mutation_generator_spec.rb +0 -71
  250. data/spec/integration/rails/generators/graphql/object_generator_spec.rb +0 -54
  251. data/spec/integration/rails/generators/graphql/scalar_generator_spec.rb +0 -28
  252. data/spec/integration/rails/generators/graphql/union_generator_spec.rb +0 -67
  253. data/spec/integration/rails/graphql/input_object_spec.rb +0 -19
  254. data/spec/integration/rails/graphql/input_object_type_spec.rb +0 -364
  255. data/spec/integration/rails/graphql/query/variables_spec.rb +0 -375
  256. data/spec/integration/rails/graphql/relay/array_connection_spec.rb +0 -309
  257. data/spec/integration/rails/graphql/relay/base_connection_spec.rb +0 -101
  258. data/spec/integration/rails/graphql/relay/connection_instrumentation_spec.rb +0 -80
  259. data/spec/integration/rails/graphql/relay/connection_resolve_spec.rb +0 -79
  260. data/spec/integration/rails/graphql/relay/connection_type_spec.rb +0 -106
  261. data/spec/integration/rails/graphql/relay/edge_spec.rb +0 -10
  262. data/spec/integration/rails/graphql/relay/mutation_spec.rb +0 -387
  263. data/spec/integration/rails/graphql/relay/node_spec.rb +0 -263
  264. data/spec/integration/rails/graphql/relay/page_info_spec.rb +0 -111
  265. data/spec/integration/rails/graphql/relay/range_add_spec.rb +0 -117
  266. data/spec/integration/rails/graphql/relay/relation_connection_spec.rb +0 -837
  267. data/spec/integration/rails/graphql/schema_spec.rb +0 -507
  268. data/spec/integration/rails/graphql/tracing/active_support_notifications_tracing_spec.rb +0 -62
  269. data/spec/integration/rails/spec_helper.rb +0 -25
  270. data/spec/spec_helper.rb +0 -116
  271. data/spec/support/dummy/data.rb +0 -45
  272. data/spec/support/dummy/schema.rb +0 -519
  273. data/spec/support/error_bubbling_helpers.rb +0 -23
  274. data/spec/support/global_id.rb +0 -23
  275. data/spec/support/jazz.rb +0 -778
  276. data/spec/support/lazy_helpers.rb +0 -192
  277. data/spec/support/magic_cards/schema.graphql +0 -33
  278. data/spec/support/minimum_input_object.rb +0 -21
  279. data/spec/support/new_relic.rb +0 -27
  280. data/spec/support/parser/filename_example.graphql +0 -5
  281. data/spec/support/parser/filename_example_error_1.graphql +0 -4
  282. data/spec/support/parser/filename_example_error_2.graphql +0 -5
  283. data/spec/support/parser/filename_example_invalid_utf8.graphql +0 -1
  284. data/spec/support/skylight.rb +0 -39
  285. data/spec/support/star_wars/schema.rb +0 -464
  286. data/spec/support/static_validation_helpers.rb +0 -32
@@ -1,375 +0,0 @@
1
- # frozen_string_literal: true
2
- require "spec_helper"
3
-
4
- describe GraphQL::Query::Variables do
5
- let(:query_string) {%|
6
- query getCheese(
7
- $animals: [DairyAnimal!],
8
- $intDefaultNull: Int = null,
9
- $int: Int,
10
- $intWithDefault: Int = 10)
11
- {
12
- cheese(id: 1) {
13
- similarCheese(source: $animals)
14
- }
15
- }
16
- |}
17
- let(:ast_variables) { GraphQL.parse(query_string).definitions.first.variables }
18
- let(:schema) { Dummy::Schema }
19
- let(:variables) {
20
- GraphQL::Query::Variables.new(
21
- OpenStruct.new({
22
- schema: schema,
23
- warden: GraphQL::Schema::Warden.new(schema.default_filter, schema: schema, context: nil),
24
- }),
25
- ast_variables,
26
- provided_variables)
27
- }
28
-
29
- describe "#to_h" do
30
- let(:provided_variables) { { "animals" => "YAK" } }
31
-
32
- it "returns a hash representation including default values" do
33
- expected_hash = {
34
- "animals" => ["YAK"],
35
- "intDefaultNull" => nil,
36
- "intWithDefault" => 10,
37
- }
38
- assert_equal expected_hash, variables.to_h
39
- end
40
- end
41
-
42
- describe "#initialize" do
43
- describe "coercing inputs" do
44
- let(:provided_variables) { { "animals" => "YAK" } }
45
-
46
- it "coerces single items into one-element lists" do
47
- assert_equal ["YAK"], variables["animals"]
48
- end
49
- end
50
-
51
- describe "symbol keys" do
52
- let(:query_string) { <<-GRAPHQL
53
- query testVariables(
54
- $dairy_product_1: DairyProductInput!
55
- $dairy_product_2: DairyProductInput!
56
- ) {
57
- __typename
58
- }
59
- GRAPHQL
60
- }
61
-
62
- let(:provided_variables) {
63
- {
64
- dairy_product_1: { source: "COW", fatContent: 0.99 },
65
- "dairy_product_2" => { source: "DONKEY", "fatContent": 0.89 },
66
- }
67
- }
68
-
69
- it "checks for string matches" do
70
- # These get merged into all the values above
71
- default_values = {
72
- origin_dairy: "Sugar Hollow Dairy",
73
- organic: false,
74
- order_by: { direction: "ASC" },
75
- }
76
-
77
- expected_input_1 = {
78
- source: 1,
79
- fat_content: 0.99,
80
- }.merge(default_values)
81
-
82
- assert_equal(expected_input_1, variables["dairy_product_1"].to_h)
83
-
84
- expected_input_2 = {
85
- source: :donkey,
86
- fat_content: 0.89,
87
- }.merge(default_values)
88
- assert_equal(expected_input_2, variables["dairy_product_2"].to_h)
89
- end
90
- end
91
-
92
- describe "validating input objects" do
93
- let(:query_string) {%|
94
- query searchMyDairy (
95
- $product: DairyProductInput
96
- ) {
97
- searchDairy(product: $product) {
98
- ... on Cheese {
99
- flavor
100
- }
101
- }
102
- }
103
- |}
104
-
105
- describe "when provided input is an array" do
106
- let(:provided_variables) { { "product" => [] } }
107
-
108
- it "validates invalid input objects" do
109
- expected = "Variable product of type DairyProductInput was provided invalid value"
110
- assert_equal expected, variables.errors.first.message
111
- end
112
- end
113
-
114
- describe "when provided input cannot be coerced" do
115
- let(:query_string) {%|
116
- query searchMyDairy (
117
- $time: Time
118
- ) {
119
- searchDairy(expiresAfter: $time) {
120
- ... on Cheese {
121
- flavor
122
- }
123
- }
124
- }
125
- |}
126
- let(:provided_variables) { { "time" => "a" } }
127
-
128
- it "validates invalid input objects" do
129
- expected = "Variable time of type Time was provided invalid value"
130
- assert_equal expected, variables.errors.first.message
131
- end
132
- end
133
- end
134
-
135
- describe "nullable variables" do
136
- module ObjectWithThingsCount
137
- def self.thingsCount(args, ctx) # rubocop:disable Naming/MethodName
138
- 1
139
- end
140
- end
141
-
142
- let(:schema) { GraphQL::Schema.from_definition(%|
143
- type Query {
144
- thingsCount(ids: [ID!]): Int!
145
- }
146
- |)
147
- }
148
- let(:query_string) {%|
149
- query getThingsCount($ids: [ID!]) {
150
- thingsCount(ids: $ids)
151
- }
152
- |}
153
- let(:result) {
154
- schema.execute(query_string, variables: provided_variables, root_value: ObjectWithThingsCount)
155
- }
156
-
157
- describe "when they are present, but null" do
158
- let(:provided_variables) { { "ids" => nil } }
159
- it "ignores them" do
160
- assert_equal 1, result["data"]["thingsCount"]
161
- end
162
- end
163
-
164
- describe "when they are not present" do
165
- let(:provided_variables) { {} }
166
- it "ignores them" do
167
- assert_equal 1, result["data"]["thingsCount"]
168
- end
169
- end
170
-
171
- describe "when a non-nullable list has a null in it" do
172
- let(:provided_variables) { { "ids" => [nil] } }
173
- it "returns an error" do
174
- assert_equal 1, result["errors"].length
175
- assert_nil result["data"]
176
- end
177
- end
178
- end
179
-
180
- describe "coercing null" do
181
- let(:provided_variables) {
182
- {
183
- "intWithVariable" => nil,
184
- "intWithDefault" => nil,
185
- "complexValWithVariable" => {
186
- "val" => 1,
187
- "val_with_default" => 2,
188
- },
189
- "complexValWithDefaultAndVariable" => {
190
- "val" => 8,
191
- },
192
- }
193
- }
194
- let(:args) { {} }
195
- let(:schema) {
196
- args_cache = args
197
-
198
- complex_val = GraphQL::InputObjectType.define do
199
- name "ComplexVal"
200
- argument :val, types.Int
201
- argument :val_with_default, types.Int, default_value: 13
202
- end
203
-
204
- query_type = GraphQL::ObjectType.define do
205
- name "Query"
206
- field :variables_test, types.Int do
207
- argument :val, types.Int
208
- argument :val_with_default, types.Int, default_value: 13
209
- argument :complex_val, complex_val
210
- resolve ->(o, a, c) {
211
- args_cache[c.ast_node.alias] = a
212
- 1
213
- }
214
- end
215
- end
216
-
217
- GraphQL::Schema.define do
218
- query(query_type)
219
- end
220
- }
221
-
222
- let(:query_string) {<<-GRAPHQL
223
- query testVariables(
224
- $intWithVariable: Int,
225
- $intWithDefault: Int = 10,
226
- $intDefaultNull: Int = null,
227
- $intWithoutVariable: Int,
228
- $complexValWithVariable: ComplexVal,
229
- $complexValWithoutVariable: ComplexVal,
230
- $complexValWithOneDefault: ComplexVal = { val: 10 },
231
- $complexValWithTwoDefaults: ComplexVal = { val: 11, val_with_default: 11 },
232
- $complexValWithNullDefaults: ComplexVal = { val: null, val_with_default: null },
233
- $complexValWithDefaultAndVariable: ComplexVal = { val: 99 },
234
- ) {
235
- aa: variables_test(val: $intWithVariable)
236
- ab: variables_test(val: $intWithoutVariable)
237
- ac: variables_test(val: $intWithDefault)
238
- ad: variables_test(val: $intDefaultNull)
239
-
240
- ba: variables_test(val_with_default: $intWithVariable)
241
- bb: variables_test(val_with_default: $intWithoutVariable)
242
- bc: variables_test(val_with_default: $intWithDefault)
243
- bd: variables_test(val_with_default: $intDefaultNull)
244
-
245
- ca: variables_test(complex_val: { val: $intWithVariable })
246
- cb: variables_test(complex_val: { val: $intWithoutVariable })
247
- cc: variables_test(complex_val: { val: $intWithDefault })
248
- cd: variables_test(complex_val: { val: $intDefaultNull })
249
-
250
- da: variables_test(complex_val: { val_with_default: $intWithVariable })
251
- db: variables_test(complex_val: { val_with_default: $intWithoutVariable })
252
- dc: variables_test(complex_val: { val_with_default: $intWithDefault })
253
- dd: variables_test(complex_val: { val_with_default: $intDefaultNull })
254
-
255
- ea: variables_test(complex_val: $complexValWithVariable)
256
- eb: variables_test(complex_val: $complexValWithoutVariable)
257
- ec: variables_test(complex_val: $complexValWithOneDefault)
258
- ed: variables_test(complex_val: $complexValWithTwoDefaults)
259
- ee: variables_test(complex_val: $complexValWithNullDefaults)
260
- ef: variables_test(complex_val: $complexValWithDefaultAndVariable)
261
- }
262
- GRAPHQL
263
- }
264
-
265
- let(:run_query) { schema.execute(query_string, variables: provided_variables) }
266
-
267
- let(:variables) { GraphQL::Query::Variables.new(
268
- OpenStruct.new({
269
- schema: schema,
270
- warden: GraphQL::Schema::Warden.new(schema.default_mask, schema: schema, context: nil),
271
- }),
272
- ast_variables,
273
- provided_variables)
274
- }
275
-
276
- def assert_has_key_with_value(hash, key, has_key, value)
277
- assert_equal(has_key, hash.key?(key))
278
- assert_equal(value, hash[key])
279
- end
280
-
281
- it "preserves explicit null" do
282
- assert_has_key_with_value(variables, "intWithVariable", true, nil)
283
- run_query
284
- # Provided `nil` should be passed along to args
285
- # and override any defaults (variable defaults and arg defaults)
286
- assert_has_key_with_value(args["aa"], "val", true, nil)
287
- assert_has_key_with_value(args["ba"], "val_with_default", true, nil)
288
- assert_has_key_with_value(args["ca"]["complex_val"], "val", true, nil)
289
- assert_has_key_with_value(args["da"]["complex_val"], "val_with_default", true, nil)
290
- end
291
-
292
- it "doesn't contain variables that weren't present" do
293
- assert_has_key_with_value(variables, "intWithoutVariable", false, nil)
294
- run_query
295
- assert_has_key_with_value(args["ab"], "val", false, nil)
296
- # This one _is_ present, it gets the argument.default_value
297
- assert_has_key_with_value(args["bb"], "val_with_default", true, 13)
298
- assert_has_key_with_value(args["cb"]["complex_val"], "val", false, nil)
299
- # This one _is_ present, it gets the argument.default_value
300
- assert_has_key_with_value(args["db"]["complex_val"], "val_with_default", true, 13)
301
- end
302
-
303
- it "preserves explicit null when variable has a default value" do
304
- assert_has_key_with_value(variables, "intWithDefault", true, nil)
305
- run_query
306
- assert_has_key_with_value(args["ac"], "val", true, nil)
307
- assert_has_key_with_value(args["bc"], "val_with_default", true, nil)
308
- assert_has_key_with_value(args["cc"]["complex_val"], "val", true, nil)
309
- assert_has_key_with_value(args["dc"]["complex_val"], "val_with_default", true, nil)
310
- end
311
-
312
- it "uses null default value" do
313
- assert_has_key_with_value(variables, "intDefaultNull", true, nil)
314
- run_query
315
- assert_has_key_with_value(args["ad"], "val", true, nil)
316
- assert_has_key_with_value(args["bd"], "val_with_default", true, nil)
317
- assert_has_key_with_value(args["cd"]["complex_val"], "val", true, nil)
318
- assert_has_key_with_value(args["dd"]["complex_val"], "val_with_default", true, nil)
319
- end
320
-
321
- it "applies argument default values" do
322
- run_query
323
- # It wasn't present in the query string, but it gets argument.default_value:
324
- assert_has_key_with_value(args["aa"], "val_with_default", true, 13)
325
- end
326
-
327
- it "applies coercion to input objects passed as variables" do
328
- run_query
329
- assert_has_key_with_value(args["ea"]["complex_val"], "val", true, 1)
330
- assert_has_key_with_value(args["ea"]["complex_val"], "val_with_default", true, 2)
331
-
332
- # Since the variable wasn't provided, it's not present at all:
333
- assert_has_key_with_value(args["eb"], "complex_val", false, nil)
334
-
335
- assert_has_key_with_value(args["ec"]["complex_val"], "val", true, 10)
336
- assert_has_key_with_value(args["ec"]["complex_val"], "val_with_default", true, 13)
337
-
338
- assert_has_key_with_value(args["ed"]["complex_val"], "val", true, 11)
339
- assert_has_key_with_value(args["ed"]["complex_val"], "val_with_default", true, 11)
340
-
341
- assert_has_key_with_value(args["ee"]["complex_val"], "val", true, nil)
342
- assert_has_key_with_value(args["ee"]["complex_val"], "val_with_default", true, nil)
343
-
344
- assert_has_key_with_value(args["ef"]["complex_val"], "val", true, 8)
345
- assert_has_key_with_value(args["ef"]["complex_val"], "val_with_default", true, 13)
346
- end
347
- end
348
- end
349
-
350
- if ActionPack::VERSION::MAJOR > 3
351
- describe "with a ActionController::Parameters" do
352
- let(:query_string) { <<-GRAPHQL
353
- query getCheeses($source: DairyAnimal!, $fatContent: Float!){
354
- searchDairy(product: [{source: $source, fatContent: $fatContent}]) {
355
- ... on Cheese { flavor }
356
- }
357
- }
358
- GRAPHQL
359
- }
360
- let(:params) do
361
- ActionController::Parameters.new(
362
- "variables" => {
363
- "source" => "COW",
364
- "fatContent" => 0.4,
365
- }
366
- )
367
- end
368
-
369
- it "works" do
370
- res = schema.execute(query_string, variables: params["variables"])
371
- assert_equal 1, res["data"]["searchDairy"].length
372
- end
373
- end
374
- end
375
- end
@@ -1,309 +0,0 @@
1
- # frozen_string_literal: true
2
- require 'spec_helper'
3
-
4
- describe GraphQL::Relay::ArrayConnection do
5
- def get_names(result)
6
- ships = result["data"]["rebels"]["ships"]["edges"]
7
- ships.map { |e| e["node"]["name"] }
8
- end
9
-
10
- def get_last_cursor(result)
11
- result["data"]["rebels"]["ships"]["edges"].last["cursor"]
12
- end
13
-
14
- def get_page_info(result, key = "bases")
15
- result["data"]["rebels"][key]["pageInfo"]
16
- end
17
-
18
- describe "results" do
19
- let(:query_string) {%|
20
- query getShips($first: Int, $after: String, $last: Int, $before: String, $nameIncludes: String){
21
- rebels {
22
- ships(first: $first, after: $after, last: $last, before: $before, nameIncludes: $nameIncludes) {
23
- edges {
24
- cursor
25
- node {
26
- name
27
- }
28
- }
29
- pageInfo {
30
- hasNextPage
31
- hasPreviousPage
32
- startCursor
33
- endCursor
34
- }
35
- }
36
- }
37
- }
38
- |}
39
-
40
- it 'limits the result' do
41
- result = star_wars_query(query_string, "first" => 2)
42
- number_of_ships = get_names(result).length
43
- assert_equal(2, number_of_ships)
44
- assert_equal(true, result["data"]["rebels"]["ships"]["pageInfo"]["hasNextPage"])
45
- assert_equal(false, result["data"]["rebels"]["ships"]["pageInfo"]["hasPreviousPage"])
46
- assert_equal("MQ", result["data"]["rebels"]["ships"]["pageInfo"]["startCursor"])
47
- assert_equal("Mg", result["data"]["rebels"]["ships"]["pageInfo"]["endCursor"])
48
-
49
- result = star_wars_query(query_string, "first" => 3)
50
- number_of_ships = get_names(result).length
51
- assert_equal(3, number_of_ships)
52
- end
53
-
54
- it 'provides pageInfo' do
55
- result = star_wars_query(query_string, "first" => 2)
56
- assert_equal(true, result["data"]["rebels"]["ships"]["pageInfo"]["hasNextPage"])
57
- assert_equal(false, result["data"]["rebels"]["ships"]["pageInfo"]["hasPreviousPage"])
58
- assert_equal("MQ", result["data"]["rebels"]["ships"]["pageInfo"]["startCursor"])
59
- assert_equal("Mg", result["data"]["rebels"]["ships"]["pageInfo"]["endCursor"])
60
-
61
- result = star_wars_query(query_string, "first" => 100)
62
- assert_equal(false, result["data"]["rebels"]["ships"]["pageInfo"]["hasNextPage"])
63
- assert_equal(false, result["data"]["rebels"]["ships"]["pageInfo"]["hasPreviousPage"])
64
- assert_equal("MQ", result["data"]["rebels"]["ships"]["pageInfo"]["startCursor"])
65
- assert_equal("NQ", result["data"]["rebels"]["ships"]["pageInfo"]["endCursor"])
66
- end
67
-
68
-
69
-
70
- it 'slices the result' do
71
- result = star_wars_query(query_string, "first" => 1)
72
- assert_equal(["X-Wing"], get_names(result))
73
-
74
- # After the last result, find the next 2:
75
- last_cursor = get_last_cursor(result)
76
-
77
- result = star_wars_query(query_string, "after" => last_cursor, "first" => 2)
78
- assert_equal(["Y-Wing", "A-Wing"], get_names(result))
79
-
80
- # After the last result, find the next 2:
81
- last_cursor = get_last_cursor(result)
82
-
83
- result = star_wars_query(query_string, "after" => last_cursor, "first" => 2)
84
- assert_equal(["Millenium Falcon", "Home One"], get_names(result))
85
-
86
- result = star_wars_query(query_string, "before" => last_cursor, "last" => 2)
87
- assert_equal(["X-Wing", "Y-Wing"], get_names(result))
88
-
89
- result = star_wars_query(query_string, "last" => 2)
90
- assert_equal(["Millenium Falcon", "Home One"], get_names(result))
91
-
92
- result = star_wars_query(query_string, "last" => 10)
93
- assert_equal(["X-Wing", "Y-Wing", "A-Wing", "Millenium Falcon", "Home One"], get_names(result))
94
- assert_equal(false, result["data"]["rebels"]["ships"]["pageInfo"]["hasNextPage"])
95
- assert_equal(false, result["data"]["rebels"]["ships"]["pageInfo"]["hasPreviousPage"])
96
- end
97
-
98
- it 'works with before and after specified together' do
99
- result = star_wars_query(query_string, "first" => 1)
100
- assert_equal(["X-Wing"], get_names(result))
101
-
102
- first_cursor = get_last_cursor(result)
103
-
104
- # There is no records between before and after if they point to the same cursor
105
- result = star_wars_query(query_string, "before" => first_cursor, "after" => first_cursor, "last" => 2)
106
- assert_equal([], get_names(result))
107
-
108
- result = star_wars_query(query_string, "after" => first_cursor, "first" => 2)
109
- assert_equal(["Y-Wing", "A-Wing"], get_names(result))
110
-
111
- # After the last result, find the next 2:
112
- second_cursor = get_last_cursor(result)
113
-
114
- # There is only 2 results between the cursors
115
- result = star_wars_query(query_string, "after" => first_cursor, "before" => second_cursor, "first" => 5)
116
- assert_equal(["Y-Wing", "A-Wing"], get_names(result))
117
- end
118
-
119
- it 'handles cursors beyond the bounds of the array' do
120
- overreaching_cursor = Base64.strict_encode64("100")
121
- result = star_wars_query(query_string, "after" => overreaching_cursor, "first" => 2)
122
- assert_equal([], get_names(result))
123
- end
124
-
125
- it 'applies custom arguments' do
126
- result = star_wars_query(query_string, "nameIncludes" => "Wing", "first" => 2)
127
- names = get_names(result)
128
- assert_equal(2, names.length)
129
-
130
- after = get_last_cursor(result)
131
- result = star_wars_query(query_string, "nameIncludes" => "Wing", "after" => after, "first" => 3)
132
- names = get_names(result)
133
- assert_equal(1, names.length)
134
- end
135
-
136
- it 'works without first/last/after/before' do
137
- result = star_wars_query(query_string)
138
-
139
- assert_equal(false, result["data"]["rebels"]["ships"]["pageInfo"]["hasNextPage"])
140
- assert_equal(false, result["data"]["rebels"]["ships"]["pageInfo"]["hasPreviousPage"])
141
- assert_equal("MQ", result["data"]["rebels"]["ships"]["pageInfo"]["startCursor"])
142
- assert_equal("NQ", result["data"]["rebels"]["ships"]["pageInfo"]["endCursor"])
143
- assert_equal(5, result["data"]["rebels"]["ships"]["edges"].length)
144
- end
145
-
146
- describe "applying max_page_size" do
147
- def get_names(result)
148
- result["data"]["rebels"]["bases"]["edges"].map { |e| e["node"]["name"] }
149
- end
150
-
151
- let(:query_string) {%|
152
- query getShips($first: Int, $after: String, $last: Int, $before: String){
153
- rebels {
154
- bases: basesWithMaxLimitArray(first: $first, after: $after, last: $last, before: $before) {
155
- edges {
156
- cursor
157
- node {
158
- name
159
- }
160
- }
161
- pageInfo {
162
- hasNextPage
163
- hasPreviousPage
164
- }
165
- }
166
- }
167
- }
168
- |}
169
-
170
- it "applies to queries by `first`" do
171
- result = star_wars_query(query_string, "first" => 100)
172
- assert_equal(["Yavin", "Echo Base"], get_names(result))
173
- assert_equal(true, get_page_info(result)["hasNextPage"])
174
-
175
- # Max page size is applied _without_ `first`, also
176
- result = star_wars_query(query_string)
177
- assert_equal(["Yavin", "Echo Base"], get_names(result))
178
- assert_equal(false, get_page_info(result)["hasNextPage"], "hasNextPage is false when first is not specified")
179
- end
180
-
181
- it "applies to queries by `last`" do
182
- last_cursor = "Ng=="
183
-
184
- result = star_wars_query(query_string, "last" => 100, "before" => last_cursor)
185
- assert_equal(["Death Star", "Shield Generator"], get_names(result))
186
- assert_equal(true, get_page_info(result)["hasPreviousPage"])
187
-
188
- result = star_wars_query(query_string, "before" => last_cursor)
189
- assert_equal(["Yavin", "Echo Base"], get_names(result))
190
- assert_equal(false, get_page_info(result)["hasPreviousPage"], "hasPreviousPage is false when last is not specified")
191
-
192
- third_cursor = "Mw"
193
- first_and_second_names = ["Yavin", "Echo Base"]
194
- result = star_wars_query(query_string, "last" => 100, "before" => third_cursor)
195
- assert_equal(first_and_second_names, get_names(result))
196
-
197
- result = star_wars_query(query_string, "before" => third_cursor)
198
- assert_equal(first_and_second_names, get_names(result))
199
- end
200
- end
201
-
202
- describe "applying default_max_page_size" do
203
- def get_names(result)
204
- result["data"]["rebels"]["bases"]["edges"].map { |e| e["node"]["name"] }
205
- end
206
-
207
- def get_page_info(result)
208
- result["data"]["rebels"]["bases"]["pageInfo"]
209
- end
210
-
211
- let(:query_string) {%|
212
- query getShips($first: Int, $after: String, $last: Int, $before: String){
213
- rebels {
214
- bases: basesWithDefaultMaxLimitArray(first: $first, after: $after, last: $last, before: $before) {
215
- edges {
216
- cursor
217
- node {
218
- name
219
- }
220
- }
221
- pageInfo {
222
- hasNextPage
223
- hasPreviousPage
224
- }
225
- }
226
- }
227
- }
228
- |}
229
-
230
- it "applies to queries by `first`" do
231
- result = star_wars_query(query_string, "first" => 100)
232
- assert_equal(["Yavin", "Echo Base", "Secret Hideout"], get_names(result))
233
- assert_equal(true, get_page_info(result)["hasNextPage"])
234
-
235
- # Max page size is applied _without_ `first`, also
236
- result = star_wars_query(query_string)
237
- assert_equal(["Yavin", "Echo Base", "Secret Hideout"], get_names(result))
238
- assert_equal(false, get_page_info(result)["hasNextPage"], "hasNextPage is false when first is not specified")
239
- end
240
-
241
- it "applies to queries by `last`" do
242
- last_cursor = "Ng=="
243
-
244
- result = star_wars_query(query_string, "last" => 100, "before" => last_cursor)
245
- assert_equal(["Secret Hideout", "Death Star", "Shield Generator"], get_names(result))
246
- assert_equal(true, get_page_info(result)["hasPreviousPage"])
247
-
248
- result = star_wars_query(query_string, "before" => last_cursor)
249
- assert_equal(["Yavin", "Echo Base", "Secret Hideout"], get_names(result))
250
- assert_equal(false, get_page_info(result)["hasPreviousPage"], "hasPreviousPage is false when last is not specified")
251
-
252
- fourth_cursor = "NA=="
253
- first_second_and_third_names = ["Yavin", "Echo Base", "Secret Hideout"]
254
- result = star_wars_query(query_string, "last" => 100, "before" => fourth_cursor)
255
- assert_equal(first_second_and_third_names, get_names(result))
256
-
257
- result = star_wars_query(query_string, "before" => fourth_cursor)
258
- assert_equal(first_second_and_third_names, get_names(result))
259
- end
260
- end
261
-
262
- describe "bidirectional pagination" do
263
- it "provides bidirectional_pagination" do
264
- result = star_wars_query(query_string, "first" => 1)
265
- last_cursor = get_last_cursor(result)
266
-
267
- # When going forwards, bi-directional pagination
268
- # returns `true` even for `hasPreviousPage`
269
- result = star_wars_query(query_string, "first" => 1, "after" => last_cursor)
270
- assert_equal(true, get_page_info(result, "ships")["hasNextPage"])
271
- assert_equal(false, get_page_info(result, "ships")["hasPreviousPage"])
272
-
273
- result = with_bidirectional_pagination {
274
- star_wars_query(query_string, "first" => 3, "after" => last_cursor)
275
- }
276
- assert_equal(true, get_page_info(result, "ships")["hasNextPage"])
277
- assert_equal(true, get_page_info(result, "ships")["hasPreviousPage"])
278
-
279
- # When going backwards, bi-directional pagination
280
- # returns true for `hasNextPage`
281
- last_cursor = get_last_cursor(result)
282
- result = star_wars_query(query_string, "last" => 1, "before" => last_cursor)
283
- assert_equal(false, get_page_info(result, "ships")["hasNextPage"])
284
- assert_equal(true, get_page_info(result, "ships")["hasPreviousPage"])
285
-
286
- result = with_bidirectional_pagination {
287
- star_wars_query(query_string, "last" => 2, "before" => last_cursor)
288
- }
289
- assert_equal(true, get_page_info(result, "ships")["hasNextPage"])
290
- assert_equal(true, get_page_info(result, "ships")["hasPreviousPage"])
291
- end
292
-
293
- it "returns correct page info when the before cursor belongs to the last element in the array" do
294
- result = with_bidirectional_pagination{
295
- star_wars_query(query_string, "last" => 1)
296
- }
297
-
298
- last_cursor = get_last_cursor(result)
299
-
300
- result = with_bidirectional_pagination{
301
- star_wars_query(query_string, "before" => last_cursor, "last" => 1)
302
- }
303
-
304
- assert_equal(true, get_page_info(result, "ships")["hasNextPage"])
305
- assert_equal(true, get_page_info(result, "ships")["hasPreviousPage"])
306
- end
307
- end
308
- end
309
- end