|
reSIProcate/stack
9694
|
#include <iostream>#include "rutil/resipfaststreams.hxx"#include "rutil/Inserter.hxx"#include "resip/stack/Connection.hxx"#include "resip/stack/Tuple.hxx"
Go to the source code of this file.
Functions | |
| int | main () |
| int main | ( | void | ) |
Definition at line 15 of file testTuple.cxx.
References resip::Tuple::hash(), resip::Inserter(), resip::Tuple::isEqualWithMask(), resip::Tuple::isLoopback(), resip::Tuple::isPrivateAddress(), resip::Tuple::makeTupleFromBinaryToken(), resip::Tuple::mFlowKey, resip::Tuple::onlyUseExistingConnection, resipCerr, resip::TCP, resip::UDP, resip::V4, resip::V6, and resip::Tuple::writeBinaryToken().
{
typedef HashMap<Tuple, Connection*> AddrMap;
//typedef std::map<Tuple, Connection*> AddrMap;
// Test isPrivateAddress function - v4
{
Tuple testTuple("192.168.1.106", 5069, V4, TCP);
assert(testTuple.isPrivateAddress());
Tuple testTuple2("10.0.0.5", 5069, V4, TCP);
assert(testTuple2.isPrivateAddress());
Tuple testTuple3("172.16.10.5", 5069, V4, TCP);
assert(testTuple3.isPrivateAddress());
Tuple testTuple4("150.1.1.106", 5069, V4, TCP);
assert(!testTuple4.isPrivateAddress());
Tuple testTuple5("127.0.0.1", 5069, V4, TCP);
assert(!testTuple5.isPrivateAddress());
}
#ifdef USE_IPV6
// Test isPrivateAddress function - v6
{
Tuple testTuple("fd00::1", 5069, V6, TCP);
assert(testTuple.isPrivateAddress());
Tuple testTuple1("fd9b:70f6:0a18:31cc::1", 5069, V6, TCP);
assert(testTuple1.isPrivateAddress());
Tuple testTuple2("fe80::1", 5069, V6, TCP); // Link Local ?slg? do we want this to return private or not? For now we do only RFC 4193
assert(!testTuple2.isPrivateAddress());
Tuple testTuple3("::ffff:10.0.0.5", 5069, V6, TCP); // V4 mapped
assert(!testTuple3.isPrivateAddress());
Tuple testTuple4("::ffff:150.1.1.106", 5069, V6, TCP); // ?slg? do we want this to return private or not? For now we do only RFC 4193
assert(!testTuple4.isPrivateAddress());
Tuple testTuple5("::10.0.0.5", 5069, V6, TCP); // V4 compatible
assert(!testTuple5.isPrivateAddress());
Tuple testTuple6("::150.1.1.106", 5069, V6, TCP); // ?slg? do we want this to return private or not? For now we do only RFC 4193
assert(!testTuple6.isPrivateAddress());
Tuple testTuple7("2000:1::203:baff:fe30:1176", 5069, V6, TCP);
assert(!testTuple7.isPrivateAddress());
}
#endif
{
Tuple testTuple("192.168.1.106", 5069, V4, TCP);
Data binaryToken;
Tuple::writeBinaryToken(testTuple, binaryToken);
Data binaryTokenWithSalt;
Tuple::writeBinaryToken(testTuple, binaryTokenWithSalt, "salt");
Tuple madeTestTuple = Tuple::makeTupleFromBinaryToken(binaryToken);
Tuple madeTestTupleWithSalt = Tuple::makeTupleFromBinaryToken(binaryTokenWithSalt, "salt");
Tuple madeTestTupleWithBadSalt = Tuple::makeTupleFromBinaryToken(binaryTokenWithSalt, "badsalt");
assert(testTuple == madeTestTuple);
assert(testTuple.onlyUseExistingConnection == madeTestTuple.onlyUseExistingConnection);
assert(testTuple.mFlowKey == madeTestTuple.mFlowKey);
assert(testTuple == madeTestTupleWithSalt);
assert(testTuple.onlyUseExistingConnection == madeTestTupleWithSalt.onlyUseExistingConnection);
assert(testTuple.mFlowKey == madeTestTupleWithSalt.mFlowKey);
assert(madeTestTupleWithBadSalt == Tuple());
}
#ifdef USE_IPV6
{
Tuple testTuple("2000:1::203:baff:fe30:1176", 5069, V6, TCP);
Data binaryToken;
Tuple::writeBinaryToken(testTuple, binaryToken);
Data binaryTokenWithSalt;
Tuple::writeBinaryToken(testTuple, binaryTokenWithSalt, "salt");
Tuple madeTestTuple = Tuple::makeTupleFromBinaryToken(binaryToken);
Tuple madeTestTupleWithSalt = Tuple::makeTupleFromBinaryToken(binaryTokenWithSalt, "salt");
Tuple madeTestTupleWithBadSalt = Tuple::makeTupleFromBinaryToken(binaryTokenWithSalt, "badsalt");
assert(testTuple == madeTestTuple);
assert(testTuple.onlyUseExistingConnection == madeTestTuple.onlyUseExistingConnection);
assert(testTuple.mFlowKey == madeTestTuple.mFlowKey);
assert(testTuple == madeTestTupleWithSalt);
assert(testTuple.onlyUseExistingConnection == madeTestTupleWithSalt.onlyUseExistingConnection);
assert(testTuple.mFlowKey == madeTestTupleWithSalt.mFlowKey);
assert(madeTestTupleWithBadSalt == Tuple());
}
#endif
#ifdef USE_IPV6
{
AddrMap mMap;
Tuple t("2000:1::203:baff:fe30:1176", 5100, V6, TCP);
Tuple s = t;
assert(s == t);
assert(s.hash() == t.hash());
mMap[t] = 0;
resipCerr << mMap.count(t) << endl;
resipCerr << Inserter(mMap) << std::endl;
assert(mMap.count(t) == 1);
}
#endif
{
Tuple t1("192.168.1.2", 2060, UDP);
Tuple t2("192.168.1.2", 2060, UDP);
Tuple t3("192.168.1.3", 2060, UDP);
Tuple t4("192.1.2.3", 2061, UDP);
Tuple t5("192.168.1.2", 2060, TCP);
Tuple t6("192.168.1.2", 2061, UDP);
Tuple loopback("127.0.0.1",2062,TCP);
assert(t1.isEqualWithMask(t2, 32, false /* ignorePort? */));
assert(!t1.isEqualWithMask(t3, 32, false)); // address is different
assert(t1.isEqualWithMask(t3, 24, false));
assert(t1.isEqualWithMask(t4, 8, true));
assert(!t1.isEqualWithMask(t5, 8, true)); // transport type is different
assert(!t1.isEqualWithMask(t6, 8, false)); // port is different
assert(loopback.isLoopback());
assert(!t1.isLoopback());
resip::Data token1;
resip::Data token2;
resip::Data token3;
resip::Data token4;
resip::Data token5;
resip::Data token6;
resip::Data tokenloopback;
Tuple::writeBinaryToken(t1,token1);
Tuple::writeBinaryToken(t2,token2);
Tuple::writeBinaryToken(t3,token3);
Tuple::writeBinaryToken(t4,token4);
Tuple::writeBinaryToken(t5,token5);
Tuple::writeBinaryToken(t6,token6);
Tuple::writeBinaryToken(loopback,tokenloopback);
Tuple t1prime=Tuple::makeTupleFromBinaryToken(token1);
Tuple t2prime=Tuple::makeTupleFromBinaryToken(token2);
Tuple t3prime=Tuple::makeTupleFromBinaryToken(token3);
Tuple t4prime=Tuple::makeTupleFromBinaryToken(token4);
Tuple t5prime=Tuple::makeTupleFromBinaryToken(token5);
Tuple t6prime=Tuple::makeTupleFromBinaryToken(token6);
Tuple loopbackprime=Tuple::makeTupleFromBinaryToken(tokenloopback);
assert(t1==t1prime);
assert(t2==t2prime);
assert(t3==t3prime);
assert(t4==t4prime);
assert(t5==t5prime);
assert(t6==t6prime);
assert(loopback==loopbackprime);
assert(t1.onlyUseExistingConnection == t1prime.onlyUseExistingConnection);
assert(t2.onlyUseExistingConnection == t2prime.onlyUseExistingConnection);
assert(t3.onlyUseExistingConnection == t3prime.onlyUseExistingConnection);
assert(t4.onlyUseExistingConnection == t4prime.onlyUseExistingConnection);
assert(t5.onlyUseExistingConnection == t5prime.onlyUseExistingConnection);
assert(t6.onlyUseExistingConnection == t6prime.onlyUseExistingConnection);
assert(loopback.onlyUseExistingConnection == loopbackprime.onlyUseExistingConnection);
assert(t1.mFlowKey == t1prime.mFlowKey);
assert(t2.mFlowKey == t2prime.mFlowKey);
assert(t3.mFlowKey == t3prime.mFlowKey);
assert(t4.mFlowKey == t4prime.mFlowKey);
assert(t5.mFlowKey == t5prime.mFlowKey);
assert(t6.mFlowKey == t6prime.mFlowKey);
assert(loopback.mFlowKey == loopbackprime.mFlowKey);
}
#ifdef USE_IPV6
{
Tuple t1("2000:1::203:baff:fe30:1176", 2060, UDP);
Tuple t2("2000:1::203:baff:fe30:1176", 2060, UDP);
Tuple t3("2000:1::203:1111:2222:3333", 2060, UDP);
Tuple t4("2000:1::0000:1111:2222:3333", 2061, UDP);
Tuple t5("2000:1::204:1111:2222:3333", 2061, TCP);
Tuple t6("2000:1::203:baff:fe30:1177", 2060, UDP);
Tuple loopback("::1",2062,TCP);
assert(t1.isEqualWithMask(t2, 128, false /* ignorePort? */));
assert(t1.isEqualWithMask(t3, 80, false));
assert(t1.isEqualWithMask(t4, 64, true));
assert(!t1.isEqualWithMask(t5, 64, true)); // transport type is different
assert(t1.isEqualWithMask(t6, 120, false));
assert(loopback.isLoopback());
assert(!t1.isLoopback());
resip::Data token1;
resip::Data token2;
resip::Data token3;
resip::Data token4;
resip::Data token5;
resip::Data token6;
resip::Data tokenloopback;
Tuple::writeBinaryToken(t1,token1);
Tuple::writeBinaryToken(t2,token2);
Tuple::writeBinaryToken(t3,token3);
Tuple::writeBinaryToken(t4,token4);
Tuple::writeBinaryToken(t5,token5);
Tuple::writeBinaryToken(t6,token6);
Tuple::writeBinaryToken(loopback,tokenloopback);
Tuple t1prime=Tuple::makeTupleFromBinaryToken(token1);
Tuple t2prime=Tuple::makeTupleFromBinaryToken(token2);
Tuple t3prime=Tuple::makeTupleFromBinaryToken(token3);
Tuple t4prime=Tuple::makeTupleFromBinaryToken(token4);
Tuple t5prime=Tuple::makeTupleFromBinaryToken(token5);
Tuple t6prime=Tuple::makeTupleFromBinaryToken(token6);
Tuple loopbackprime=Tuple::makeTupleFromBinaryToken(tokenloopback);
assert(t1==t1prime);
assert(t2==t2prime);
assert(t3==t3prime);
assert(t4==t4prime);
assert(t5==t5prime);
assert(t6==t6prime);
assert(loopback==loopbackprime);
assert(t1.onlyUseExistingConnection == t1prime.onlyUseExistingConnection);
assert(t2.onlyUseExistingConnection == t2prime.onlyUseExistingConnection);
assert(t3.onlyUseExistingConnection == t3prime.onlyUseExistingConnection);
assert(t4.onlyUseExistingConnection == t4prime.onlyUseExistingConnection);
assert(t5.onlyUseExistingConnection == t5prime.onlyUseExistingConnection);
assert(t6.onlyUseExistingConnection == t6prime.onlyUseExistingConnection);
assert(loopback.onlyUseExistingConnection == loopbackprime.onlyUseExistingConnection);
assert(t1.mFlowKey == t1prime.mFlowKey);
assert(t2.mFlowKey == t2prime.mFlowKey);
assert(t3.mFlowKey == t3prime.mFlowKey);
assert(t4.mFlowKey == t4prime.mFlowKey);
assert(t5.mFlowKey == t5prime.mFlowKey);
assert(t6.mFlowKey == t6prime.mFlowKey);
assert(loopback.mFlowKey == loopbackprime.mFlowKey);
}
#endif
resipCerr << "ALL OK" << std::endl;
}

1.7.5.1