rdata_ds_unittest.cc 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. // Copyright (C) 2010 Internet Systems Consortium, Inc. ("ISC")
  2. //
  3. // Permission to use, copy, modify, and/or 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 ISC DISCLAIMS ALL WARRANTIES WITH
  8. // REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  9. // AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
  10. // INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  11. // LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
  12. // OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  13. // PERFORMANCE OF THIS SOFTWARE.
  14. #include <string>
  15. #include <util/buffer.h>
  16. #include <dns/messagerenderer.h>
  17. #include <dns/rdata.h>
  18. #include <dns/rdataclass.h>
  19. #include <dns/rrclass.h>
  20. #include <dns/rrtype.h>
  21. #include <gtest/gtest.h>
  22. #include <dns/tests/unittest_util.h>
  23. #include <dns/tests/rdata_unittest.h>
  24. using isc::UnitTestUtil;
  25. using namespace std;
  26. using namespace isc::dns;
  27. using namespace isc::util;
  28. using namespace isc::dns::rdata;
  29. namespace {
  30. class Rdata_DS_Test : public RdataTest {
  31. // there's nothing to specialize
  32. };
  33. string ds_txt("12892 5 2 F1E184C0E1D615D20EB3C223ACED3B03C773DD952D"
  34. "5F0EB5C777586DE18DA6B5");
  35. const generic::DS rdata_ds(ds_txt);
  36. TEST_F(Rdata_DS_Test, toText_DS) {
  37. EXPECT_EQ(ds_txt, rdata_ds.toText());
  38. }
  39. TEST_F(Rdata_DS_Test, badText_DS) {
  40. EXPECT_THROW(const generic::DS ds2("99999 5 2 BEEF"), InvalidRdataText);
  41. EXPECT_THROW(const generic::DS ds2("11111 555 2 BEEF"), InvalidRdataText);
  42. EXPECT_THROW(const generic::DS ds2("11111 5 22222 BEEF"), InvalidRdataText);
  43. EXPECT_THROW(const generic::DS ds2("11111 5 2"), InvalidRdataText);
  44. EXPECT_THROW(const generic::DS ds2("GARBAGE IN"), InvalidRdataText);
  45. }
  46. // this test currently fails; we must fix it, and then migrate the test to
  47. // badText_DS
  48. TEST_F(Rdata_DS_Test, DISABLED_badText_DS) {
  49. // no space between the digest type and the digest.
  50. EXPECT_THROW(const generic::DS ds2(
  51. "12892 5 2F1E184C0E1D615D20EB3C223ACED3B03C773DD952D"
  52. "5F0EB5C777586DE18DA6B5"), InvalidRdataText);
  53. }
  54. TEST_F(Rdata_DS_Test, createFromWire_DS) {
  55. EXPECT_EQ(0, rdata_ds.compare(
  56. *rdataFactoryFromFile(RRType::DS(), RRClass::IN(),
  57. "rdata_ds_fromWire")));
  58. }
  59. TEST_F(Rdata_DS_Test, getTag_DS) {
  60. EXPECT_EQ(12892, rdata_ds.getTag());
  61. }
  62. TEST_F(Rdata_DS_Test, toWireRenderer) {
  63. renderer.skip(2);
  64. generic::DS rdata_ds(ds_txt);
  65. rdata_ds.toWire(renderer);
  66. vector<unsigned char> data;
  67. UnitTestUtil::readWireData("rdata_ds_fromWire", data);
  68. EXPECT_PRED_FORMAT4(UnitTestUtil::matchWireData,
  69. static_cast<const uint8_t *>(obuffer.getData()) + 2,
  70. obuffer.getLength() - 2, &data[2], data.size() - 2);
  71. }
  72. TEST_F(Rdata_DS_Test, toWireBuffer) {
  73. generic::DS rdata_ds(ds_txt);
  74. rdata_ds.toWire(obuffer);
  75. }
  76. TEST_F(Rdata_DS_Test, compare) {
  77. // trivial case: self equivalence
  78. EXPECT_EQ(0, generic::DS(ds_txt).compare(generic::DS(ds_txt)));
  79. // TODO: need more tests
  80. }
  81. }