messagerenderer_python_test.py 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. # Copyright (C) 2010 Internet Systems Consortium.
  2. #
  3. # Permission to use, copy, modify, and distribute this software for any
  4. # purpose with or without fee is hereby granted, provided that the above
  5. # copyright notice and this permission notice appear in all copies.
  6. #
  7. # THE SOFTWARE IS PROVIDED "AS IS" AND INTERNET SYSTEMS CONSORTIUM
  8. # DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL
  9. # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL
  10. # INTERNET SYSTEMS CONSORTIUM BE LIABLE FOR ANY SPECIAL, DIRECT,
  11. # INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING
  12. # FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
  13. # NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
  14. # WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. #
  16. # Tests for the messagerenderer part of the pydnspp module
  17. #
  18. import unittest
  19. import os
  20. from pydnspp import *
  21. class MessageRendererTest(unittest.TestCase):
  22. def setUp(self):
  23. name = Name("example.com")
  24. c = RRClass("IN")
  25. t = RRType("A")
  26. ttl = RRTTL("3600")
  27. message = Message(Message.RENDER)
  28. message.set_qid(123)
  29. message.set_opcode(Opcode.QUERY())
  30. message.set_rcode(Rcode.NOERROR())
  31. message.add_question(Question(name, c, t))
  32. self.message1 = message
  33. message = Message(Message.RENDER)
  34. message.set_qid(123)
  35. message.set_header_flag(Message.HEADERFLAG_AA, True)
  36. message.set_header_flag(Message.HEADERFLAG_QR, True)
  37. message.set_opcode(Opcode.QUERY())
  38. message.set_rcode(Rcode.NOERROR())
  39. message.add_question(Question(name, c, t))
  40. rrset = RRset(name, c, t, ttl)
  41. rrset.add_rdata(Rdata(t, c, "192.0.2.98"))
  42. rrset.add_rdata(Rdata(t, c, "192.0.2.99"))
  43. message.add_rrset(Message.SECTION_AUTHORITY, rrset)
  44. self.message2 = message
  45. self.renderer1 = MessageRenderer()
  46. self.renderer2 = MessageRenderer()
  47. self.renderer3 = MessageRenderer()
  48. self.renderer3.set_length_limit(50)
  49. self.message1.to_wire(self.renderer1)
  50. self.message2.to_wire(self.renderer2)
  51. self.message2.to_wire(self.renderer3)
  52. def test_messagerenderer_get_data(self):
  53. data1 = b'\x00{\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x07example\x03com\x00\x00\x01\x00\x01'
  54. self.assertEqual(data1, self.renderer1.get_data())
  55. data2 = b'\x00{\x84\x00\x00\x01\x00\x00\x00\x02\x00\x00\x07example\x03com\x00\x00\x01\x00\x01\xc0\x0c\x00\x01\x00\x01\x00\x00\x0e\x10\x00\x04\xc0\x00\x02b\xc0\x0c\x00\x01\x00\x01\x00\x00\x0e\x10\x00\x04\xc0\x00\x02c'
  56. self.assertEqual(data2, self.renderer2.get_data())
  57. def test_messagerenderer_get_length(self):
  58. self.assertEqual(29, self.renderer1.get_length())
  59. self.assertEqual(61, self.renderer2.get_length())
  60. self.assertEqual(45, self.renderer3.get_length())
  61. def test_messagerenderer_is_truncated(self):
  62. self.assertFalse(self.renderer1.is_truncated())
  63. self.assertFalse(self.renderer2.is_truncated())
  64. self.assertTrue(self.renderer3.is_truncated())
  65. def test_messagerenderer_get_length_limit(self):
  66. self.assertEqual(512, self.renderer1.get_length_limit())
  67. self.assertEqual(512, self.renderer2.get_length_limit())
  68. self.assertEqual(50, self.renderer3.get_length_limit())
  69. def test_messagerenderer_get_compress_mode(self):
  70. self.assertEqual(MessageRenderer.CASE_INSENSITIVE,
  71. self.renderer1.get_compress_mode())
  72. self.assertEqual(MessageRenderer.CASE_INSENSITIVE,
  73. self.renderer2.get_compress_mode())
  74. self.assertEqual(MessageRenderer.CASE_INSENSITIVE,
  75. self.renderer3.get_compress_mode())
  76. def test_messagerenderer_set_truncated(self):
  77. self.assertFalse(self.renderer1.is_truncated())
  78. self.renderer1.set_truncated()
  79. self.assertTrue(self.renderer1.is_truncated())
  80. def test_messagerenderer_set_length_limit(self):
  81. renderer = MessageRenderer()
  82. self.assertEqual(512, renderer.get_length_limit())
  83. renderer.set_length_limit(1024)
  84. self.assertEqual(1024, renderer.get_length_limit())
  85. self.assertRaises(TypeError, renderer.set_length_limit, "wrong")
  86. # Range check. We need to do this at the binding level, so we need
  87. # explicit tests for it.
  88. renderer.set_length_limit(0)
  89. self.assertEqual(0, renderer.get_length_limit())
  90. self.assertRaises(ValueError, renderer.set_length_limit, -1)
  91. def test_messagerenderer_set_compress_mode(self):
  92. renderer = MessageRenderer()
  93. self.assertEqual(MessageRenderer.CASE_INSENSITIVE,
  94. renderer.get_compress_mode())
  95. renderer.set_compress_mode(MessageRenderer.CASE_SENSITIVE)
  96. self.assertEqual(MessageRenderer.CASE_SENSITIVE,
  97. renderer.get_compress_mode())
  98. renderer.set_compress_mode(MessageRenderer.CASE_INSENSITIVE)
  99. self.assertEqual(MessageRenderer.CASE_INSENSITIVE,
  100. renderer.get_compress_mode())
  101. self.assertRaises(TypeError, renderer.set_compress_mode, "wrong")
  102. if __name__ == '__main__':
  103. unittest.main()