mirror of
https://gitlab.isc.org/isc-projects/bind9
synced 2025-08-30 14:07:59 +00:00
3893. [bug] Peer DSCP values could be returned without being set.
[RT #36538]
This commit is contained in:
3
CHANGES
3
CHANGES
@@ -1,3 +1,6 @@
|
|||||||
|
3893. [bug] Peer DSCP values could be returned without being set.
|
||||||
|
[RT #36538]
|
||||||
|
|
||||||
3892. [bug] Setting '-t aaaa' in .digrc had unintended side
|
3892. [bug] Setting '-t aaaa' in .digrc had unintended side
|
||||||
effects. [RT #36452]
|
effects. [RT #36452]
|
||||||
|
|
||||||
|
@@ -44,6 +44,9 @@
|
|||||||
#define SERVER_MAXUDP_BIT 7
|
#define SERVER_MAXUDP_BIT 7
|
||||||
#define REQUEST_NSID_BIT 8
|
#define REQUEST_NSID_BIT 8
|
||||||
#define REQUEST_SIT_BIT 9
|
#define REQUEST_SIT_BIT 9
|
||||||
|
#define NOTIFY_DSCP_BIT 10
|
||||||
|
#define TRANSFER_DSCP_BIT 11
|
||||||
|
#define QUERY_DSCP_BIT 12
|
||||||
|
|
||||||
static void
|
static void
|
||||||
peerlist_delete(dns_peerlist_t **list);
|
peerlist_delete(dns_peerlist_t **list);
|
||||||
@@ -749,6 +752,7 @@ dns_peer_setnotifydscp(dns_peer_t *peer, isc_dscp_t dscp) {
|
|||||||
REQUIRE(dscp < 64);
|
REQUIRE(dscp < 64);
|
||||||
|
|
||||||
peer->notify_dscp = dscp;
|
peer->notify_dscp = dscp;
|
||||||
|
DNS_BIT_SET(NOTIFY_DSCP_BIT, &peer->bitflags);
|
||||||
return (ISC_R_SUCCESS);
|
return (ISC_R_SUCCESS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -757,8 +761,11 @@ dns_peer_getnotifydscp(dns_peer_t *peer, isc_dscp_t *dscpp) {
|
|||||||
REQUIRE(DNS_PEER_VALID(peer));
|
REQUIRE(DNS_PEER_VALID(peer));
|
||||||
REQUIRE(dscpp != NULL);
|
REQUIRE(dscpp != NULL);
|
||||||
|
|
||||||
|
if (DNS_BIT_CHECK(NOTIFY_DSCP_BIT, &peer->bitflags)) {
|
||||||
*dscpp = peer->notify_dscp;
|
*dscpp = peer->notify_dscp;
|
||||||
return (ISC_R_SUCCESS);
|
return (ISC_R_SUCCESS);
|
||||||
|
}
|
||||||
|
return (ISC_R_NOTFOUND);
|
||||||
}
|
}
|
||||||
|
|
||||||
isc_result_t
|
isc_result_t
|
||||||
@@ -767,6 +774,7 @@ dns_peer_settransferdscp(dns_peer_t *peer, isc_dscp_t dscp) {
|
|||||||
REQUIRE(dscp < 64);
|
REQUIRE(dscp < 64);
|
||||||
|
|
||||||
peer->transfer_dscp = dscp;
|
peer->transfer_dscp = dscp;
|
||||||
|
DNS_BIT_SET(TRANSFER_DSCP_BIT, &peer->bitflags);
|
||||||
return (ISC_R_SUCCESS);
|
return (ISC_R_SUCCESS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -775,8 +783,11 @@ dns_peer_gettransferdscp(dns_peer_t *peer, isc_dscp_t *dscpp) {
|
|||||||
REQUIRE(DNS_PEER_VALID(peer));
|
REQUIRE(DNS_PEER_VALID(peer));
|
||||||
REQUIRE(dscpp != NULL);
|
REQUIRE(dscpp != NULL);
|
||||||
|
|
||||||
|
if (DNS_BIT_CHECK(TRANSFER_DSCP_BIT, &peer->bitflags)) {
|
||||||
*dscpp = peer->transfer_dscp;
|
*dscpp = peer->transfer_dscp;
|
||||||
return (ISC_R_SUCCESS);
|
return (ISC_R_SUCCESS);
|
||||||
|
}
|
||||||
|
return (ISC_R_NOTFOUND);
|
||||||
}
|
}
|
||||||
|
|
||||||
isc_result_t
|
isc_result_t
|
||||||
@@ -785,6 +796,7 @@ dns_peer_setquerydscp(dns_peer_t *peer, isc_dscp_t dscp) {
|
|||||||
REQUIRE(dscp < 64);
|
REQUIRE(dscp < 64);
|
||||||
|
|
||||||
peer->query_dscp = dscp;
|
peer->query_dscp = dscp;
|
||||||
|
DNS_BIT_SET(QUERY_DSCP_BIT, &peer->bitflags);
|
||||||
return (ISC_R_SUCCESS);
|
return (ISC_R_SUCCESS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -793,6 +805,9 @@ dns_peer_getquerydscp(dns_peer_t *peer, isc_dscp_t *dscpp) {
|
|||||||
REQUIRE(DNS_PEER_VALID(peer));
|
REQUIRE(DNS_PEER_VALID(peer));
|
||||||
REQUIRE(dscpp != NULL);
|
REQUIRE(dscpp != NULL);
|
||||||
|
|
||||||
|
if (DNS_BIT_CHECK(QUERY_DSCP_BIT, &peer->bitflags)) {
|
||||||
*dscpp = peer->query_dscp;
|
*dscpp = peer->query_dscp;
|
||||||
return (ISC_R_SUCCESS);
|
return (ISC_R_SUCCESS);
|
||||||
|
}
|
||||||
|
return (ISC_R_NOTFOUND);
|
||||||
}
|
}
|
||||||
|
@@ -48,6 +48,7 @@ SRCS = db_test.c \
|
|||||||
keytable_test.c \
|
keytable_test.c \
|
||||||
master_test.c \
|
master_test.c \
|
||||||
nsec3_test.c \
|
nsec3_test.c \
|
||||||
|
peer_test.c \
|
||||||
private_test.c \
|
private_test.c \
|
||||||
rbt_test.c \
|
rbt_test.c \
|
||||||
rbt_serialize_test.c \
|
rbt_serialize_test.c \
|
||||||
@@ -70,6 +71,7 @@ TARGETS = db_test@EXEEXT@ \
|
|||||||
keytable_test@EXEEXT@ \
|
keytable_test@EXEEXT@ \
|
||||||
master_test@EXEEXT@ \
|
master_test@EXEEXT@ \
|
||||||
nsec3_test@EXEEXT@ \
|
nsec3_test@EXEEXT@ \
|
||||||
|
peer_test@EXEEXT@ \
|
||||||
private_test@EXEEXT@ \
|
private_test@EXEEXT@ \
|
||||||
rbt_test@EXEEXT@ \
|
rbt_test@EXEEXT@ \
|
||||||
rbt_serialize_test@EXEEXT@ \
|
rbt_serialize_test@EXEEXT@ \
|
||||||
@@ -106,6 +108,11 @@ time_test@EXEEXT@: time_test.@O@ dnstest.@O@ ${ISCDEPLIBS} ${DNSDEPLIBS}
|
|||||||
time_test.@O@ dnstest.@O@ ${DNSLIBS} \
|
time_test.@O@ dnstest.@O@ ${DNSLIBS} \
|
||||||
${ISCLIBS} ${LIBS}
|
${ISCLIBS} ${LIBS}
|
||||||
|
|
||||||
|
peer_test@EXEEXT@: peer_test.@O@ dnstest.@O@ ${ISCDEPLIBS} ${DNSDEPLIBS}
|
||||||
|
${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ \
|
||||||
|
peer_test.@O@ dnstest.@O@ ${DNSLIBS} \
|
||||||
|
${ISCLIBS} ${LIBS}
|
||||||
|
|
||||||
private_test@EXEEXT@: private_test.@O@ dnstest.@O@ ${ISCDEPLIBS} ${DNSDEPLIBS}
|
private_test@EXEEXT@: private_test.@O@ dnstest.@O@ ${ISCDEPLIBS} ${DNSDEPLIBS}
|
||||||
${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ \
|
${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ \
|
||||||
private_test.@O@ dnstest.@O@ ${DNSLIBS} \
|
private_test.@O@ dnstest.@O@ ${DNSLIBS} \
|
||||||
|
145
lib/dns/tests/peer_test.c
Normal file
145
lib/dns/tests/peer_test.c
Normal file
@@ -0,0 +1,145 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2014 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! \file */
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
|
||||||
|
#include <atf-c.h>
|
||||||
|
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include <dns/peer.h>
|
||||||
|
|
||||||
|
#include "dnstest.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Individual unit tests
|
||||||
|
*/
|
||||||
|
ATF_TC(dscp);
|
||||||
|
ATF_TC_HEAD(dscp, tc) {
|
||||||
|
atf_tc_set_md_var(tc, "descr",
|
||||||
|
"Test DSCP set/get functions");
|
||||||
|
}
|
||||||
|
ATF_TC_BODY(dscp, tc) {
|
||||||
|
isc_result_t result;
|
||||||
|
isc_netaddr_t netaddr;
|
||||||
|
struct in_addr ina;
|
||||||
|
dns_peer_t *peer = NULL;
|
||||||
|
isc_dscp_t dscp;
|
||||||
|
|
||||||
|
result = dns_test_begin(NULL, ISC_TRUE);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Create peer structure for the loopback address.
|
||||||
|
*/
|
||||||
|
ina.s_addr = INADDR_LOOPBACK;
|
||||||
|
isc_netaddr_fromin(&netaddr, &ina);
|
||||||
|
result = dns_peer_new(mctx, &netaddr, &peer);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* All should be not set on creation.
|
||||||
|
* 'dscp' should remain unchanged.
|
||||||
|
*/
|
||||||
|
dscp = 100;
|
||||||
|
result = dns_peer_getquerydscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_NOTFOUND);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 100);
|
||||||
|
|
||||||
|
result = dns_peer_getnotifydscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_NOTFOUND);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 100);
|
||||||
|
|
||||||
|
result = dns_peer_gettransferdscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_NOTFOUND);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 100);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test that setting query dscp does not affect the other
|
||||||
|
* dscp values. 'dscp' should remain unchanged until
|
||||||
|
* dns_peer_getquerydscp is called.
|
||||||
|
*/
|
||||||
|
dscp = 100;
|
||||||
|
result = dns_peer_setquerydscp(peer, 1);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
|
||||||
|
result = dns_peer_getnotifydscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_NOTFOUND);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 100);
|
||||||
|
|
||||||
|
result = dns_peer_gettransferdscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_NOTFOUND);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 100);
|
||||||
|
|
||||||
|
result = dns_peer_getquerydscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test that setting notify dscp does not affect the other
|
||||||
|
* dscp values. 'dscp' should remain unchanged until
|
||||||
|
* dns_peer_getquerydscp is called then should change again
|
||||||
|
* on dns_peer_getnotifydscp.
|
||||||
|
*/
|
||||||
|
dscp = 100;
|
||||||
|
result = dns_peer_setnotifydscp(peer, 2);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
|
||||||
|
result = dns_peer_gettransferdscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_NOTFOUND);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 100);
|
||||||
|
|
||||||
|
result = dns_peer_getquerydscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 1);
|
||||||
|
|
||||||
|
result = dns_peer_getnotifydscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 2);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test that setting notify dscp does not affect the other
|
||||||
|
* dscp values. Check that appropriate values are returned.
|
||||||
|
*/
|
||||||
|
dscp = 100;
|
||||||
|
result = dns_peer_settransferdscp(peer, 3);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
|
||||||
|
result = dns_peer_getquerydscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 1);
|
||||||
|
|
||||||
|
result = dns_peer_getnotifydscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 2);
|
||||||
|
|
||||||
|
result = dns_peer_gettransferdscp(peer, &dscp);
|
||||||
|
ATF_REQUIRE_EQ(result, ISC_R_SUCCESS);
|
||||||
|
ATF_REQUIRE_EQ(dscp, 3);
|
||||||
|
|
||||||
|
dns_peer_detach(&peer);
|
||||||
|
dns_test_end();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Main
|
||||||
|
*/
|
||||||
|
ATF_TP_ADD_TCS(tp) {
|
||||||
|
ATF_TP_ADD_TC(tp, dscp);
|
||||||
|
return (atf_no_error());
|
||||||
|
}
|
Reference in New Issue
Block a user