rdata_nsec3param_unittest.cc 4.33 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// Copyright (C) 2010  Internet Systems Consortium, Inc. ("ISC")
//
// Permission to use, copy, modify, and/or 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 ISC DISCLAIMS ALL WARRANTIES WITH
// REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
// AND FITNESS.  IN NO EVENT SHALL ISC 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.

#include <string>

17
18
#include <exceptions/exceptions.h>

chenzhengzhang's avatar
chenzhengzhang committed
19
20
#include <util/encode/base32hex.h>
#include <util/encode/hex.h>
21
#include <util/buffer.h>
22
23
24
25
26
27
28
29
#include <dns/messagerenderer.h>
#include <dns/rdata.h>
#include <dns/rdataclass.h>
#include <dns/rrclass.h>
#include <dns/rrtype.h>

#include <gtest/gtest.h>

30
31
#include <dns/tests/unittest_util.h>
#include <dns/tests/rdata_unittest.h>
32
33
34

using isc::UnitTestUtil;
using namespace std;
35
using namespace isc;
36
using namespace isc::dns;
37
using namespace isc::util;
chenzhengzhang's avatar
chenzhengzhang committed
38
using namespace isc::util::encode;
39
40
41
42
using namespace isc::dns::rdata;

namespace {
class Rdata_NSEC3PARAM_Test : public RdataTest {
43
public:
44
    Rdata_NSEC3PARAM_Test() : nsec3param_txt("1 1 1 D399EAAB") {}
45
    const string nsec3param_txt;
46
};
47
48
49
50

TEST_F(Rdata_NSEC3PARAM_Test, fromText) {
    // With a salt
    EXPECT_EQ(1, generic::NSEC3PARAM(nsec3param_txt).getHashalg());
51
    EXPECT_EQ(1, generic::NSEC3PARAM(nsec3param_txt).getFlags());
52
53
54
55
56
    // (salt is checked in the toText test)

    // With an empty salt
    EXPECT_EQ(0, generic::NSEC3PARAM("1 0 0 -").getSalt().size());
}
57

58
TEST_F(Rdata_NSEC3PARAM_Test, toText) {
59
60
61
62
    const generic::NSEC3PARAM rdata_nsec3param(nsec3param_txt);
    EXPECT_EQ(nsec3param_txt, rdata_nsec3param.toText());
}

63
TEST_F(Rdata_NSEC3PARAM_Test, badText) {
64
65
66
    // garbage space at the end
    EXPECT_THROW(generic::NSEC3PARAM("1 1 1 D399EAAB "),
                 InvalidRdataText);
67
68
}

69
TEST_F(Rdata_NSEC3PARAM_Test, createFromWire) {
70
71
72
    const generic::NSEC3PARAM rdata_nsec3param(nsec3param_txt);
    EXPECT_EQ(0, rdata_nsec3param.compare(
                  *rdataFactoryFromFile(RRType::NSEC3PARAM(), RRClass::IN(),
73
                                       "rdata_nsec3param_fromWire1")));
74
75
76
77
78
79
80
81
82
83
84
85
86

    // Short buffer cases.  The data is valid NSEC3PARAM RDATA, but the buffer
    // is trimmed at the end.  All cases should result in an exception from
    // the buffer class.
    vector<uint8_t> data;
    UnitTestUtil::readWireData("rdata_nsec3param_fromWire1", data);
    const uint16_t rdlen = (data.at(0) << 8) + data.at(1);
    for (int i = 0; i < rdlen; ++i) {
        // intentionally construct a short buffer
        InputBuffer b(&data[0] + 2, i);
        EXPECT_THROW(createRdata(RRType::NSEC3PARAM(), RRClass::IN(), b, 9),
                     InvalidBufferPosition);
    }
87
88
}

89
TEST_F(Rdata_NSEC3PARAM_Test, toWireRenderer) {
90
91
92
93
94
    renderer.skip(2);
    const generic::NSEC3PARAM rdata_nsec3param(nsec3param_txt);
    rdata_nsec3param.toWire(renderer);

    vector<unsigned char> data;
95
    UnitTestUtil::readWireData("rdata_nsec3param_fromWire1", data);
96
97
98
99
100
    EXPECT_PRED_FORMAT4(UnitTestUtil::matchWireData,
                        static_cast<const uint8_t *>(obuffer.getData()) + 2,
                        obuffer.getLength() - 2, &data[2], data.size() - 2);
}

101
TEST_F(Rdata_NSEC3PARAM_Test, toWireBuffer) {
102
103
104
105
    const generic::NSEC3PARAM rdata_nsec3param(nsec3param_txt);
    rdata_nsec3param.toWire(obuffer);
}

106
TEST_F(Rdata_NSEC3PARAM_Test, assign) {
107
108
109
110
111
    generic::NSEC3PARAM rdata_nsec3param(nsec3param_txt);
    generic::NSEC3PARAM other_nsec3param = rdata_nsec3param;
    EXPECT_EQ(0, rdata_nsec3param.compare(other_nsec3param));
}

112
113
114
115
116
117
118
119
120
121
122
123
TEST_F(Rdata_NSEC3PARAM_Test, compare) {
    // trivial case: self equivalence
    EXPECT_EQ(0, generic::NSEC3PARAM(nsec3param_txt).
              compare(generic::NSEC3PARAM(nsec3param_txt)));
    EXPECT_EQ(0, generic::NSEC3PARAM("1 1 1 -").
              compare(generic::NSEC3PARAM("1 1 1 -")));

    // comparison attempt between incompatible RR types should be rejected
    EXPECT_THROW(generic::NSEC3PARAM(nsec3param_txt).compare(*rdata_nomatch),
                 bad_cast);
}

124
}