add unit test for extract_peer_info

This commit is contained in:
Arvid Norberg 2015-05-10 18:24:38 +00:00
parent 242dad0743
commit 0029ac62a8
4 changed files with 56 additions and 2 deletions

View File

@ -698,7 +698,6 @@ KADEMLIA_SOURCES =
node_id node_id
routing_table routing_table
traversal_algorithm traversal_algorithm
logging
dos_blocker dos_blocker
get_peers get_peers
item item

View File

@ -102,7 +102,6 @@ namespace libtorrent
char const* data, int size, error_code& ec char const* data, int size, error_code& ec
, bool scrape_request, sha1_hash scrape_ih); , bool scrape_request, sha1_hash scrape_ih);
// TODO: 3 add a unit test for this function
TORRENT_EXTRA_EXPORT bool extract_peer_info(bdecode_node const& info TORRENT_EXTRA_EXPORT bool extract_peer_info(bdecode_node const& info
, peer_entry& ret, error_code& ec); , peer_entry& ret, error_code& ec);
} }

View File

@ -376,6 +376,8 @@ namespace libtorrent
close(); close();
} }
// TODO: 2 returning a bool here is redundant. Instead this function should
// return the peer_entry
bool extract_peer_info(bdecode_node const& info, peer_entry& ret, error_code& ec) bool extract_peer_info(bdecode_node const& info, peer_entry& ret, error_code& ec)
{ {
// extract peer id (if any) // extract peer id (if any)

View File

@ -181,8 +181,62 @@ void test_parse_external_ip6()
} }
#endif #endif
peer_entry extract_peer(char const* peer_field, error_code expected_ec, bool expected_ret)
{
error_code ec;
peer_entry result;
bdecode_node n;
bdecode(peer_field, peer_field + strlen(peer_field)
, n, ec, NULL, 1000, 1000);
TEST_CHECK(!ec);
bool ret = extract_peer_info(n, result, ec);
TEST_EQUAL(expected_ret, ret);
TEST_EQUAL(expected_ec, ec);
return result;
}
void test_extract_peer()
{
{
peer_entry result = extract_peer("d7:peer id20:abababababababababab2:ip4:abcd4:porti1337ee"
, error_code(), true);
TEST_EQUAL(result.hostname, "abcd");
TEST_EQUAL(result.pid, peer_id("abababababababababab"));
TEST_EQUAL(result.port, 1337);
}
{
peer_entry result = extract_peer("d2:ip11:example.com4:porti1ee"
, error_code(), true);
TEST_EQUAL(result.hostname, "example.com");
TEST_EQUAL(result.pid, (peer_id::min)());
TEST_EQUAL(result.port, 1);
}
{
// not a dictionary
peer_entry result = extract_peer("2:ip11:example.com"
, error_code(errors::invalid_peer_dict, get_libtorrent_category()), false);
}
{
// missing IP
peer_entry result = extract_peer("d7:peer id20:abababababababababab4:porti1337ee"
, error_code(errors::invalid_tracker_response, get_libtorrent_category()), false);
}
{
// missing port
peer_entry result = extract_peer("d7:peer id20:abababababababababab2:ip4:abcde"
, error_code(errors::invalid_tracker_response, get_libtorrent_category()), false);
}
}
int test_main() int test_main()
{ {
test_extract_peer();
test_parse_hostname_peers(); test_parse_hostname_peers();
test_parse_peers4(); test_parse_peers4();
test_parse_interval(); test_parse_interval();