File: TestTypes.py

package info (click to toggle)
thrift 0.22.0-3
  • links: PTS
  • area: main
  • in suites: forky, sid
  • size: 29,588 kB
  • sloc: cpp: 103,295; java: 26,996; ansic: 21,793; pascal: 15,437; php: 12,823; cs: 10,610; python: 9,733; javascript: 9,274; ruby: 8,316; erlang: 7,360; sh: 5,569; makefile: 4,203; perl: 3,351; yacc: 1,145; xml: 1,079; ml: 962; lisp: 664; lex: 322
file content (65 lines) | stat: -rw-r--r-- 2,594 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#!/usr/bin/env python

#
# 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.
from ThriftTest import ThriftTest
from ThriftTest.ThriftTest import Client
from ThriftTest.ttypes import Xtruct

import unittest

# only run this test if the string 'options string: py:type_hints' esxists in the file 
def has_type_hints_option():
    with open(ThriftTest.__file__) as f:
        return 'options string: py:type_hints' in f.read()

@unittest.skipUnless(has_type_hints_option(), "type hints not enabled")
class TypeAnnotationsTest(unittest.TestCase):

    def test_void(self):
        self.assertEqual(Client.testVoid.__annotations__, {'return': None})

    def test_string(self):
        self.assertEqual(Client.testString.__annotations__, {'return': str, 'thing': str})

    def test_byte(self):
        self.assertEqual(Client.testByte.__annotations__, {'return': int, 'thing': int})

    def test_i32(self):
        self.assertEqual(Client.testI32.__annotations__, {'return': int, 'thing': int})

    def test_i64(self):
        self.assertEqual(Client.testI64.__annotations__, {'return': int, 'thing': int})

    def test_double(self):
        self.assertEqual(Client.testDouble.__annotations__, {'return': float, 'thing': float})

    def test_binary(self):
        self.assertEqual(Client.testBinary.__annotations__, {'return': bytes, 'thing': bytes})

    def test_struct(self):
        self.assertEqual(Client.testStruct.__annotations__, {'return': Xtruct, 'thing': Xtruct})

    def test_map(self):
        self.assertEqual(Client.testMap.__annotations__, {'return': dict[int, int], 'thing': dict[int, int]})
    
    def test_list(self):
        self.assertEqual(Client.testList.__annotations__, {'return': list[int], 'thing': list[int]})

    def test_set(self):
        self.assertEqual(Client.testSet.__annotations__, {'return': set[int], 'thing': set[int]})