summaryrefslogtreecommitdiffstats
path: root/src/jaegertracing/thrift/lib/rb/spec/struct_nested_containers_spec.rb
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 18:45:59 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 18:45:59 +0000
commit19fcec84d8d7d21e796c7624e521b60d28ee21ed (patch)
tree42d26aa27d1e3f7c0b8bd3fd14e7d7082f5008dc /src/jaegertracing/thrift/lib/rb/spec/struct_nested_containers_spec.rb
parentInitial commit. (diff)
downloadceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.tar.xz
ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.zip
Adding upstream version 16.2.11+ds.upstream/16.2.11+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/jaegertracing/thrift/lib/rb/spec/struct_nested_containers_spec.rb')
-rw-r--r--src/jaegertracing/thrift/lib/rb/spec/struct_nested_containers_spec.rb191
1 files changed, 191 insertions, 0 deletions
diff --git a/src/jaegertracing/thrift/lib/rb/spec/struct_nested_containers_spec.rb b/src/jaegertracing/thrift/lib/rb/spec/struct_nested_containers_spec.rb
new file mode 100644
index 000000000..d063569b5
--- /dev/null
+++ b/src/jaegertracing/thrift/lib/rb/spec/struct_nested_containers_spec.rb
@@ -0,0 +1,191 @@
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements. See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership. The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied. See the License for the
+# specific language governing permissions and limitations
+# under the License.
+#
+
+require 'spec_helper'
+
+describe 'StructNestedContainers' do
+
+ def with_type_checking
+ saved_type_checking, Thrift.type_checking = Thrift.type_checking, true
+ begin
+ yield
+ ensure
+ Thrift.type_checking = saved_type_checking
+ end
+ end
+
+ describe Thrift::Struct do
+ # Nested container tests, see THRIFT-369.
+ it "should support nested lists inside lists" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedListInList.new, SpecNamespace::NestedListInList.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = [ [1, 2, 3], [2, 3, 4] ]
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value.push [3, 4, 5]
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested lists inside sets" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedListInSet.new, SpecNamespace::NestedListInSet.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = [ [1, 2, 3], [2, 3, 4] ].to_set
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value.add [3, 4, 5]
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested lists in map keys" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedListInMapKey.new, SpecNamespace::NestedListInMapKey.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = { [1, 2, 3] => 1, [2, 3, 4] => 2 }
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value[[3, 4, 5]] = 3
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested lists in map values" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedListInMapValue.new, SpecNamespace::NestedListInMapValue.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = { 1 => [1, 2, 3], 2 => [2, 3, 4] }
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value[3] = [3, 4, 5]
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested sets inside lists" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedSetInList.new, SpecNamespace::NestedSetInList.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = [ [1, 2, 3].to_set, [2, 3, 4].to_set ]
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value.push([3, 4, 5].to_set)
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested sets inside sets" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedSetInSet.new, SpecNamespace::NestedSetInSet.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = [ [1, 2, 3].to_set, [2, 3, 4].to_set ].to_set
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value.add([3, 4, 5].to_set)
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested sets in map keys" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedSetInMapKey.new, SpecNamespace::NestedSetInMapKey.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = { [1, 2, 3].to_set => 1, [2, 3, 4].to_set => 2 }
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value[[3, 4, 5].to_set] = 3
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested sets in map values" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedSetInMapValue.new, SpecNamespace::NestedSetInMapValue.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = { 1 => [1, 2, 3].to_set, 2 => [2, 3, 4].to_set }
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value[3] = [3, 4, 5].to_set
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested maps inside lists" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedMapInList.new, SpecNamespace::NestedMapInList.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = [ {1 => 2, 3 => 4}, {2 => 3, 4 => 5} ]
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value.push({ 3 => 4, 5 => 6 })
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested maps inside sets" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedMapInSet.new, SpecNamespace::NestedMapInSet.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = [ {1 => 2, 3 => 4}, {2 => 3, 4 => 5} ].to_set
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value.add({ 3 => 4, 5 => 6 })
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested maps in map keys" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedMapInMapKey.new, SpecNamespace::NestedMapInMapKey.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = { { 1 => 2, 3 => 4} => 1, {2 => 3, 4 => 5} => 2 }
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value[{3 => 4, 5 => 6}] = 3
+ expect(a).not_to eq(b)
+ end
+ end
+
+ it "should support nested maps in map values" do
+ with_type_checking do
+ a, b = SpecNamespace::NestedMapInMapValue.new, SpecNamespace::NestedMapInMapValue.new
+ [a, b].each do |thrift_struct|
+ thrift_struct.value = { 1 => { 1 => 2, 3 => 4}, 2 => {2 => 3, 4 => 5} }
+ thrift_struct.validate
+ end
+ expect(a).to eq(b)
+ b.value[3] = { 3 => 4, 5 => 6 }
+ expect(a).not_to eq(b)
+ end
+ end
+ end
+end