Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

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

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

# Copyright (C) 2011  Internet Systems Consortium. 

# 

# Permission to use, copy, modify, and distribute this software for any 

# purpose with or without fee is hereby granted, provided that the above 

# copyright notice and this permission notice appear in all copies. 

# 

# THE SOFTWARE IS PROVIDED "AS IS" AND INTERNET SYSTEMS CONSORTIUM 

# DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL 

# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL 

# INTERNET SYSTEMS CONSORTIUM BE LIABLE FOR ANY SPECIAL, DIRECT, 

# INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING 

# FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, 

# NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION 

# WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 

 

import unittest 

import sys 

from pydnspp import * 

 

class TSIGErrorTest(unittest.TestCase): 

    def test_from_code(self): 

        self.assertEqual(0, TSIGError(0).get_code()) 

        self.assertEqual(18, TSIGError(18).get_code()) 

        self.assertEqual(65535, TSIGError(65535).get_code()) 

        self.assertRaises(ValueError, TSIGError, 65536) 

        self.assertRaises(ValueError, TSIGError, -1) 

        self.assertRaises(TypeError, TSIGError, "not yet supported") 

 

    def test_from_rcode(self): 

        # We use RCODE for code values from 0-15. 

        self.assertEqual(0, TSIGError(Rcode.NOERROR()).get_code()) 

        self.assertEqual(15, TSIGError(Rcode(15)).get_code()) 

 

        # From error code 16 TSIG errors define a separate space, so passing 

        # corresponding RCODE for such code values should be prohibited. 

        self.assertRaises(ValueError, TSIGError, Rcode(16)) 

 

    def test_constants(self): 

        # We'll only test arbitrarily chosen subsets of the codes. 

        # This class is quite simple, so it should be suffice. 

        self.assertEqual(TSIGError.BAD_SIG_CODE, TSIGError(16).get_code()) 

        self.assertEqual(TSIGError.BAD_KEY_CODE, TSIGError(17).get_code()) 

        self.assertEqual(TSIGError.BAD_TIME_CODE, TSIGError(18).get_code()) 

 

        self.assertEqual(0, TSIGError.NOERROR.get_code()) 

        self.assertEqual(9, TSIGError.NOTAUTH.get_code()) 

        self.assertEqual(14, TSIGError.RESERVED14.get_code()) 

        self.assertEqual(TSIGError.BAD_SIG_CODE, TSIGError.BAD_SIG.get_code()) 

        self.assertEqual(TSIGError.BAD_KEY_CODE, TSIGError.BAD_KEY.get_code()) 

        self.assertEqual(TSIGError.BAD_TIME_CODE, TSIGError.BAD_TIME.get_code()) 

 

    def test_equal(self): 

        self.assertTrue(TSIGError.NOERROR == TSIGError(Rcode.NOERROR())) 

        self.assertTrue(TSIGError(Rcode.NOERROR()) == TSIGError.NOERROR) 

 

        self.assertTrue(TSIGError.BAD_SIG == TSIGError(16)) 

        self.assertTrue(TSIGError(16) == TSIGError.BAD_SIG) 

 

    def test_nequal(self): 

        self.assertTrue(TSIGError.BAD_KEY != TSIGError(Rcode.NOERROR())) 

        self.assertTrue(TSIGError(Rcode.NOERROR()) != TSIGError.BAD_KEY) 

 

    def test_to_text(self): 

        # TSIGError derived from the standard Rcode 

        self.assertEqual("NOERROR", TSIGError(Rcode.NOERROR()).to_text()) 

 

        # Well known TSIG errors 

        self.assertEqual("BADSIG", TSIGError.BAD_SIG.to_text()) 

        self.assertEqual("BADKEY", TSIGError.BAD_KEY.to_text()) 

        self.assertEqual("BADTIME", TSIGError.BAD_TIME.to_text()) 

 

        # Unknown (or not yet supported) codes.  Simply converted as numeric. 

        self.assertEqual("19", TSIGError(19).to_text()); 

        self.assertEqual("65535", TSIGError(65535).to_text()); 

 

        # also check str() works same way 

        self.assertEqual("NOERROR", str(TSIGError(Rcode.NOERROR()))) 

        self.assertEqual("BADSIG", str(TSIGError.BAD_SIG)) 

 

    def test_to_rcode(self): 

        # TSIGError derived from the standard Rcode 

        self.assertEqual(Rcode.NOERROR(), TSIGError(Rcode.NOERROR()).to_rcode()) 

 

        # Well known TSIG errors 

        self.assertEqual(Rcode.NOTAUTH(), TSIGError.BAD_SIG.to_rcode()) 

        self.assertEqual(Rcode.NOTAUTH(), TSIGError.BAD_KEY.to_rcode()) 

        self.assertEqual(Rcode.NOTAUTH(), TSIGError.BAD_TIME.to_rcode()) 

 

        # Unknown (or not yet supported) codes are treated as SERVFAIL. 

        self.assertEqual(Rcode.SERVFAIL(), TSIGError(19).to_rcode()) 

        self.assertEqual(Rcode.SERVFAIL(), TSIGError(65535).to_rcode()) 

 

        # Check there's no redundant refcount (which would cause leak) 

        self.assertEqual(1, sys.getrefcount(TSIGError.BAD_SIG.to_rcode())) 

 

exitif __name__ == '__main__': 

    unittest.main()