rails-graphql 0.2.1 → 1.0.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/ext/console.rb +18 -0
- data/ext/extconf.h +3 -0
- data/ext/extconf.rb +1 -54
- data/ext/gql_parser.c +631 -0
- data/ext/gql_parser.h +21 -0
- data/ext/shared.c +477 -0
- data/ext/shared.h +177 -0
- data/lib/generators/graphql/channel_generator.rb +27 -0
- data/lib/generators/graphql/controller_generator.rb +9 -4
- data/lib/generators/graphql/install_generator.rb +49 -0
- data/lib/generators/graphql/schema_generator.rb +9 -4
- data/lib/generators/graphql/templates/channel.erb +7 -0
- data/lib/generators/graphql/templates/config.rb +97 -0
- data/lib/generators/graphql/templates/controller.erb +2 -0
- data/lib/generators/graphql/templates/schema.erb +5 -3
- data/lib/gql_parser.so +0 -0
- data/lib/rails/graphql/adapters/mysql_adapter.rb +59 -0
- data/lib/rails/graphql/adapters/pg_adapter.rb +25 -22
- data/lib/rails/graphql/adapters/sqlite_adapter.rb +17 -14
- data/lib/rails/graphql/alternative/field_set.rb +48 -0
- data/lib/rails/graphql/alternative/mutation.rb +17 -0
- data/lib/rails/graphql/alternative/query.rb +98 -0
- data/lib/rails/graphql/alternative/subscription.rb +18 -0
- data/lib/rails/graphql/alternative.rb +20 -0
- data/lib/rails/graphql/argument.rb +25 -26
- data/lib/rails/graphql/callback.rb +30 -14
- data/lib/rails/graphql/collectors/hash_collector.rb +26 -7
- data/lib/rails/graphql/collectors/idented_collector.rb +10 -7
- data/lib/rails/graphql/collectors/json_collector.rb +43 -17
- data/lib/rails/graphql/collectors.rb +4 -4
- data/lib/rails/graphql/config.rb +154 -23
- data/lib/rails/graphql/directive/cached_directive.rb +33 -0
- data/lib/rails/graphql/directive/deprecated_directive.rb +10 -10
- data/lib/rails/graphql/directive/include_directive.rb +4 -4
- data/lib/rails/graphql/directive/skip_directive.rb +4 -4
- data/lib/rails/graphql/directive/specified_by_directive.rb +24 -0
- data/lib/rails/graphql/directive.rb +134 -73
- data/lib/rails/graphql/errors.rb +33 -4
- data/lib/rails/graphql/event.rb +21 -9
- data/lib/rails/graphql/field/authorized_field.rb +17 -6
- data/lib/rails/graphql/field/input_field.rb +8 -12
- data/lib/rails/graphql/field/mutation_field.rb +43 -9
- data/lib/rails/graphql/field/output_field.rb +112 -12
- data/lib/rails/graphql/field/proxied_field.rb +35 -26
- data/lib/rails/graphql/field/resolved_field.rb +27 -25
- data/lib/rails/graphql/field/scoped_config.rb +10 -4
- data/lib/rails/graphql/field/subscription_field.rb +123 -0
- data/lib/rails/graphql/field/typed_field.rb +69 -24
- data/lib/rails/graphql/field.rb +89 -74
- data/lib/rails/graphql/global_id.rb +89 -0
- data/lib/rails/graphql/helpers/attribute_delegator.rb +5 -5
- data/lib/rails/graphql/helpers/inherited_collection/array.rb +51 -0
- data/lib/rails/graphql/helpers/inherited_collection/base.rb +45 -0
- data/lib/rails/graphql/helpers/inherited_collection/hash.rb +88 -0
- data/lib/rails/graphql/helpers/inherited_collection.rb +25 -76
- data/lib/rails/graphql/helpers/instantiable.rb +15 -0
- data/lib/rails/graphql/helpers/leaf_from_ar.rb +7 -7
- data/lib/rails/graphql/helpers/registerable.rb +44 -62
- data/lib/rails/graphql/helpers/unregisterable.rb +16 -0
- data/lib/rails/graphql/helpers/with_arguments.rb +33 -28
- data/lib/rails/graphql/helpers/with_assignment.rb +6 -6
- data/lib/rails/graphql/helpers/with_callbacks.rb +28 -11
- data/lib/rails/graphql/helpers/with_description.rb +73 -0
- data/lib/rails/graphql/helpers/with_directives.rb +58 -30
- data/lib/rails/graphql/helpers/with_events.rb +22 -23
- data/lib/rails/graphql/helpers/with_fields.rb +86 -26
- data/lib/rails/graphql/helpers/with_global_id.rb +22 -0
- data/lib/rails/graphql/helpers/with_name.rb +44 -0
- data/lib/rails/graphql/helpers/with_namespace.rb +7 -4
- data/lib/rails/graphql/helpers/with_owner.rb +8 -7
- data/lib/rails/graphql/helpers/with_schema_fields.rb +162 -56
- data/lib/rails/graphql/helpers/with_validator.rb +9 -9
- data/lib/rails/graphql/helpers.rb +10 -3
- data/lib/rails/graphql/introspection.rb +43 -36
- data/lib/rails/graphql/railtie.rb +89 -33
- data/lib/rails/graphql/railties/app/base_channel.rb +10 -0
- data/lib/rails/graphql/railties/app/base_controller.rb +12 -0
- data/lib/rails/graphql/railties/app/views/_cable.js.erb +56 -0
- data/lib/rails/graphql/railties/app/views/_fetch.js.erb +20 -0
- data/lib/rails/graphql/railties/app/views/graphiql.html.erb +101 -0
- data/lib/rails/graphql/railties/base_generator.rb +5 -17
- data/lib/rails/graphql/railties/channel.rb +157 -0
- data/lib/rails/graphql/railties/controller.rb +91 -25
- data/lib/rails/graphql/railties/controller_runtime.rb +5 -5
- data/lib/rails/graphql/railties/log_subscriber.rb +81 -14
- data/lib/rails/graphql/request/arguments.rb +26 -50
- data/lib/rails/graphql/request/backtrace.rb +212 -0
- data/lib/rails/graphql/request/component/field.rb +98 -70
- data/lib/rails/graphql/request/component/fragment.rb +80 -26
- data/lib/rails/graphql/request/component/operation/subscription.rb +162 -4
- data/lib/rails/graphql/request/component/operation.rb +73 -34
- data/lib/rails/graphql/request/component/spread.rb +79 -27
- data/lib/rails/graphql/request/component/typename.rb +28 -13
- data/lib/rails/graphql/request/component.rb +77 -36
- data/lib/rails/graphql/request/context.rb +19 -9
- data/lib/rails/graphql/request/errors.rb +16 -6
- data/lib/rails/graphql/request/event.rb +23 -8
- data/lib/rails/graphql/request/helpers/directives.rb +69 -27
- data/lib/rails/graphql/request/helpers/selection_set.rb +57 -25
- data/lib/rails/graphql/request/helpers/value_writers.rb +24 -19
- data/lib/rails/graphql/request/prepared_data.rb +100 -0
- data/lib/rails/graphql/request/steps/authorizable.rb +24 -14
- data/lib/rails/graphql/request/steps/organizable.rb +111 -49
- data/lib/rails/graphql/request/steps/{prepareable.rb → preparable.rb} +21 -8
- data/lib/rails/graphql/request/steps/{resolveable.rb → resolvable.rb} +16 -7
- data/lib/rails/graphql/request/strategy/cached_strategy.rb +64 -0
- data/lib/rails/graphql/request/strategy/dynamic_instance.rb +6 -6
- data/lib/rails/graphql/request/strategy/multi_query_strategy.rb +6 -13
- data/lib/rails/graphql/request/strategy/sequenced_strategy.rb +9 -9
- data/lib/rails/graphql/request/strategy.rb +147 -77
- data/lib/rails/graphql/request/subscription.rb +82 -0
- data/lib/rails/graphql/request.rb +353 -104
- data/lib/rails/graphql/schema.rb +251 -106
- data/lib/rails/graphql/shortcuts.rb +33 -8
- data/lib/rails/graphql/source/active_record/builders.rb +64 -51
- data/lib/rails/graphql/source/active_record_source.rb +158 -82
- data/lib/rails/graphql/source/base.rb +83 -0
- data/lib/rails/graphql/source/builder.rb +115 -0
- data/lib/rails/graphql/source/scoped_arguments.rb +39 -21
- data/lib/rails/graphql/source.rb +90 -228
- data/lib/rails/graphql/subscription/provider/action_cable.rb +113 -0
- data/lib/rails/graphql/subscription/provider/base.rb +192 -0
- data/lib/rails/graphql/subscription/provider.rb +18 -0
- data/lib/rails/graphql/subscription/store/base.rb +141 -0
- data/lib/rails/graphql/subscription/store/memory.rb +136 -0
- data/lib/rails/graphql/subscription/store.rb +19 -0
- data/lib/rails/graphql/subscription.rb +17 -0
- data/lib/rails/graphql/to_gql.rb +29 -32
- data/lib/rails/graphql/type/creator.rb +196 -0
- data/lib/rails/graphql/type/enum/directive_location_enum.rb +11 -11
- data/lib/rails/graphql/type/enum/type_kind_enum.rb +3 -3
- data/lib/rails/graphql/type/enum.rb +44 -50
- data/lib/rails/graphql/type/input.rb +92 -25
- data/lib/rails/graphql/type/interface.rb +29 -28
- data/lib/rails/graphql/type/object/directive_object.rb +10 -9
- data/lib/rails/graphql/type/object/enum_value_object.rb +3 -3
- data/lib/rails/graphql/type/object/field_object.rb +24 -6
- data/lib/rails/graphql/type/object/input_value_object.rb +6 -7
- data/lib/rails/graphql/type/object/schema_object.rb +5 -8
- data/lib/rails/graphql/type/object/type_object.rb +62 -25
- data/lib/rails/graphql/type/object.rb +34 -26
- data/lib/rails/graphql/type/scalar/any_scalar.rb +30 -0
- data/lib/rails/graphql/type/scalar/bigint_scalar.rb +5 -5
- data/lib/rails/graphql/type/scalar/binary_scalar.rb +5 -3
- data/lib/rails/graphql/type/scalar/boolean_scalar.rb +8 -8
- data/lib/rails/graphql/type/scalar/date_scalar.rb +5 -3
- data/lib/rails/graphql/type/scalar/date_time_scalar.rb +5 -3
- data/lib/rails/graphql/type/scalar/decimal_scalar.rb +5 -3
- data/lib/rails/graphql/type/scalar/float_scalar.rb +5 -5
- data/lib/rails/graphql/type/scalar/id_scalar.rb +6 -5
- data/lib/rails/graphql/type/scalar/int_scalar.rb +6 -5
- data/lib/rails/graphql/type/scalar/json_scalar.rb +41 -0
- data/lib/rails/graphql/type/scalar/string_scalar.rb +18 -4
- data/lib/rails/graphql/type/scalar/time_scalar.rb +8 -6
- data/lib/rails/graphql/type/scalar.rb +26 -23
- data/lib/rails/graphql/type/union.rb +21 -18
- data/lib/rails/graphql/type.rb +43 -26
- data/lib/rails/graphql/type_map.rb +268 -165
- data/lib/rails/graphql/uri.rb +167 -0
- data/lib/rails/graphql/version.rb +19 -3
- data/lib/rails/graphql.rake +3 -0
- data/lib/rails/graphql.rb +91 -56
- data/lib/rails-graphql.rb +1 -1
- data/test/assets/en.yml +29 -0
- data/test/assets/introspection-mem.txt +1 -1
- data/test/assets/introspection.gql +2 -0
- data/test/assets/mem.gql +86 -99
- data/test/assets/mysql.gql +406 -0
- data/test/assets/sqlite.gql +96 -73
- data/test/assets/translate.gql +346 -0
- data/test/config.rb +19 -8
- data/test/graphql/schema_test.rb +14 -50
- data/test/graphql/source_test.rb +8 -85
- data/test/graphql/type/enum_test.rb +207 -203
- data/test/graphql/type/input_test.rb +14 -9
- data/test/graphql/type/interface_test.rb +12 -9
- data/test/graphql/type/object_test.rb +8 -2
- data/test/graphql/type/scalar/any_scalar_test.rb +38 -0
- data/test/graphql/type/scalar/boolean_scalar_test.rb +6 -3
- data/test/graphql/type/scalar/json_scalar_test.rb +23 -0
- data/test/graphql/type_map_test.rb +63 -81
- data/test/graphql/type_test.rb +0 -19
- data/test/graphql_test.rb +1 -1
- data/test/integration/{authorization/authorization_test.rb → authorization_test.rb} +40 -14
- data/test/integration/config.rb +36 -3
- data/test/integration/customization_test.rb +39 -0
- data/test/integration/global_id_test.rb +99 -0
- data/test/integration/memory/star_wars_introspection_test.rb +24 -16
- data/test/integration/memory/star_wars_query_test.rb +54 -3
- data/test/integration/memory/star_wars_validation_test.rb +3 -3
- data/test/integration/mysql/star_wars_introspection_test.rb +25 -0
- data/test/integration/persisted_query_test.rb +87 -0
- data/test/integration/resolver_precedence_test.rb +154 -0
- data/test/integration/schemas/memory.rb +24 -10
- data/test/integration/schemas/mysql.rb +62 -0
- data/test/integration/schemas/sqlite.rb +21 -12
- data/test/integration/sqlite/star_wars_global_id_test.rb +89 -0
- data/test/integration/sqlite/star_wars_introspection_test.rb +10 -0
- data/test/integration/sqlite/star_wars_query_test.rb +14 -1
- data/test/integration/translate_test.rb +73 -0
- data/test/test_ext.rb +16 -13
- metadata +125 -161
- data/ext/depend +0 -3
- data/ext/graphqlparser/Ast.cpp +0 -346
- data/ext/graphqlparser/Ast.h +0 -1214
- data/ext/graphqlparser/AstNode.h +0 -36
- data/ext/graphqlparser/AstVisitor.h +0 -137
- data/ext/graphqlparser/GraphQLParser.cpp +0 -76
- data/ext/graphqlparser/GraphQLParser.h +0 -55
- data/ext/graphqlparser/JsonVisitor.cpp +0 -161
- data/ext/graphqlparser/JsonVisitor.cpp.inc +0 -456
- data/ext/graphqlparser/JsonVisitor.h +0 -121
- data/ext/graphqlparser/JsonVisitor.h.inc +0 -110
- data/ext/graphqlparser/VERSION +0 -1
- data/ext/graphqlparser/c/GraphQLAst.cpp +0 -324
- data/ext/graphqlparser/c/GraphQLAst.h +0 -180
- data/ext/graphqlparser/c/GraphQLAstForEachConcreteType.h +0 -44
- data/ext/graphqlparser/c/GraphQLAstNode.cpp +0 -25
- data/ext/graphqlparser/c/GraphQLAstNode.h +0 -33
- data/ext/graphqlparser/c/GraphQLAstToJSON.cpp +0 -21
- data/ext/graphqlparser/c/GraphQLAstToJSON.h +0 -24
- data/ext/graphqlparser/c/GraphQLAstVisitor.cpp +0 -55
- data/ext/graphqlparser/c/GraphQLAstVisitor.h +0 -53
- data/ext/graphqlparser/c/GraphQLParser.cpp +0 -35
- data/ext/graphqlparser/c/GraphQLParser.h +0 -54
- data/ext/graphqlparser/dump_json_ast.cpp +0 -48
- data/ext/graphqlparser/lexer.lpp +0 -324
- data/ext/graphqlparser/parser.ypp +0 -693
- data/ext/graphqlparser/parsergen/lexer.cpp +0 -2633
- data/ext/graphqlparser/parsergen/lexer.h +0 -528
- data/ext/graphqlparser/parsergen/location.hh +0 -189
- data/ext/graphqlparser/parsergen/parser.tab.cpp +0 -3300
- data/ext/graphqlparser/parsergen/parser.tab.hpp +0 -646
- data/ext/graphqlparser/parsergen/position.hh +0 -179
- data/ext/graphqlparser/parsergen/stack.hh +0 -156
- data/ext/graphqlparser/syntaxdefs.h +0 -19
- data/ext/libgraphqlparser/AstNode.h +0 -36
- data/ext/libgraphqlparser/CMakeLists.txt +0 -148
- data/ext/libgraphqlparser/CONTRIBUTING.md +0 -23
- data/ext/libgraphqlparser/GraphQLParser.cpp +0 -76
- data/ext/libgraphqlparser/GraphQLParser.h +0 -55
- data/ext/libgraphqlparser/JsonVisitor.cpp +0 -161
- data/ext/libgraphqlparser/JsonVisitor.h +0 -121
- data/ext/libgraphqlparser/LICENSE +0 -22
- data/ext/libgraphqlparser/README.clang-tidy +0 -7
- data/ext/libgraphqlparser/README.md +0 -84
- data/ext/libgraphqlparser/ast/ast.ast +0 -203
- data/ext/libgraphqlparser/ast/ast.py +0 -61
- data/ext/libgraphqlparser/ast/c.py +0 -100
- data/ext/libgraphqlparser/ast/c.pyc +0 -0
- data/ext/libgraphqlparser/ast/c_impl.py +0 -61
- data/ext/libgraphqlparser/ast/c_impl.pyc +0 -0
- data/ext/libgraphqlparser/ast/c_visitor_impl.py +0 -39
- data/ext/libgraphqlparser/ast/c_visitor_impl.pyc +0 -0
- data/ext/libgraphqlparser/ast/casing.py +0 -26
- data/ext/libgraphqlparser/ast/casing.pyc +0 -0
- data/ext/libgraphqlparser/ast/cxx.py +0 -197
- data/ext/libgraphqlparser/ast/cxx.pyc +0 -0
- data/ext/libgraphqlparser/ast/cxx_impl.py +0 -61
- data/ext/libgraphqlparser/ast/cxx_impl.pyc +0 -0
- data/ext/libgraphqlparser/ast/cxx_json_visitor_header.py +0 -42
- data/ext/libgraphqlparser/ast/cxx_json_visitor_header.pyc +0 -0
- data/ext/libgraphqlparser/ast/cxx_json_visitor_impl.py +0 -80
- data/ext/libgraphqlparser/ast/cxx_json_visitor_impl.pyc +0 -0
- data/ext/libgraphqlparser/ast/cxx_visitor.py +0 -64
- data/ext/libgraphqlparser/ast/cxx_visitor.pyc +0 -0
- data/ext/libgraphqlparser/ast/js.py +0 -65
- data/ext/libgraphqlparser/ast/license.py +0 -10
- data/ext/libgraphqlparser/ast/license.pyc +0 -0
- data/ext/libgraphqlparser/c/GraphQLAstNode.cpp +0 -25
- data/ext/libgraphqlparser/c/GraphQLAstNode.h +0 -33
- data/ext/libgraphqlparser/c/GraphQLAstToJSON.cpp +0 -21
- data/ext/libgraphqlparser/c/GraphQLAstToJSON.h +0 -24
- data/ext/libgraphqlparser/c/GraphQLAstVisitor.cpp +0 -55
- data/ext/libgraphqlparser/c/GraphQLAstVisitor.h +0 -53
- data/ext/libgraphqlparser/c/GraphQLParser.cpp +0 -35
- data/ext/libgraphqlparser/c/GraphQLParser.h +0 -54
- data/ext/libgraphqlparser/clang-tidy-all.sh +0 -3
- data/ext/libgraphqlparser/cmake/version.cmake +0 -16
- data/ext/libgraphqlparser/dump_json_ast.cpp +0 -48
- data/ext/libgraphqlparser/go/README.md +0 -20
- data/ext/libgraphqlparser/go/callbacks.go +0 -18
- data/ext/libgraphqlparser/go/gotest.go +0 -64
- data/ext/libgraphqlparser/lexer.lpp +0 -324
- data/ext/libgraphqlparser/libgraphqlparser.pc.in +0 -11
- data/ext/libgraphqlparser/parser.ypp +0 -693
- data/ext/libgraphqlparser/parsergen/lexer.cpp +0 -2633
- data/ext/libgraphqlparser/parsergen/lexer.h +0 -528
- data/ext/libgraphqlparser/parsergen/location.hh +0 -189
- data/ext/libgraphqlparser/parsergen/parser.tab.cpp +0 -3300
- data/ext/libgraphqlparser/parsergen/parser.tab.hpp +0 -646
- data/ext/libgraphqlparser/parsergen/position.hh +0 -179
- data/ext/libgraphqlparser/parsergen/stack.hh +0 -156
- data/ext/libgraphqlparser/python/CMakeLists.txt +0 -14
- data/ext/libgraphqlparser/python/README.md +0 -5
- data/ext/libgraphqlparser/python/example.py +0 -31
- data/ext/libgraphqlparser/syntaxdefs.h +0 -19
- data/ext/libgraphqlparser/test/BuildCAPI.c +0 -5
- data/ext/libgraphqlparser/test/CMakeLists.txt +0 -25
- data/ext/libgraphqlparser/test/JsonVisitorTests.cpp +0 -28
- data/ext/libgraphqlparser/test/ParserTests.cpp +0 -352
- data/ext/libgraphqlparser/test/kitchen-sink.graphql +0 -59
- data/ext/libgraphqlparser/test/kitchen-sink.json +0 -1
- data/ext/libgraphqlparser/test/schema-kitchen-sink.graphql +0 -78
- data/ext/libgraphqlparser/test/schema-kitchen-sink.json +0 -1
- data/ext/libgraphqlparser/test/valgrind.supp +0 -33
- data/ext/version.cpp +0 -21
- data/lib/graphqlparser.so +0 -0
- data/lib/rails/graphql/native/functions.rb +0 -38
- data/lib/rails/graphql/native/location.rb +0 -41
- data/lib/rails/graphql/native/pointers.rb +0 -23
- data/lib/rails/graphql/native/visitor.rb +0 -349
- data/lib/rails/graphql/native.rb +0 -56
- data/test/integration/schemas/authorization.rb +0 -12
@@ -0,0 +1,89 @@
|
|
1
|
+
require 'integration/config'
|
2
|
+
|
3
|
+
class Integration_SQLite_StarWarsGlobalIDTest < GraphQL::IntegrationTestCase
|
4
|
+
load_schema 'sqlite'
|
5
|
+
|
6
|
+
SCHEMA = ::StartWarsSqliteSchema
|
7
|
+
|
8
|
+
## CREATE
|
9
|
+
|
10
|
+
def test_create_query_field
|
11
|
+
obj = source[:query][:lite_factions]
|
12
|
+
assert_gid_value('gql://star-wars-sqlite/Schema/query/liteFactions', obj)
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_create_object
|
16
|
+
obj = source.object
|
17
|
+
assert_gid_value('gql://star-wars-sqlite/Type/LiteFaction', obj)
|
18
|
+
end
|
19
|
+
|
20
|
+
def test_create_input
|
21
|
+
obj = source.input
|
22
|
+
assert_gid_value('gql://star-wars-sqlite/Type/LiteFactionInput', obj)
|
23
|
+
|
24
|
+
obj = source.input.deserialize(nil)
|
25
|
+
assert_gid_value('gql://star-wars-sqlite/Type/LiteFactionInput?', obj)
|
26
|
+
|
27
|
+
params = { name: 'Sample' }
|
28
|
+
obj = source.input.deserialize(params)
|
29
|
+
assert_gid_value('gql://star-wars-sqlite/Type/LiteFactionInput?name=Sample', obj)
|
30
|
+
|
31
|
+
params = { name: 'Sample', bases_attributes: [{ name: 'Other' }] }
|
32
|
+
obj = source.input.deserialize(params)
|
33
|
+
assert_gid_value('gql://star-wars-sqlite/Type/LiteFactionInput?basesAttributes[][name]=Other&name=Sample', obj)
|
34
|
+
end
|
35
|
+
|
36
|
+
def test_create_object_field
|
37
|
+
obj = source.object[:name]
|
38
|
+
assert_gid_value('gql://star-wars-sqlite/LiteFaction/name', obj)
|
39
|
+
end
|
40
|
+
|
41
|
+
def assert_gid_value(result, object)
|
42
|
+
assert_equal(result.gsub(/\[|\]/, { '[' => '%5B', ']' => '%5D' }), object.to_gid.to_s)
|
43
|
+
end
|
44
|
+
|
45
|
+
## PARSE
|
46
|
+
|
47
|
+
def test_parse_query_field
|
48
|
+
obj = find_gid('gql://star-wars-sqlite/Schema/query/liteFactions')
|
49
|
+
assert_equal(source[:query][:lite_factions], obj.proxied_field)
|
50
|
+
end
|
51
|
+
|
52
|
+
def test_parse_object
|
53
|
+
obj = find_gid('gql://star-wars-sqlite/Type/LiteFaction')
|
54
|
+
assert_equal(source.object, obj)
|
55
|
+
end
|
56
|
+
|
57
|
+
def test_parse_input
|
58
|
+
obj = find_gid('gql://star-wars-sqlite/Type/LiteFactionInput')
|
59
|
+
assert_equal(source.input, obj)
|
60
|
+
|
61
|
+
obj = find_gid('gql://star-wars-sqlite/Type/LiteFactionInput?')
|
62
|
+
assert_instance_of(source.input, obj)
|
63
|
+
assert_empty(obj.params)
|
64
|
+
|
65
|
+
obj = find_gid('gql://star-wars-sqlite/Type/LiteFactionInput?name=Sample')
|
66
|
+
assert_instance_of(source.input, obj)
|
67
|
+
assert_equal('Sample', obj.params[:name])
|
68
|
+
|
69
|
+
obj = find_gid('gql://star-wars-sqlite/Type/LiteFactionInput?bases_attributes[][name]=Other&name=Sample')
|
70
|
+
assert_instance_of(source.input, obj)
|
71
|
+
assert_equal([{name: 'Other'}], obj.params[:bases_attributes])
|
72
|
+
assert_equal('Sample', obj.params[:name])
|
73
|
+
end
|
74
|
+
|
75
|
+
def test_parse_object_field
|
76
|
+
obj = find_gid('gql://star-wars-sqlite/LiteFaction/name')
|
77
|
+
assert_equal(source.object[:name], obj)
|
78
|
+
end
|
79
|
+
|
80
|
+
protected
|
81
|
+
|
82
|
+
def find_gid(gid)
|
83
|
+
GraphQL::GlobalID.find(gid)
|
84
|
+
end
|
85
|
+
|
86
|
+
def source
|
87
|
+
StartWarsSqliteSchema::NestedTypes::LiteFactionSource
|
88
|
+
end
|
89
|
+
end
|
@@ -5,6 +5,16 @@ class Integration_SQLite_StarWarsIntrospectionTest < GraphQL::IntegrationTestCas
|
|
5
5
|
|
6
6
|
SCHEMA = ::StartWarsSqliteSchema
|
7
7
|
|
8
|
+
def test_auto_introspection
|
9
|
+
assert(SCHEMA.introspection?)
|
10
|
+
assert(SCHEMA.has_field?(:query, :__schema))
|
11
|
+
assert(SCHEMA.has_field?(:query, :__type))
|
12
|
+
end
|
13
|
+
|
14
|
+
# Test this spec with all available scalars
|
15
|
+
def remove_keys_form_type_map
|
16
|
+
end
|
17
|
+
|
8
18
|
# There are some issues with the end sorting, so compare the string result
|
9
19
|
# with sorted characters, which will produce the exact match
|
10
20
|
def test_gql_introspection
|
@@ -52,7 +52,7 @@ class Integration_SQLite_StarWarsQueryTest < GraphQL::IntegrationTestCase
|
|
52
52
|
GQL
|
53
53
|
end
|
54
54
|
|
55
|
-
def
|
55
|
+
def test_data_recursion
|
56
56
|
faction = { name: 'Galactic Empire' }
|
57
57
|
bases = named_list('Death Star', 'Shield Generator', 'Headquarters', faction: faction.dup)
|
58
58
|
faction[:bases] = bases
|
@@ -68,4 +68,17 @@ class Integration_SQLite_StarWarsQueryTest < GraphQL::IntegrationTestCase
|
|
68
68
|
query AllFactions($order: String!) { liteFactions(order: $order) { name } }
|
69
69
|
GQL
|
70
70
|
end
|
71
|
+
|
72
|
+
def test_bases_scoped_argument_with_default
|
73
|
+
bases = named_list('Death Star', 'Echo Base', 'Headquarters', 'Secret Hideout',
|
74
|
+
'Shield Generator', 'Yavin')
|
75
|
+
|
76
|
+
assert_result({ data: { liteBases: bases.reverse } }, <<~GQL)
|
77
|
+
query AllBases { liteBases { name } }
|
78
|
+
GQL
|
79
|
+
|
80
|
+
assert_result({ data: { liteBases: bases } }, <<~GQL, args: { order: 'asc' })
|
81
|
+
query AllBases($order: String!) { liteBases(order: $order) { name } }
|
82
|
+
GQL
|
83
|
+
end
|
71
84
|
end
|
@@ -0,0 +1,73 @@
|
|
1
|
+
require 'integration/config'
|
2
|
+
|
3
|
+
class Translate_test < GraphQL::IntegrationTestCase
|
4
|
+
class SCHEMA < GraphQL::Schema
|
5
|
+
namespace :translate
|
6
|
+
|
7
|
+
configure do |config|
|
8
|
+
config.enable_string_collector = false
|
9
|
+
config.default_response_format = :json
|
10
|
+
end
|
11
|
+
|
12
|
+
query_fields do
|
13
|
+
field :sample_field, :string
|
14
|
+
field :sample_a, :string
|
15
|
+
field :sample_b, :string
|
16
|
+
field :sample_c, :string
|
17
|
+
field :sample_d, :string
|
18
|
+
field :sample_e, :string
|
19
|
+
field :sample_f, :string
|
20
|
+
end
|
21
|
+
|
22
|
+
enum :enum_desc
|
23
|
+
interface :interface_desc
|
24
|
+
object :object_desc
|
25
|
+
union :union_desc
|
26
|
+
input :input_desc
|
27
|
+
scalar :scalar_desc
|
28
|
+
end
|
29
|
+
|
30
|
+
def setup
|
31
|
+
$config.enable_i18n_descriptions = true
|
32
|
+
end
|
33
|
+
|
34
|
+
def teardown
|
35
|
+
$config.enable_i18n_descriptions = false
|
36
|
+
end
|
37
|
+
|
38
|
+
def test_simple_translate
|
39
|
+
skip 'Fix for new I18n structure'
|
40
|
+
assert_equal('Field', SCHEMA[:query][:sample_field].description)
|
41
|
+
assert_equal('Enum', GraphQL::EnumDescEnum.description)
|
42
|
+
assert_equal('Interface', GraphQL::InterfaceDescInterface.description)
|
43
|
+
assert_equal('Object', GraphQL::ObjectDescObject.description)
|
44
|
+
assert_equal('Union', GraphQL::UnionDescUnion.description)
|
45
|
+
assert_equal('Input', GraphQL::InputDescInput.description)
|
46
|
+
assert_equal('Scalar', GraphQL::ScalarDescScalar.description)
|
47
|
+
end
|
48
|
+
|
49
|
+
def test_all_levels_translate_fields
|
50
|
+
skip 'Fix for new I18n structure'
|
51
|
+
assert_equal('A', SCHEMA[:query][:sample_a].description)
|
52
|
+
assert_equal('B', SCHEMA[:query][:sample_b].description)
|
53
|
+
assert_equal('C', SCHEMA[:query][:sample_c].description)
|
54
|
+
assert_equal('D', SCHEMA[:query][:sample_d].description)
|
55
|
+
assert_equal('E', SCHEMA[:query][:sample_e].description)
|
56
|
+
assert_equal('F', SCHEMA[:query][:sample_f].description)
|
57
|
+
end
|
58
|
+
|
59
|
+
def test_request_translate
|
60
|
+
skip 'Fix for new I18n structure'
|
61
|
+
result = { data: { __type: { name: 'InterfaceDesc', description: 'Interface' } } }
|
62
|
+
assert_result(result, '{ __type(name: "InterfaceDesc") { name description } }')
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_gql_introspection
|
66
|
+
skip 'Fix for new I18n structure'
|
67
|
+
result = SCHEMA.to_gql
|
68
|
+
expected = gql_file('translate').split('').sort.join.squish
|
69
|
+
|
70
|
+
# File.write('test/assets/translate.gql', result)
|
71
|
+
assert_equal(expected, result.split('').sort.join.squish)
|
72
|
+
end
|
73
|
+
end
|
data/test/test_ext.rb
CHANGED
@@ -28,17 +28,16 @@ class Object < BasicObject
|
|
28
28
|
const_set(name, old_value) if defined? old_value
|
29
29
|
end
|
30
30
|
|
31
|
-
def stub_imethod(name,
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
end
|
31
|
+
def stub_imethod(name, block)
|
32
|
+
alias_method(:"_old_#{name}", name) if (reset_old = method_defined?(name))
|
33
|
+
define_method(name, &block)
|
34
|
+
yield
|
35
|
+
ensure
|
36
|
+
undef_method(name)
|
37
|
+
|
38
|
+
if reset_old
|
39
|
+
alias_method(name, :"_old_#{name}")
|
40
|
+
undef_method(:"_old_#{name}")
|
42
41
|
end
|
43
42
|
end
|
44
43
|
|
@@ -46,8 +45,10 @@ class Object < BasicObject
|
|
46
45
|
instance_variable_set(name, extra.first) if extra.any?
|
47
46
|
instance_exec(&block)
|
48
47
|
|
48
|
+
return unless instance_variable_defined?(name)
|
49
|
+
|
49
50
|
instance_variable_get(name).tap do
|
50
|
-
remove_instance_variable(name)
|
51
|
+
remove_instance_variable(name)
|
51
52
|
end
|
52
53
|
end
|
53
54
|
|
@@ -55,8 +56,10 @@ class Object < BasicObject
|
|
55
56
|
class_variable_set(name, extra.first) if extra.any?
|
56
57
|
instance_exec(&block)
|
57
58
|
|
59
|
+
return unless class_variable_defined?(name)
|
60
|
+
|
58
61
|
class_variable_get(name).tap do
|
59
|
-
remove_class_variable(name)
|
62
|
+
remove_class_variable(name)
|
60
63
|
end
|
61
64
|
end
|
62
65
|
end
|