blob: 6d2595cf29be57f98871aa2b879f2be8c31126f7 [file] [log] [blame]
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +09001#!/usr/bin/env python
2
3#
4# Licensed to the Apache Software Foundation (ASF) under one
5# or more contributor license agreements. See the NOTICE file
6# distributed with this work for additional information
7# regarding copyright ownership. The ASF licenses this file
8# to you under the Apache License, Version 2.0 (the
9# "License"); you may not use this file except in compliance
10# with the License. You may obtain a copy of the License at
11#
12# http://www.apache.org/licenses/LICENSE-2.0
13#
14# Unless required by applicable law or agreed to in writing,
15# software distributed under the License is distributed on an
16# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17# KIND, either express or implied. See the License for the
18# specific language governing permissions and limitations
19# under the License.
20#
21
22from DebugProtoTest.ttypes import CompactProtoTestStruct, Empty, Wrapper
23from thrift.Thrift import TFrozenDict
24from thrift.transport import TTransport
Nobuaki Sukegawa6525f6a2016-02-11 13:58:39 +090025from thrift.protocol import TBinaryProtocol, TCompactProtocol
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090026import collections
27import unittest
28
29
30class TestFrozenBase(unittest.TestCase):
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090031 def _roundtrip(self, src, dst):
32 otrans = TTransport.TMemoryBuffer()
33 optoro = self.protocol(otrans)
34 src.write(optoro)
35 itrans = TTransport.TMemoryBuffer(otrans.getvalue())
36 iproto = self.protocol(itrans)
37 return dst.read(iproto) or dst
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090038
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090039 def test_dict_is_hashable_only_after_frozen(self):
40 d0 = {}
41 self.assertFalse(isinstance(d0, collections.Hashable))
42 d1 = TFrozenDict(d0)
43 self.assertTrue(isinstance(d1, collections.Hashable))
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090044
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090045 def test_struct_with_collection_fields(self):
46 pass
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090047
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090048 def test_set(self):
49 """Test that annotated set field can be serialized and deserialized"""
50 x = CompactProtoTestStruct(set_byte_map={
51 frozenset([42, 100, -100]): 99,
52 frozenset([0]): 100,
53 frozenset([]): 0,
54 })
55 x2 = self._roundtrip(x, CompactProtoTestStruct())
56 self.assertEqual(x2.set_byte_map[frozenset([42, 100, -100])], 99)
57 self.assertEqual(x2.set_byte_map[frozenset([0])], 100)
58 self.assertEqual(x2.set_byte_map[frozenset([])], 0)
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090059
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090060 def test_map(self):
61 """Test that annotated map field can be serialized and deserialized"""
62 x = CompactProtoTestStruct(map_byte_map={
63 TFrozenDict({42: 42, 100: -100}): 99,
64 TFrozenDict({0: 0}): 100,
65 TFrozenDict({}): 0,
66 })
67 x2 = self._roundtrip(x, CompactProtoTestStruct())
68 self.assertEqual(x2.map_byte_map[TFrozenDict({42: 42, 100: -100})], 99)
69 self.assertEqual(x2.map_byte_map[TFrozenDict({0: 0})], 100)
70 self.assertEqual(x2.map_byte_map[TFrozenDict({})], 0)
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090071
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090072 def test_list(self):
73 """Test that annotated list field can be serialized and deserialized"""
74 x = CompactProtoTestStruct(list_byte_map={
75 (42, 100, -100): 99,
76 (0,): 100,
77 (): 0,
78 })
79 x2 = self._roundtrip(x, CompactProtoTestStruct())
80 self.assertEqual(x2.list_byte_map[(42, 100, -100)], 99)
81 self.assertEqual(x2.list_byte_map[(0,)], 100)
82 self.assertEqual(x2.list_byte_map[()], 0)
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090083
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090084 def test_empty_struct(self):
85 """Test that annotated empty struct can be serialized and deserialized"""
86 x = CompactProtoTestStruct(empty_struct_field=Empty())
87 x2 = self._roundtrip(x, CompactProtoTestStruct())
88 self.assertEqual(x2.empty_struct_field, Empty())
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090089
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090090 def test_struct(self):
91 """Test that annotated struct can be serialized and deserialized"""
92 x = Wrapper(foo=Empty())
93 self.assertEqual(x.foo, Empty())
94 x2 = self._roundtrip(x, Wrapper)
95 self.assertEqual(x2.foo, Empty())
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +090096
97
98class TestFrozen(TestFrozenBase):
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +090099 def protocol(self, trans):
100 return TBinaryProtocol.TBinaryProtocolFactory().getProtocol(trans)
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +0900101
102
Nobuaki Sukegawa6525f6a2016-02-11 13:58:39 +0900103class TestFrozenAcceleratedBinary(TestFrozenBase):
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900104 def protocol(self, trans):
Nobuaki Sukegawa7af189a2016-02-11 16:21:01 +0900105 return TBinaryProtocol.TBinaryProtocolAcceleratedFactory(fallback=False).getProtocol(trans)
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +0900106
107
Nobuaki Sukegawa6525f6a2016-02-11 13:58:39 +0900108class TestFrozenAcceleratedCompact(TestFrozenBase):
109 def protocol(self, trans):
Nobuaki Sukegawa7af189a2016-02-11 16:21:01 +0900110 return TCompactProtocol.TCompactProtocolAcceleratedFactory(fallback=False).getProtocol(trans)
Nobuaki Sukegawa6525f6a2016-02-11 13:58:39 +0900111
112
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +0900113def suite():
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900114 suite = unittest.TestSuite()
115 loader = unittest.TestLoader()
116 suite.addTest(loader.loadTestsFromTestCase(TestFrozen))
Nobuaki Sukegawa6525f6a2016-02-11 13:58:39 +0900117 suite.addTest(loader.loadTestsFromTestCase(TestFrozenAcceleratedBinary))
118 suite.addTest(loader.loadTestsFromTestCase(TestFrozenAcceleratedCompact))
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900119 return suite
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +0900120
James E. King, III0ad20bd2017-09-30 15:44:16 -0700121
Nobuaki Sukegawae841b3d2015-11-17 11:01:17 +0900122if __name__ == "__main__":
Nobuaki Sukegawa10308cb2016-02-03 01:57:03 +0900123 unittest.main(defaultTest="suite", testRunner=unittest.TextTestRunner(verbosity=2))