fix test support for platforms not supporting IPv6

This commit is contained in:
Arvid Norberg 2013-01-06 22:41:56 +00:00
parent 5b638c3c9e
commit 72d4999ca4
1 changed files with 19 additions and 15 deletions

View File

@ -32,6 +32,7 @@ POSSIBILITY OF SUCH DAMAGE.
#include "libtorrent/policy.hpp" #include "libtorrent/policy.hpp"
#include "libtorrent/hasher.hpp" #include "libtorrent/hasher.hpp"
#include "libtorrent/broadcast_socket.hpp" // for supports_ipv6()
#include "test.hpp" #include "test.hpp"
@ -76,21 +77,24 @@ int test_main()
, tcp::endpoint(address::from_string("230.12.123.3"), 0x12c)); , tcp::endpoint(address::from_string("230.12.123.3"), 0x12c));
TEST_EQUAL(p, hash_buffer("\xe6\x0c\x51\x01\xe6\x78\x15\x01", 8)); TEST_EQUAL(p, hash_buffer("\xe6\x0c\x51\x01\xe6\x78\x15\x01", 8));
// IPv6 has a twice as wide mask, and we only care about the top 64 bits if (supports_ipv6())
// when the IPs are the same, just hash the ports {
p = peer_priority( // IPv6 has a twice as wide mask, and we only care about the top 64 bits
tcp::endpoint(address::from_string("ffff:ffff:ffff:ffff::1"), 0x4d2) // when the IPs are the same, just hash the ports
, tcp::endpoint(address::from_string("ffff:ffff:ffff:ffff::1"), 0x12c)); p = peer_priority(
TEST_EQUAL(p, hash_buffer("\x01\x2c\x04\xd2", 4)); tcp::endpoint(address::from_string("ffff:ffff:ffff:ffff::1"), 0x4d2)
, tcp::endpoint(address::from_string("ffff:ffff:ffff:ffff::1"), 0x12c));
// these IPs don't belong to the same /32, so apply the full mask TEST_EQUAL(p, hash_buffer("\x01\x2c\x04\xd2", 4));
// 0xffffffff55555555
p = peer_priority( // these IPs don't belong to the same /32, so apply the full mask
tcp::endpoint(address::from_string("ffff:ffff:ffff:ffff::1"), 0x4d2) // 0xffffffff55555555
, tcp::endpoint(address::from_string("ffff:0fff:ffff:ffff::1"), 0x12c)); p = peer_priority(
TEST_EQUAL(p, hash_buffer( tcp::endpoint(address::from_string("ffff:ffff:ffff:ffff::1"), 0x4d2)
"\xff\xff\x0f\xff\x55\x55\x55\x55\x00\x00\x00\x00\x00\x00\x00\x01" , tcp::endpoint(address::from_string("ffff:0fff:ffff:ffff::1"), 0x12c));
"\xff\xff\xff\xff\x55\x55\x55\x55\x00\x00\x00\x00\x00\x00\x00\x01", 32)); TEST_EQUAL(p, hash_buffer(
"\xff\xff\x0f\xff\x55\x55\x55\x55\x00\x00\x00\x00\x00\x00\x00\x01"
"\xff\xff\xff\xff\x55\x55\x55\x55\x00\x00\x00\x00\x00\x00\x00\x01", 32));
}
return 0; return 0;
} }