deimos-ruby 1.16.1 → 1.16.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/CHANGELOG.md +13 -0
- data/Gemfile +6 -0
- data/README.md +22 -0
- data/lib/deimos/active_record_consume/batch_consumption.rb +7 -2
- data/lib/deimos/active_record_consume/batch_slicer.rb +2 -0
- data/lib/deimos/active_record_consume/message_consumption.rb +8 -4
- data/lib/deimos/active_record_consumer.rb +7 -4
- data/lib/deimos/active_record_producer.rb +10 -0
- data/lib/deimos/backends/base.rb +4 -2
- data/lib/deimos/backends/kafka.rb +1 -0
- data/lib/deimos/backends/kafka_async.rb +1 -0
- data/lib/deimos/config/configuration.rb +4 -0
- data/lib/deimos/config/phobos_config.rb +2 -1
- data/lib/deimos/consume/batch_consumption.rb +8 -1
- data/lib/deimos/consume/message_consumption.rb +4 -1
- data/lib/deimos/instrumentation.rb +11 -4
- data/lib/deimos/kafka_message.rb +1 -0
- data/lib/deimos/kafka_source.rb +5 -0
- data/lib/deimos/kafka_topic_info.rb +4 -0
- data/lib/deimos/message.rb +19 -2
- data/lib/deimos/metrics/datadog.rb +2 -1
- data/lib/deimos/metrics/mock.rb +2 -2
- data/lib/deimos/metrics/provider.rb +6 -0
- data/lib/deimos/monkey_patches/phobos_cli.rb +1 -1
- data/lib/deimos/monkey_patches/phobos_producer.rb +1 -0
- data/lib/deimos/producer.rb +12 -6
- data/lib/deimos/schema_backends/base.rb +31 -17
- data/lib/deimos/schema_backends/mock.rb +2 -2
- data/lib/deimos/schema_class/base.rb +9 -5
- data/lib/deimos/schema_class/enum.rb +4 -2
- data/lib/deimos/schema_class/record.rb +12 -6
- data/lib/deimos/shared_config.rb +6 -2
- data/lib/deimos/test_helpers.rb +21 -4
- data/lib/deimos/tracing/datadog.rb +1 -1
- data/lib/deimos/tracing/mock.rb +4 -3
- data/lib/deimos/tracing/provider.rb +5 -0
- data/lib/deimos/utils/db_poller.rb +9 -1
- data/lib/deimos/utils/db_producer.rb +14 -2
- data/lib/deimos/utils/deadlock_retry.rb +3 -0
- data/lib/deimos/utils/inline_consumer.rb +14 -6
- data/lib/deimos/utils/lag_reporter.rb +11 -0
- data/lib/deimos/utils/schema_controller_mixin.rb +8 -0
- data/lib/deimos/version.rb +1 -1
- data/lib/deimos.rb +3 -2
- data/lib/generators/deimos/active_record_generator.rb +1 -1
- data/lib/generators/deimos/db_backend_generator.rb +1 -0
- data/lib/generators/deimos/db_poller_generator.rb +1 -0
- data/lib/generators/deimos/schema_class/templates/schema_record.rb.tt +13 -5
- data/lib/generators/deimos/schema_class_generator.rb +51 -24
- data/rbs_collection.lock.yaml +176 -0
- data/rbs_collection.yaml +15 -0
- data/regenerate_test_schema_classes.rb +68 -0
- data/sig/avro.rbs +14 -0
- data/sig/defs.rbs +1859 -0
- data/sig/fig_tree.rbs +2 -0
- data/spec/active_record_producer_spec.rb +24 -0
- data/spec/generators/schema_class/my_schema_spec.rb +16 -0
- data/spec/generators/schema_class/my_schema_with_circular_reference_spec.rb +1 -1
- data/spec/generators/schema_class/my_schema_with_complex_types_spec.rb +32 -24
- data/spec/producer_spec.rb +11 -11
- data/spec/schemas/{generated.rb → my_namespace/generated.rb} +28 -32
- data/spec/schemas/{my_nested_schema.rb → my_namespace/my_nested_schema.rb} +23 -16
- data/spec/schemas/{my_schema.rb → my_namespace/my_schema.rb} +12 -5
- data/spec/schemas/my_namespace/my_schema_compound_key.rb +41 -0
- data/spec/schemas/my_namespace/my_schema_id_key.rb +36 -0
- data/spec/schemas/{my_schema_key.rb → my_namespace/my_schema_key.rb} +3 -3
- data/spec/schemas/my_namespace/my_schema_with_boolean.rb +41 -0
- data/spec/schemas/{my_schema_with_circular_reference.rb → my_namespace/my_schema_with_circular_reference.rb} +15 -10
- data/spec/schemas/{my_schema_with_complex_type.rb → my_namespace/my_schema_with_complex_type.rb} +34 -49
- data/spec/schemas/my_namespace/my_schema_with_date_time.rb +56 -0
- data/spec/schemas/my_namespace/my_schema_with_id.rb +51 -0
- data/spec/schemas/my_namespace/my_schema_with_unique_id.rb +56 -0
- data/spec/schemas/my_namespace/wibble.rb +76 -0
- data/spec/schemas/my_namespace/widget.rb +56 -0
- data/spec/schemas/my_namespace/widget_the_second.rb +56 -0
- data/spec/schemas/request/create_topic.rb +36 -0
- data/spec/schemas/request/index.rb +36 -0
- data/spec/schemas/request/update_request.rb +36 -0
- data/spec/schemas/response/create_topic.rb +36 -0
- data/spec/schemas/response/index.rb +36 -0
- data/spec/schemas/response/update_response.rb +36 -0
- data/spec/snapshots/consumers-no-nest.snap +93 -86
- data/spec/snapshots/consumers.snap +94 -87
- data/spec/snapshots/consumers_and_producers-no-nest.snap +108 -87
- data/spec/snapshots/consumers_and_producers.snap +109 -88
- data/spec/snapshots/consumers_circular-no-nest.snap +93 -86
- data/spec/snapshots/consumers_circular.snap +94 -87
- data/spec/snapshots/consumers_complex_types-no-nest.snap +93 -86
- data/spec/snapshots/consumers_complex_types.snap +94 -87
- data/spec/snapshots/consumers_nested-no-nest.snap +93 -86
- data/spec/snapshots/consumers_nested.snap +94 -87
- data/spec/snapshots/namespace_folders.snap +111 -90
- data/spec/snapshots/producers_with_key-no-nest.snap +94 -87
- data/spec/snapshots/producers_with_key.snap +95 -88
- data/spec/spec_helper.rb +2 -1
- metadata +53 -15
@@ -8,7 +8,7 @@ module Schemas
|
|
8
8
|
class CreateTopic < Deimos::SchemaClass::Record
|
9
9
|
|
10
10
|
### Attribute Accessors ###
|
11
|
-
# @
|
11
|
+
# @return [String]
|
12
12
|
attr_accessor :response_id
|
13
13
|
|
14
14
|
# @override
|
@@ -51,7 +51,7 @@ module Schemas
|
|
51
51
|
class ARecord < Deimos::SchemaClass::Record
|
52
52
|
|
53
53
|
### Attribute Accessors ###
|
54
|
-
# @
|
54
|
+
# @return [String]
|
55
55
|
attr_accessor :a_record_field
|
56
56
|
|
57
57
|
# @override
|
@@ -97,34 +97,34 @@ module Schemas
|
|
97
97
|
attr_reader :a_record
|
98
98
|
|
99
99
|
### Attribute Accessors ###
|
100
|
-
# @
|
100
|
+
# @return [String]
|
101
101
|
attr_accessor :a_string
|
102
|
-
# @
|
102
|
+
# @return [Integer]
|
103
103
|
attr_accessor :a_int
|
104
|
-
# @
|
104
|
+
# @return [Integer]
|
105
105
|
attr_accessor :a_long
|
106
|
-
# @
|
106
|
+
# @return [Float]
|
107
107
|
attr_accessor :a_float
|
108
|
-
# @
|
108
|
+
# @return [Float]
|
109
109
|
attr_accessor :a_double
|
110
|
-
# @
|
110
|
+
# @return [nil, Integer]
|
111
111
|
attr_accessor :an_optional_int
|
112
|
-
# @
|
112
|
+
# @return [Array<Integer>]
|
113
113
|
attr_accessor :an_array
|
114
|
-
# @
|
114
|
+
# @return [Hash<String, String>]
|
115
115
|
attr_accessor :a_map
|
116
|
-
# @
|
116
|
+
# @return [String]
|
117
117
|
attr_accessor :timestamp
|
118
|
-
# @
|
118
|
+
# @return [String]
|
119
119
|
attr_accessor :message_id
|
120
120
|
|
121
121
|
### Attribute Writers ###
|
122
|
-
# @
|
122
|
+
# @return [AnEnum]
|
123
123
|
def an_enum=(value)
|
124
124
|
@an_enum = AnEnum.initialize_from_value(value)
|
125
125
|
end
|
126
126
|
|
127
|
-
# @
|
127
|
+
# @return [ARecord]
|
128
128
|
def a_record=(value)
|
129
129
|
@a_record = ARecord.initialize_from_value(value)
|
130
130
|
end
|
@@ -198,7 +198,7 @@ module Schemas
|
|
198
198
|
class Index < Deimos::SchemaClass::Record
|
199
199
|
|
200
200
|
### Attribute Accessors ###
|
201
|
-
# @
|
201
|
+
# @return [String]
|
202
202
|
attr_accessor :response_id
|
203
203
|
|
204
204
|
# @override
|
@@ -241,13 +241,13 @@ module Schemas
|
|
241
241
|
class MyNestedRecord < Deimos::SchemaClass::Record
|
242
242
|
|
243
243
|
### Attribute Accessors ###
|
244
|
-
# @
|
244
|
+
# @return [Integer]
|
245
245
|
attr_accessor :some_int
|
246
|
-
# @
|
246
|
+
# @return [Float]
|
247
247
|
attr_accessor :some_float
|
248
|
-
# @
|
248
|
+
# @return [String]
|
249
249
|
attr_accessor :some_string
|
250
|
-
# @
|
250
|
+
# @return [nil, Integer]
|
251
251
|
attr_accessor :some_optional_int
|
252
252
|
|
253
253
|
# @override
|
@@ -291,20 +291,20 @@ module Schemas
|
|
291
291
|
attr_reader :some_optional_record
|
292
292
|
|
293
293
|
### Attribute Accessors ###
|
294
|
-
# @
|
294
|
+
# @return [String]
|
295
295
|
attr_accessor :test_id
|
296
|
-
# @
|
296
|
+
# @return [Float]
|
297
297
|
attr_accessor :test_float
|
298
|
-
# @
|
298
|
+
# @return [Array<String>]
|
299
299
|
attr_accessor :test_array
|
300
300
|
|
301
301
|
### Attribute Writers ###
|
302
|
-
# @
|
302
|
+
# @return [MyNestedRecord]
|
303
303
|
def some_nested_record=(value)
|
304
304
|
@some_nested_record = MyNestedRecord.initialize_from_value(value)
|
305
305
|
end
|
306
306
|
|
307
|
-
# @
|
307
|
+
# @return [nil, MyNestedRecord]
|
308
308
|
def some_optional_record=(value)
|
309
309
|
@some_optional_record = MyNestedRecord.initialize_from_value(value)
|
310
310
|
end
|
@@ -361,13 +361,13 @@ module Schemas
|
|
361
361
|
attr_reader :payload_key
|
362
362
|
|
363
363
|
### Attribute Accessors ###
|
364
|
-
# @
|
364
|
+
# @return [String]
|
365
365
|
attr_accessor :test_id
|
366
|
-
# @
|
366
|
+
# @return [Integer]
|
367
367
|
attr_accessor :some_int
|
368
368
|
|
369
369
|
### Attribute Writers ###
|
370
|
-
# @
|
370
|
+
# @return [MySchemaKey]
|
371
371
|
def payload_key=(value)
|
372
372
|
@payload_key = MySchemaKey.initialize_from_value(value)
|
373
373
|
end
|
@@ -392,6 +392,13 @@ module Schemas
|
|
392
392
|
'com.my-namespace'
|
393
393
|
end
|
394
394
|
|
395
|
+
def self.tombstone(key)
|
396
|
+
record = self.allocate
|
397
|
+
record.tombstone_key = MySchemaKey.initialize_from_value(key)
|
398
|
+
record.payload_key = key
|
399
|
+
record
|
400
|
+
end
|
401
|
+
|
395
402
|
# @override
|
396
403
|
def as_json(_opts={})
|
397
404
|
{
|
@@ -414,9 +421,9 @@ module Schemas
|
|
414
421
|
class MySchemaCompoundKey < Deimos::SchemaClass::Record
|
415
422
|
|
416
423
|
### Attribute Accessors ###
|
417
|
-
# @
|
424
|
+
# @return [String]
|
418
425
|
attr_accessor :part_one
|
419
|
-
# @
|
426
|
+
# @return [String]
|
420
427
|
attr_accessor :part_two
|
421
428
|
|
422
429
|
# @override
|
@@ -458,7 +465,7 @@ module Schemas
|
|
458
465
|
class MySchemaIdKey < Deimos::SchemaClass::Record
|
459
466
|
|
460
467
|
### Attribute Accessors ###
|
461
|
-
# @
|
468
|
+
# @return [Integer]
|
462
469
|
attr_accessor :id
|
463
470
|
|
464
471
|
# @override
|
@@ -497,7 +504,7 @@ module Schemas
|
|
497
504
|
class MySchemaKey < Deimos::SchemaClass::Record
|
498
505
|
|
499
506
|
### Attribute Accessors ###
|
500
|
-
# @
|
507
|
+
# @return [String]
|
501
508
|
attr_accessor :test_id
|
502
509
|
|
503
510
|
# @override
|
@@ -536,9 +543,9 @@ module Schemas
|
|
536
543
|
class MySchemaWithBoolean < Deimos::SchemaClass::Record
|
537
544
|
|
538
545
|
### Attribute Accessors ###
|
539
|
-
# @
|
546
|
+
# @return [String]
|
540
547
|
attr_accessor :test_id
|
541
|
-
# @
|
548
|
+
# @return [Boolean]
|
542
549
|
attr_accessor :some_bool
|
543
550
|
|
544
551
|
# @override
|
@@ -584,7 +591,7 @@ module Schemas
|
|
584
591
|
class Property < Deimos::SchemaClass::Record
|
585
592
|
|
586
593
|
### Attribute Accessors ###
|
587
|
-
# @
|
594
|
+
# @return [Boolean, Integer, Integer, Float, Float, String, Array<Property>, Hash<String, Property>]
|
588
595
|
attr_accessor :property
|
589
596
|
|
590
597
|
# @override
|
@@ -617,9 +624,9 @@ module Schemas
|
|
617
624
|
attr_reader :properties
|
618
625
|
|
619
626
|
### Attribute Writers ###
|
620
|
-
# @
|
627
|
+
# @return [Hash<String, Property>]
|
621
628
|
def properties=(values)
|
622
|
-
@properties = values
|
629
|
+
@properties = values&.transform_values do |value|
|
623
630
|
Property.initialize_from_value(value)
|
624
631
|
end
|
625
632
|
end
|
@@ -664,7 +671,7 @@ module Schemas
|
|
664
671
|
class ARecord < Deimos::SchemaClass::Record
|
665
672
|
|
666
673
|
### Attribute Accessors ###
|
667
|
-
# @
|
674
|
+
# @return [String]
|
668
675
|
attr_accessor :a_record_field
|
669
676
|
|
670
677
|
# @override
|
@@ -742,57 +749,57 @@ module Schemas
|
|
742
749
|
attr_reader :some_enum_with_default
|
743
750
|
|
744
751
|
### Attribute Accessors ###
|
745
|
-
# @
|
752
|
+
# @return [String]
|
746
753
|
attr_accessor :test_id
|
747
|
-
# @
|
754
|
+
# @return [Float]
|
748
755
|
attr_accessor :test_float
|
749
|
-
# @
|
756
|
+
# @return [Array<String>]
|
750
757
|
attr_accessor :test_string_array
|
751
|
-
# @
|
758
|
+
# @return [Array<Integer>]
|
752
759
|
attr_accessor :test_int_array
|
753
|
-
# @
|
760
|
+
# @return [Integer, nil]
|
754
761
|
attr_accessor :test_optional_int
|
755
|
-
# @
|
762
|
+
# @return [Hash<String, Integer>]
|
756
763
|
attr_accessor :some_integer_map
|
757
764
|
|
758
765
|
### Attribute Writers ###
|
759
|
-
# @
|
766
|
+
# @return [ARecord]
|
760
767
|
def some_record=(value)
|
761
768
|
@some_record = ARecord.initialize_from_value(value)
|
762
769
|
end
|
763
770
|
|
764
|
-
# @
|
771
|
+
# @return [nil, ARecord]
|
765
772
|
def some_optional_record=(value)
|
766
773
|
@some_optional_record = ARecord.initialize_from_value(value)
|
767
774
|
end
|
768
775
|
|
769
|
-
# @
|
776
|
+
# @return [Array<ARecord>]
|
770
777
|
def some_record_array=(values)
|
771
|
-
@some_record_array = values
|
778
|
+
@some_record_array = values&.map do |value|
|
772
779
|
ARecord.initialize_from_value(value)
|
773
780
|
end
|
774
781
|
end
|
775
782
|
|
776
|
-
# @
|
783
|
+
# @return [Hash<String, ARecord>]
|
777
784
|
def some_record_map=(values)
|
778
|
-
@some_record_map = values
|
785
|
+
@some_record_map = values&.transform_values do |value|
|
779
786
|
ARecord.initialize_from_value(value)
|
780
787
|
end
|
781
788
|
end
|
782
789
|
|
783
|
-
# @
|
790
|
+
# @return [Array<AnEnum>]
|
784
791
|
def some_enum_array=(values)
|
785
|
-
@some_enum_array = values
|
792
|
+
@some_enum_array = values&.map do |value|
|
786
793
|
AnEnum.initialize_from_value(value)
|
787
794
|
end
|
788
795
|
end
|
789
796
|
|
790
|
-
# @
|
797
|
+
# @return [nil, AnotherEnum]
|
791
798
|
def some_optional_enum=(value)
|
792
799
|
@some_optional_enum = AnotherEnum.initialize_from_value(value)
|
793
800
|
end
|
794
801
|
|
795
|
-
# @
|
802
|
+
# @return [YetAnotherEnum]
|
796
803
|
def some_enum_with_default=(value)
|
797
804
|
@some_enum_with_default = YetAnotherEnum.initialize_from_value(value)
|
798
805
|
end
|
@@ -869,15 +876,15 @@ module Schemas
|
|
869
876
|
class MySchemaWithDateTime < Deimos::SchemaClass::Record
|
870
877
|
|
871
878
|
### Attribute Accessors ###
|
872
|
-
# @
|
879
|
+
# @return [String]
|
873
880
|
attr_accessor :test_id
|
874
|
-
# @
|
881
|
+
# @return [Integer, nil]
|
875
882
|
attr_accessor :updated_at
|
876
|
-
# @
|
883
|
+
# @return [nil, Integer]
|
877
884
|
attr_accessor :some_int
|
878
|
-
# @
|
885
|
+
# @return [nil, Integer]
|
879
886
|
attr_accessor :some_datetime_int
|
880
|
-
# @
|
887
|
+
# @return [String]
|
881
888
|
attr_accessor :timestamp
|
882
889
|
|
883
890
|
# @override
|
@@ -928,13 +935,13 @@ module Schemas
|
|
928
935
|
class MySchemaWithId < Deimos::SchemaClass::Record
|
929
936
|
|
930
937
|
### Attribute Accessors ###
|
931
|
-
# @
|
938
|
+
# @return [String]
|
932
939
|
attr_accessor :test_id
|
933
|
-
# @
|
940
|
+
# @return [Integer]
|
934
941
|
attr_accessor :some_int
|
935
|
-
# @
|
942
|
+
# @return [String]
|
936
943
|
attr_accessor :message_id
|
937
|
-
# @
|
944
|
+
# @return [String]
|
938
945
|
attr_accessor :timestamp
|
939
946
|
|
940
947
|
# @override
|
@@ -982,15 +989,15 @@ module Schemas
|
|
982
989
|
class MySchemaWithUniqueId < Deimos::SchemaClass::Record
|
983
990
|
|
984
991
|
### Attribute Accessors ###
|
985
|
-
# @
|
992
|
+
# @return [Integer]
|
986
993
|
attr_accessor :id
|
987
|
-
# @
|
994
|
+
# @return [String]
|
988
995
|
attr_accessor :test_id
|
989
|
-
# @
|
996
|
+
# @return [Integer]
|
990
997
|
attr_accessor :some_int
|
991
|
-
# @
|
998
|
+
# @return [String]
|
992
999
|
attr_accessor :message_id
|
993
|
-
# @
|
1000
|
+
# @return [String]
|
994
1001
|
attr_accessor :timestamp
|
995
1002
|
|
996
1003
|
# @override
|
@@ -1041,7 +1048,7 @@ module Schemas
|
|
1041
1048
|
class UpdateRequest < Deimos::SchemaClass::Record
|
1042
1049
|
|
1043
1050
|
### Attribute Accessors ###
|
1044
|
-
# @
|
1051
|
+
# @return [String]
|
1045
1052
|
attr_accessor :update_request_id
|
1046
1053
|
|
1047
1054
|
# @override
|
@@ -1080,7 +1087,7 @@ module Schemas
|
|
1080
1087
|
class UpdateResponse < Deimos::SchemaClass::Record
|
1081
1088
|
|
1082
1089
|
### Attribute Accessors ###
|
1083
|
-
# @
|
1090
|
+
# @return [String]
|
1084
1091
|
attr_accessor :update_response_id
|
1085
1092
|
|
1086
1093
|
# @override
|
@@ -1119,23 +1126,23 @@ module Schemas
|
|
1119
1126
|
class Wibble < Deimos::SchemaClass::Record
|
1120
1127
|
|
1121
1128
|
### Attribute Accessors ###
|
1122
|
-
# @
|
1129
|
+
# @return [Integer]
|
1123
1130
|
attr_accessor :id
|
1124
|
-
# @
|
1131
|
+
# @return [Integer]
|
1125
1132
|
attr_accessor :wibble_id
|
1126
|
-
# @
|
1133
|
+
# @return [String]
|
1127
1134
|
attr_accessor :name
|
1128
|
-
# @
|
1135
|
+
# @return [String]
|
1129
1136
|
attr_accessor :floop
|
1130
|
-
# @
|
1137
|
+
# @return [Integer]
|
1131
1138
|
attr_accessor :birthday_int
|
1132
|
-
# @
|
1139
|
+
# @return [Integer]
|
1133
1140
|
attr_accessor :birthday_long
|
1134
|
-
# @
|
1141
|
+
# @return [nil, Integer]
|
1135
1142
|
attr_accessor :birthday_optional
|
1136
|
-
# @
|
1143
|
+
# @return [Integer]
|
1137
1144
|
attr_accessor :updated_at
|
1138
|
-
# @
|
1145
|
+
# @return [Integer]
|
1139
1146
|
attr_accessor :created_at
|
1140
1147
|
|
1141
1148
|
# @override
|
@@ -1198,15 +1205,15 @@ module Schemas
|
|
1198
1205
|
class Widget < Deimos::SchemaClass::Record
|
1199
1206
|
|
1200
1207
|
### Attribute Accessors ###
|
1201
|
-
# @
|
1208
|
+
# @return [Integer]
|
1202
1209
|
attr_accessor :id
|
1203
|
-
# @
|
1210
|
+
# @return [Integer]
|
1204
1211
|
attr_accessor :widget_id
|
1205
|
-
# @
|
1212
|
+
# @return [String]
|
1206
1213
|
attr_accessor :name
|
1207
|
-
# @
|
1214
|
+
# @return [Integer]
|
1208
1215
|
attr_accessor :updated_at
|
1209
|
-
# @
|
1216
|
+
# @return [Integer]
|
1210
1217
|
attr_accessor :created_at
|
1211
1218
|
|
1212
1219
|
# @override
|
@@ -1257,15 +1264,15 @@ module Schemas
|
|
1257
1264
|
class WidgetTheSecond < Deimos::SchemaClass::Record
|
1258
1265
|
|
1259
1266
|
### Attribute Accessors ###
|
1260
|
-
# @
|
1267
|
+
# @return [Integer]
|
1261
1268
|
attr_accessor :id
|
1262
|
-
# @
|
1269
|
+
# @return [Integer]
|
1263
1270
|
attr_accessor :widget_id
|
1264
|
-
# @
|
1271
|
+
# @return [String]
|
1265
1272
|
attr_accessor :model_id
|
1266
|
-
# @
|
1273
|
+
# @return [Integer]
|
1267
1274
|
attr_accessor :updated_at
|
1268
|
-
# @
|
1275
|
+
# @return [Integer]
|
1269
1276
|
attr_accessor :created_at
|
1270
1277
|
|
1271
1278
|
# @override
|
data/spec/spec_helper.rb
CHANGED
@@ -191,6 +191,7 @@ RSpec.configure do |config|
|
|
191
191
|
Deimos.config.reset!
|
192
192
|
Deimos.configure do |deimos_config|
|
193
193
|
deimos_config.producers.backend = :test
|
194
|
+
deimos_config.schema.nest_child_schemas = true
|
194
195
|
deimos_config.phobos_config_file = File.join(File.dirname(__FILE__), 'phobos.yml')
|
195
196
|
deimos_config.schema.path = File.join(File.expand_path(__dir__), 'schemas')
|
196
197
|
deimos_config.consumers.reraise_errors = true
|
@@ -199,7 +200,7 @@ RSpec.configure do |config|
|
|
199
200
|
deimos_config.logger = Logger.new('/dev/null')
|
200
201
|
deimos_config.logger.level = Logger::INFO
|
201
202
|
deimos_config.schema.backend = :avro_validation
|
202
|
-
deimos_config.schema.generated_class_path = 'spec/
|
203
|
+
deimos_config.schema.generated_class_path = 'spec/schemas'
|
203
204
|
end
|
204
205
|
end
|
205
206
|
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: deimos-ruby
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.16.
|
4
|
+
version: 1.16.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Daniel Orner
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-
|
11
|
+
date: 2022-09-09 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: avro_turf
|
@@ -469,6 +469,12 @@ files:
|
|
469
469
|
- lib/generators/deimos/schema_class/templates/schema_record.rb.tt
|
470
470
|
- lib/generators/deimos/schema_class_generator.rb
|
471
471
|
- lib/tasks/deimos.rake
|
472
|
+
- rbs_collection.lock.yaml
|
473
|
+
- rbs_collection.yaml
|
474
|
+
- regenerate_test_schema_classes.rb
|
475
|
+
- sig/avro.rbs
|
476
|
+
- sig/defs.rbs
|
477
|
+
- sig/fig_tree.rbs
|
472
478
|
- spec/active_record_batch_consumer_spec.rb
|
473
479
|
- spec/active_record_consume/batch_slicer_spec.rb
|
474
480
|
- spec/active_record_consume/schema_model_converter_spec.rb
|
@@ -483,6 +489,7 @@ files:
|
|
483
489
|
- spec/consumer_spec.rb
|
484
490
|
- spec/deimos_spec.rb
|
485
491
|
- spec/generators/active_record_generator_spec.rb
|
492
|
+
- spec/generators/schema_class/my_schema_spec.rb
|
486
493
|
- spec/generators/schema_class/my_schema_with_circular_reference_spec.rb
|
487
494
|
- spec/generators/schema_class/my_schema_with_complex_types_spec.rb
|
488
495
|
- spec/generators/schema_class_generator_spec.rb
|
@@ -522,12 +529,27 @@ files:
|
|
522
529
|
- spec/schemas/com/my-namespace/response/CreateTopic.avsc
|
523
530
|
- spec/schemas/com/my-namespace/response/Index.avsc
|
524
531
|
- spec/schemas/com/my-namespace/response/UpdateResponse.avsc
|
525
|
-
- spec/schemas/generated.rb
|
526
|
-
- spec/schemas/my_nested_schema.rb
|
527
|
-
- spec/schemas/my_schema.rb
|
528
|
-
- spec/schemas/
|
529
|
-
- spec/schemas/
|
530
|
-
- spec/schemas/
|
532
|
+
- spec/schemas/my_namespace/generated.rb
|
533
|
+
- spec/schemas/my_namespace/my_nested_schema.rb
|
534
|
+
- spec/schemas/my_namespace/my_schema.rb
|
535
|
+
- spec/schemas/my_namespace/my_schema_compound_key.rb
|
536
|
+
- spec/schemas/my_namespace/my_schema_id_key.rb
|
537
|
+
- spec/schemas/my_namespace/my_schema_key.rb
|
538
|
+
- spec/schemas/my_namespace/my_schema_with_boolean.rb
|
539
|
+
- spec/schemas/my_namespace/my_schema_with_circular_reference.rb
|
540
|
+
- spec/schemas/my_namespace/my_schema_with_complex_type.rb
|
541
|
+
- spec/schemas/my_namespace/my_schema_with_date_time.rb
|
542
|
+
- spec/schemas/my_namespace/my_schema_with_id.rb
|
543
|
+
- spec/schemas/my_namespace/my_schema_with_unique_id.rb
|
544
|
+
- spec/schemas/my_namespace/wibble.rb
|
545
|
+
- spec/schemas/my_namespace/widget.rb
|
546
|
+
- spec/schemas/my_namespace/widget_the_second.rb
|
547
|
+
- spec/schemas/request/create_topic.rb
|
548
|
+
- spec/schemas/request/index.rb
|
549
|
+
- spec/schemas/request/update_request.rb
|
550
|
+
- spec/schemas/response/create_topic.rb
|
551
|
+
- spec/schemas/response/index.rb
|
552
|
+
- spec/schemas/response/update_response.rb
|
531
553
|
- spec/snapshots/consumers-no-nest.snap
|
532
554
|
- spec/snapshots/consumers.snap
|
533
555
|
- spec/snapshots/consumers_and_producers-no-nest.snap
|
@@ -572,7 +594,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
572
594
|
- !ruby/object:Gem::Version
|
573
595
|
version: '0'
|
574
596
|
requirements: []
|
575
|
-
rubygems_version: 3.
|
597
|
+
rubygems_version: 3.3.21
|
576
598
|
signing_key:
|
577
599
|
specification_version: 4
|
578
600
|
summary: Kafka libraries for Ruby.
|
@@ -591,6 +613,7 @@ test_files:
|
|
591
613
|
- spec/consumer_spec.rb
|
592
614
|
- spec/deimos_spec.rb
|
593
615
|
- spec/generators/active_record_generator_spec.rb
|
616
|
+
- spec/generators/schema_class/my_schema_spec.rb
|
594
617
|
- spec/generators/schema_class/my_schema_with_circular_reference_spec.rb
|
595
618
|
- spec/generators/schema_class/my_schema_with_complex_types_spec.rb
|
596
619
|
- spec/generators/schema_class_generator_spec.rb
|
@@ -630,12 +653,27 @@ test_files:
|
|
630
653
|
- spec/schemas/com/my-namespace/response/CreateTopic.avsc
|
631
654
|
- spec/schemas/com/my-namespace/response/Index.avsc
|
632
655
|
- spec/schemas/com/my-namespace/response/UpdateResponse.avsc
|
633
|
-
- spec/schemas/generated.rb
|
634
|
-
- spec/schemas/my_nested_schema.rb
|
635
|
-
- spec/schemas/my_schema.rb
|
636
|
-
- spec/schemas/
|
637
|
-
- spec/schemas/
|
638
|
-
- spec/schemas/
|
656
|
+
- spec/schemas/my_namespace/generated.rb
|
657
|
+
- spec/schemas/my_namespace/my_nested_schema.rb
|
658
|
+
- spec/schemas/my_namespace/my_schema.rb
|
659
|
+
- spec/schemas/my_namespace/my_schema_compound_key.rb
|
660
|
+
- spec/schemas/my_namespace/my_schema_id_key.rb
|
661
|
+
- spec/schemas/my_namespace/my_schema_key.rb
|
662
|
+
- spec/schemas/my_namespace/my_schema_with_boolean.rb
|
663
|
+
- spec/schemas/my_namespace/my_schema_with_circular_reference.rb
|
664
|
+
- spec/schemas/my_namespace/my_schema_with_complex_type.rb
|
665
|
+
- spec/schemas/my_namespace/my_schema_with_date_time.rb
|
666
|
+
- spec/schemas/my_namespace/my_schema_with_id.rb
|
667
|
+
- spec/schemas/my_namespace/my_schema_with_unique_id.rb
|
668
|
+
- spec/schemas/my_namespace/wibble.rb
|
669
|
+
- spec/schemas/my_namespace/widget.rb
|
670
|
+
- spec/schemas/my_namespace/widget_the_second.rb
|
671
|
+
- spec/schemas/request/create_topic.rb
|
672
|
+
- spec/schemas/request/index.rb
|
673
|
+
- spec/schemas/request/update_request.rb
|
674
|
+
- spec/schemas/response/create_topic.rb
|
675
|
+
- spec/schemas/response/index.rb
|
676
|
+
- spec/schemas/response/update_response.rb
|
639
677
|
- spec/snapshots/consumers-no-nest.snap
|
640
678
|
- spec/snapshots/consumers.snap
|
641
679
|
- spec/snapshots/consumers_and_producers-no-nest.snap
|