bson 4.1.1-java → 4.2.0-java

Sign up to get free protection for your applications and to get access to all the features.
Files changed (82) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data.tar.gz.sig +0 -0
  4. data/Rakefile +18 -3
  5. data/lib/bson-ruby.jar +0 -0
  6. data/lib/bson.rb +6 -4
  7. data/lib/bson/array.rb +1 -1
  8. data/lib/bson/binary.rb +4 -2
  9. data/lib/bson/code.rb +1 -1
  10. data/lib/bson/code_with_scope.rb +1 -1
  11. data/lib/bson/config.rb +1 -1
  12. data/lib/bson/date.rb +1 -1
  13. data/lib/bson/date_time.rb +1 -1
  14. data/lib/bson/decimal128.rb +318 -0
  15. data/lib/bson/decimal128/builder.rb +448 -0
  16. data/lib/bson/document.rb +2 -2
  17. data/lib/bson/environment.rb +13 -1
  18. data/lib/bson/false_class.rb +1 -1
  19. data/lib/bson/float.rb +1 -1
  20. data/lib/bson/hash.rb +1 -1
  21. data/lib/bson/int32.rb +46 -0
  22. data/lib/bson/int64.rb +46 -0
  23. data/lib/bson/integer.rb +1 -1
  24. data/lib/bson/max_key.rb +1 -1
  25. data/lib/bson/min_key.rb +1 -1
  26. data/lib/bson/object_id.rb +3 -2
  27. data/lib/bson/open_struct.rb +57 -0
  28. data/lib/bson/regexp.rb +87 -19
  29. data/lib/bson/registry.rb +1 -1
  30. data/lib/bson/specialized.rb +1 -1
  31. data/lib/bson/string.rb +1 -1
  32. data/lib/bson/symbol.rb +1 -1
  33. data/lib/bson/time.rb +1 -1
  34. data/lib/bson/timestamp.rb +2 -2
  35. data/lib/bson/true_class.rb +1 -1
  36. data/lib/bson/version.rb +2 -2
  37. data/spec/bson/array_spec.rb +1 -1
  38. data/spec/bson/binary_spec.rb +2 -1
  39. data/spec/bson/corpus_spec.rb +68 -0
  40. data/spec/bson/decimal128_spec.rb +1583 -0
  41. data/spec/bson/document_spec.rb +1 -1
  42. data/spec/bson/driver_bson_spec.rb +77 -0
  43. data/spec/bson/int32_spec.rb +58 -0
  44. data/spec/bson/int64_spec.rb +58 -0
  45. data/spec/bson/open_struct_spec.rb +144 -0
  46. data/spec/bson/raw_spec.rb +540 -0
  47. data/spec/bson/regexp_spec.rb +7 -7
  48. data/spec/bson/timestamp_spec.rb +1 -1
  49. data/spec/spec_helper.rb +5 -0
  50. data/spec/support/common_driver.rb +347 -0
  51. data/spec/support/corpus-tests/array.json +43 -0
  52. data/spec/support/corpus-tests/boolean.json +27 -0
  53. data/spec/support/corpus-tests/code.json +67 -0
  54. data/spec/support/corpus-tests/code_w_scope.json +78 -0
  55. data/spec/support/corpus-tests/document.json +36 -0
  56. data/spec/support/corpus-tests/double.json +69 -0
  57. data/spec/support/corpus-tests/failures/binary.json +69 -0
  58. data/spec/support/corpus-tests/failures/datetime.json +31 -0
  59. data/spec/support/corpus-tests/failures/dbpointer.json +42 -0
  60. data/spec/support/corpus-tests/failures/int64.json +38 -0
  61. data/spec/support/corpus-tests/failures/symbol.json +62 -0
  62. data/spec/support/corpus-tests/failures/undefined.json +13 -0
  63. data/spec/support/corpus-tests/int32.json +38 -0
  64. data/spec/support/corpus-tests/maxkey.json +12 -0
  65. data/spec/support/corpus-tests/minkey.json +12 -0
  66. data/spec/support/corpus-tests/null.json +12 -0
  67. data/spec/support/corpus-tests/oid.json +28 -0
  68. data/spec/support/corpus-tests/regex.json +37 -0
  69. data/spec/support/corpus-tests/string.json +67 -0
  70. data/spec/support/corpus-tests/timestamp.json +18 -0
  71. data/spec/support/corpus-tests/top.json +62 -0
  72. data/spec/support/corpus.rb +265 -0
  73. data/spec/support/driver-spec-tests/decimal128/decimal128-1.json +363 -0
  74. data/spec/support/driver-spec-tests/decimal128/decimal128-2.json +793 -0
  75. data/spec/support/driver-spec-tests/decimal128/decimal128-3.json +1771 -0
  76. data/spec/support/driver-spec-tests/decimal128/decimal128-4.json +165 -0
  77. data/spec/support/driver-spec-tests/decimal128/decimal128-5.json +402 -0
  78. data/spec/support/driver-spec-tests/decimal128/decimal128-6.json +131 -0
  79. data/spec/support/driver-spec-tests/decimal128/decimal128-7.json +327 -0
  80. data/spec/support/shared_examples.rb +1 -1
  81. metadata +77 -4
  82. metadata.gz.sig +0 -0
@@ -0,0 +1,62 @@
1
+ {
2
+ "description": "Symbol",
3
+ "bson_type": "0x0E",
4
+ "deprecated": true,
5
+ "test_key": "a",
6
+ "valid": [
7
+ {
8
+ "description": "Empty string",
9
+ "bson": "0D0000000E6100010000000000"
10
+ },
11
+ {
12
+ "description": "Single character",
13
+ "bson": "0E0000000E610002000000620000"
14
+ },
15
+ {
16
+ "description": "Multi-character",
17
+ "bson": "190000000E61000D0000006162616261626162616261620000"
18
+ },
19
+ {
20
+ "description": "two-byte UTF-8 (\u00e9)",
21
+ "bson": "190000000E61000D000000C3A9C3A9C3A9C3A9C3A9C3A90000"
22
+ },
23
+ {
24
+ "description": "three-byte UTF-8 (\u2606)",
25
+ "bson": "190000000E61000D000000E29886E29886E29886E298860000"
26
+ },
27
+ {
28
+ "description": "Embedded nulls",
29
+ "bson": "190000000E61000D0000006162006261620062616261620000"
30
+ }
31
+ ],
32
+ "decodeErrors": [
33
+ {
34
+ "description": "bad symbol length: 0 (but no 0x00 either)",
35
+ "bson": "0C0000000261000000000000"
36
+ },
37
+ {
38
+ "description": "bad symbol length: -1",
39
+ "bson": "0C000000026100FFFFFFFF00"
40
+ },
41
+ {
42
+ "description": "bad symbol length: eats terminator",
43
+ "bson": "10000000026100050000006200620000"
44
+ },
45
+ {
46
+ "description": "bad symbol length: longer than rest of document",
47
+ "bson": "120000000200FFFFFF00666F6F6261720000"
48
+ },
49
+ {
50
+ "description": "symbol is not null-terminated",
51
+ "bson": "1000000002610004000000616263FF00"
52
+ },
53
+ {
54
+ "description": "empty symbol, but extra null",
55
+ "bson": "0E00000002610001000000000000"
56
+ },
57
+ {
58
+ "description": "invalid UTF-8",
59
+ "bson": "0E00000002610002000000E90000"
60
+ }
61
+ ]
62
+ }
@@ -0,0 +1,13 @@
1
+ {
2
+ "description": "Undefined type (deprecated)",
3
+ "bson_type": "0x06",
4
+ "deprecated": true,
5
+ "test_key": "a",
6
+ "valid": [
7
+ {
8
+ "description": "Undefined",
9
+ "bson": "0800000006610000",
10
+ "extjson": "{\"a\" : {\"$undefined\" : true}}"
11
+ }
12
+ ]
13
+ }
@@ -0,0 +1,38 @@
1
+ {
2
+ "description": "Int32 type",
3
+ "bson_type": "0x10",
4
+ "test_key": "i",
5
+ "valid": [
6
+ {
7
+ "description": "MinValue",
8
+ "bson": "0C0000001069000000008000",
9
+ "extjson": "{\"i\" : -2147483648}"
10
+ },
11
+ {
12
+ "description": "MaxValue",
13
+ "bson": "0C000000106900FFFFFF7F00",
14
+ "extjson": "{\"i\" : 2147483647}"
15
+ },
16
+ {
17
+ "description": "-1",
18
+ "bson": "0C000000106900FFFFFFFF00",
19
+ "extjson": "{\"i\" : -1}"
20
+ },
21
+ {
22
+ "description": "0",
23
+ "bson": "0C0000001069000000000000",
24
+ "extjson": "{\"i\" : 0}"
25
+ },
26
+ {
27
+ "description": "1",
28
+ "bson": "0C0000001069000100000000",
29
+ "extjson": "{\"i\" : 1}"
30
+ }
31
+ ],
32
+ "decodeErrors": [
33
+ {
34
+ "description": "Bad int32 field length",
35
+ "bson": "090000001061000500"
36
+ }
37
+ ]
38
+ }
@@ -0,0 +1,12 @@
1
+ {
2
+ "description": "Maxkey type",
3
+ "bson_type": "0xFF",
4
+ "test_key": "a",
5
+ "valid": [
6
+ {
7
+ "description": "Maxkey",
8
+ "bson": "080000007F610000",
9
+ "extjson": "{\"a\" : {\"$maxKey\" : 1}}"
10
+ }
11
+ ]
12
+ }
@@ -0,0 +1,12 @@
1
+ {
2
+ "description": "Minkey type",
3
+ "bson_type": "0xFF",
4
+ "test_key": "a",
5
+ "valid": [
6
+ {
7
+ "description": "Minkey",
8
+ "bson": "08000000FF610000",
9
+ "extjson": "{\"a\" : {\"$minKey\" : 1}}"
10
+ }
11
+ ]
12
+ }
@@ -0,0 +1,12 @@
1
+ {
2
+ "description": "Null type",
3
+ "bson_type": "0x0A",
4
+ "test_key": "a",
5
+ "valid": [
6
+ {
7
+ "description": "Null",
8
+ "bson": "080000000A610000",
9
+ "extjson": "{\"a\" : null}"
10
+ }
11
+ ]
12
+ }
@@ -0,0 +1,28 @@
1
+ {
2
+ "description": "ObjectId",
3
+ "bson_type": "0x07",
4
+ "test_key": "a",
5
+ "valid": [
6
+ {
7
+ "description": "All zeroes",
8
+ "bson": "1400000007610000000000000000000000000000",
9
+ "extjson": "{\"a\" : {\"$oid\" : \"000000000000000000000000\"}}"
10
+ },
11
+ {
12
+ "description": "All ones",
13
+ "bson": "14000000076100FFFFFFFFFFFFFFFFFFFFFFFF00",
14
+ "extjson": "{\"a\" : {\"$oid\" : \"ffffffffffffffffffffffff\"}}"
15
+ },
16
+ {
17
+ "description": "Random",
18
+ "bson": "1400000007610056E1FC72E0C917E9C471416100",
19
+ "extjson": "{\"a\" : {\"$oid\" : \"56e1fc72e0c917e9c4714161\"}}"
20
+ }
21
+ ],
22
+ "decodeErrors": [
23
+ {
24
+ "description": "OID truncated",
25
+ "bson": "1200000007610056E1FC72E0C917E9C471"
26
+ }
27
+ ]
28
+ }
@@ -0,0 +1,37 @@
1
+ {
2
+ "description": "Regular Expression type",
3
+ "bson_type": "0x0B",
4
+ "test_key": "a",
5
+ "valid": [
6
+ {
7
+ "description": "empty regex with no options",
8
+ "bson": "0A0000000B6100000000",
9
+ "extjson": "{\"a\" : {\"$regex\" : \"\", \"$options\" : \"\"}}"
10
+ },
11
+ {
12
+ "description": "regex without options",
13
+ "bson": "0D0000000B6100616263000000",
14
+ "extjson": "{\"a\" : {\"$regex\" : \"abc\", \"$options\" : \"\"}}"
15
+ },
16
+ {
17
+ "description": "regex with options",
18
+ "bson": "0F0000000B610061626300696D0000",
19
+ "extjson": "{\"a\" : {\"$regex\" : \"abc\", \"$options\" : \"im\"}}"
20
+ },
21
+ {
22
+ "description": "regex with slash",
23
+ "bson": "110000000B610061622F636400696D0000",
24
+ "extjson": "{\"a\" : {\"$regex\" : \"ab/cd\", \"$options\" : \"im\"}}"
25
+ }
26
+ ],
27
+ "decodeErrors": [
28
+ {
29
+ "description": "embedded null in pattern",
30
+ "bson": "0F0000000B610061006300696D0000"
31
+ },
32
+ {
33
+ "description": "embedded null in flags",
34
+ "bson": "100000000B61006162630069006D0000"
35
+ }
36
+ ]
37
+ }
@@ -0,0 +1,67 @@
1
+ {
2
+ "description": "String",
3
+ "bson_type": "0x02",
4
+ "test_key": "a",
5
+ "valid": [
6
+ {
7
+ "description": "Empty string",
8
+ "bson": "0D000000026100010000000000",
9
+ "extjson": "{\"a\" : \"\"}"
10
+ },
11
+ {
12
+ "description": "Single character",
13
+ "bson": "0E00000002610002000000620000",
14
+ "extjson": "{\"a\" : \"b\"}"
15
+ },
16
+ {
17
+ "description": "Multi-character",
18
+ "bson": "190000000261000D0000006162616261626162616261620000",
19
+ "extjson": "{\"a\" : \"abababababab\"}"
20
+ },
21
+ {
22
+ "description": "two-byte UTF-8 (\u00e9)",
23
+ "bson": "190000000261000D000000C3A9C3A9C3A9C3A9C3A9C3A90000",
24
+ "extjson": "{\"a\" : \"\\u00e9\\u00e9\\u00e9\\u00e9\\u00e9\\u00e9\"}"
25
+ },
26
+ {
27
+ "description": "three-byte UTF-8 (\u2606)",
28
+ "bson": "190000000261000D000000E29886E29886E29886E298860000",
29
+ "extjson": "{\"a\" : \"\\u2606\\u2606\\u2606\\u2606\"}"
30
+ },
31
+ {
32
+ "description": "Embedded nulls",
33
+ "bson": "190000000261000D0000006162006261620062616261620000",
34
+ "extjson": "{\"a\" : \"ab\\u0000bab\\u0000babab\"}"
35
+ }
36
+ ],
37
+ "decodeErrors": [
38
+ {
39
+ "description": "bad string length: 0 (but no 0x00 either)",
40
+ "bson": "0C0000000261000000000000"
41
+ },
42
+ {
43
+ "description": "bad string length: -1",
44
+ "bson": "0C000000026100FFFFFFFF00"
45
+ },
46
+ {
47
+ "description": "bad string length: eats terminator",
48
+ "bson": "10000000026100050000006200620000"
49
+ },
50
+ {
51
+ "description": "bad string length: longer than rest of document",
52
+ "bson": "120000000200FFFFFF00666F6F6261720000"
53
+ },
54
+ {
55
+ "description": "string is not null-terminated",
56
+ "bson": "1000000002610004000000616263FF00"
57
+ },
58
+ {
59
+ "description": "empty string, but extra null",
60
+ "bson": "0E00000002610001000000000000"
61
+ },
62
+ {
63
+ "description": "invalid UTF-8",
64
+ "bson": "0E00000002610002000000E90000"
65
+ }
66
+ ]
67
+ }
@@ -0,0 +1,18 @@
1
+ {
2
+ "description": "Timestamp type",
3
+ "bson_type": "0x11",
4
+ "test_key": "a",
5
+ "valid": [
6
+ {
7
+ "description": "Timestamp: (123456789, 42)",
8
+ "bson": "100000001161002A00000015CD5B0700",
9
+ "extjson": "{\"a\" : {\"$timestamp\" : {\"t\" : 123456789, \"i\" : 42}}}"
10
+ }
11
+ ],
12
+ "decodeErrors": [
13
+ {
14
+ "description": "Truncated timestamp field",
15
+ "bson": "0f0000001161002A00000015CD5B00"
16
+ }
17
+ ]
18
+ }
@@ -0,0 +1,62 @@
1
+ {
2
+ "description": "Top-level document validity",
3
+ "bson_type": "0x00",
4
+ "decodeErrors": [
5
+ {
6
+ "description": "An object size that's too small to even include the object size, but is a well-formed, empty object",
7
+ "bson": "0100000000"
8
+ },
9
+ {
10
+ "description": "An object size that's only enough for the object size, but is a well-formed, empty object",
11
+ "bson": "0400000000"
12
+ },
13
+ {
14
+ "description": "One object, with length shorter than size (missing EOO)",
15
+ "bson": "05000000"
16
+ },
17
+ {
18
+ "description": "One object, sized correctly, with a spot for an EOO, but the EOO is 0x01",
19
+ "bson": "0500000001"
20
+ },
21
+ {
22
+ "description": "One object, sized correctly, with a spot for an EOO, but the EOO is 0xff",
23
+ "bson": "05000000FF"
24
+ },
25
+ {
26
+ "description": "One object, sized correctly, with a spot for an EOO, but the EOO is 0x70",
27
+ "bson": "0500000070"
28
+ },
29
+ {
30
+ "description": "Byte count is zero (with non-zero input length)",
31
+ "bson": "00000000000000000000"
32
+ },
33
+ {
34
+ "description": "Stated length exceeds byte count, with truncated document",
35
+ "bson": "1200000002666F6F0004000000626172"
36
+ },
37
+ {
38
+ "description": "Stated length less than byte count, with garbage after envelope",
39
+ "bson": "1200000002666F6F00040000006261720000DEADBEEF"
40
+ },
41
+ {
42
+ "description": "Stated length exceeds byte count, with valid envelope",
43
+ "bson": "1300000002666F6F00040000006261720000"
44
+ },
45
+ {
46
+ "description": "Stated length less than byte count, with valid envelope",
47
+ "bson": "1100000002666F6F00040000006261720000"
48
+ },
49
+ {
50
+ "description": "Invalid BSON type low range",
51
+ "bson": "07000000000000"
52
+ },
53
+ {
54
+ "description": "Invalid BSON type high range",
55
+ "bson": "07000000800000"
56
+ },
57
+ {
58
+ "description": "Document truncated mid-key",
59
+ "bson": "1200000002666F"
60
+ }
61
+ ]
62
+ }
@@ -0,0 +1,265 @@
1
+ # Copyright (C) 2016 MongoDB, Inc.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ require 'json'
16
+
17
+ module BSON
18
+ module Corpus
19
+
20
+ # Represents a test from the driver BSON Corpus.
21
+ #
22
+ # @since 4.2.0
23
+ class Spec
24
+
25
+ # The spec description.
26
+ #
27
+ # @return [ String ] The spec description.
28
+ #
29
+ # @since 4.2.0
30
+ attr_reader :description
31
+
32
+ # The document key of the object to test.
33
+ #
34
+ # @return [ String ] The document key.
35
+ #
36
+ # @since 4.2.0
37
+ attr_reader :test_key
38
+
39
+ # Instantiate the new spec.
40
+ #
41
+ # @example Create the spec.
42
+ # Spec.new(file)
43
+ #
44
+ # @param [ String ] file The name of the json file.
45
+ #
46
+ # @since 4.2.0
47
+ def initialize(file)
48
+ @spec = ::JSON.parse(File.read(file))
49
+ @valid = @spec['valid'] || []
50
+ @invalid = @spec['decodeErrors'] || []
51
+ @description = @spec['description']
52
+ @test_key = @spec['test_key']
53
+ end
54
+
55
+ # Get a list of tests that are expected to pass.
56
+ #
57
+ # @example Get the list of valid tests.
58
+ # spec.valid_tests
59
+ #
60
+ # @return [ Array<BSON::Corpus::Test> ] The list of valid Tests.
61
+ #
62
+ # @since 4.2.0
63
+ def valid_tests
64
+ @valid_tests ||=
65
+ @valid.collect do |test|
66
+ BSON::Corpus::Test.new(self, test)
67
+ end
68
+ end
69
+
70
+ # Get a list of tests that raise exceptions.
71
+ #
72
+ # @example Get the list of invalid tests.
73
+ # spec.invalid_tests
74
+ #
75
+ # @return [ Array<BSON::Corpus::Test> ] The list of invalid Tests.
76
+ #
77
+ # @since 4.2.0
78
+ def invalid_tests
79
+ @invalid_tests ||=
80
+ @invalid.collect do |test|
81
+ BSON::Corpus::Test.new(self, test)
82
+ end
83
+ end
84
+
85
+ # The class of the bson object to test.
86
+ #
87
+ # @example Get the class of the object to test.
88
+ # spec.klass
89
+ #
90
+ # @return [ Class ] The object class.
91
+ #
92
+ # @since 4.2.0
93
+ def klass
94
+ @klass ||= BSON.const_get(description)
95
+ end
96
+ end
97
+
98
+ # Represents a single BSON Corpus test.
99
+ #
100
+ # @since 4.2.0
101
+ class Test
102
+
103
+ # The test description.
104
+ #
105
+ # @return [ String ] The test description.
106
+ #
107
+ # @since 4.2.0
108
+ attr_reader :description
109
+
110
+ # Name of a field in a valid test case extjson document that should be
111
+ # checked against the case's string field.
112
+ #
113
+ # @return [ String ] The json representation of the object.
114
+ #
115
+ # @since 4.2.0
116
+ attr_reader :test_key
117
+
118
+ # Instantiate the new Test.
119
+ #
120
+ # @example Create the test.
121
+ # Test.new(test)
122
+ #
123
+ # @param [ Corpus::Spec ] spec The test specification.
124
+ # @param [ Hash ] test The test specification.
125
+ #
126
+ # @since 4.2.0
127
+ def initialize(spec, test)
128
+ @spec = spec
129
+ @description = test['description']
130
+ @canonical_bson = test['canonical_bson']
131
+ @extjson = ::JSON.parse(test['extjson']) if test['extjson']
132
+ @bson = test['bson']
133
+ @test_key = spec.test_key
134
+ end
135
+
136
+ # The correct representation of the subject as bson.
137
+ #
138
+ # @example Get the correct representation of the subject as bson.
139
+ # test.correct_bson
140
+ #
141
+ # @return [ String ] The correct bson bytes.
142
+ #
143
+ # @since 4.2.0
144
+ def correct_bson
145
+ @correct_bson ||= decode_hex(@canonical_bson || @bson)
146
+ end
147
+
148
+ # Given the hex representation of bson, decode it into a Document,
149
+ # then reencoded it to bson.
150
+ #
151
+ # @example Decoded the bson hex representation, then reencode.
152
+ # test.reencoded_bson
153
+ #
154
+ # @return [ String ] The reencoded bson bytes.
155
+ #
156
+ # @since 4.2.0
157
+ def reencoded_bson
158
+ bson_bytes = decode_hex(@bson)
159
+ buffer = BSON::ByteBuffer.new(bson_bytes)
160
+ BSON::Document.from_bson(buffer).to_bson.to_s
161
+ end
162
+
163
+ # Given the hex representation of the canonical bson, decode it into a Document,
164
+ # then reencoded it to bson.
165
+ #
166
+ # @example Decoded the canonical bson hex representation, then reencode.
167
+ # test.reencoded_canonical_bson
168
+ #
169
+ # @return [ String ] The reencoded canonical bson bytes.
170
+ #
171
+ # @since 4.2.0
172
+ def reencoded_canonical_bson
173
+ bson_bytes = decode_hex(@canonical_bson)
174
+ buffer = BSON::ByteBuffer.new(bson_bytes)
175
+ BSON::Document.from_bson(buffer).to_bson.to_s
176
+ end
177
+
178
+ # Whether the canonical bson should be tested.
179
+ #
180
+ # @example Determine if the canonical bson should be tested.
181
+ # test.test_canonical_bson?
182
+ #
183
+ # @return [ true, false ] Whether the canonical bson should be tested.
184
+ #
185
+ # @since 4.2.0
186
+ def test_canonical_bson?
187
+ @canonical_bson && (@bson != @canonical_bson)
188
+ end
189
+
190
+ # The correct representation of the subject as extended json.
191
+ #
192
+ # @example Get the correct representation of the subject as extended json.
193
+ # test.correct_extjson
194
+ #
195
+ # @return [ String ] The correct extended json representation.
196
+ #
197
+ # @since 4.2.0
198
+ def correct_extjson
199
+ @canonical_extjson || @extjson
200
+ end
201
+
202
+ # Whether the extended json should be tested.
203
+ #
204
+ # @example Determine if the extended json should be tested.
205
+ # test.test_extjson?
206
+ #
207
+ # @return [ true, false ] Whether the extended json should be tested.
208
+ #
209
+ # @since 4.2.0
210
+ def test_extjson?
211
+ !!@extjson
212
+ end
213
+
214
+ # Get the extended json representation of the decoded doc from the provided
215
+ # bson hex representation.
216
+ #
217
+ # @example Get the extended json representation of the decoded doc.
218
+ # test.extjson_from_encoded_bson
219
+ #
220
+ # @return [ Hash ] The extended json representation.
221
+ #
222
+ # @since 4.2.0
223
+ def extjson_from_bson
224
+ subject = decode_hex(@bson)
225
+ buffer = BSON::ByteBuffer.new(subject)
226
+ ::JSON.parse(BSON::Document.from_bson(buffer).to_json)
227
+ end
228
+
229
+ # Get the extended json representation of the decoded doc from the provided
230
+ # canonical bson hex representation.
231
+ #
232
+ # @example Get the extended json representation of the canonical decoded doc.
233
+ # test.extjson_from_canonical_bson
234
+ #
235
+ # @return [ Hash ] The extended json representation.
236
+ #
237
+ # @since 4.2.0
238
+ def extjson_from_canonical_bson
239
+ subject = decode_hex(@canonical_bson)
240
+ buffer = BSON::ByteBuffer.new(subject)
241
+ ::JSON.parse(BSON::Document.from_bson(buffer).to_json)
242
+ end
243
+
244
+ # Get the extended json representation of the decoded doc from the provided
245
+ # extended json representation. (Verifies roundtrip)
246
+ #
247
+ # @example Get the extended json representation of the canonical decoded doc.
248
+ # test.extjson_from_encoded_extjson
249
+ #
250
+ # @return [ Hash ] The extended json representation.
251
+ #
252
+ # @since 4.2.0
253
+ def extjson_from_encoded_extjson
254
+ doc = BSON::Document.new(@extjson)
255
+ ::JSON.parse(doc.to_json)
256
+ end
257
+
258
+ private
259
+
260
+ def decode_hex(obj)
261
+ [ obj ].pack('H*')
262
+ end
263
+ end
264
+ end
265
+ end