improve print-out of fast extension test

This commit is contained in:
Arvid Norberg 2011-02-13 03:16:53 +00:00
parent 8e8b0495e1
commit d73f4f0c92
1 changed files with 44 additions and 14 deletions

View File

@ -64,10 +64,47 @@ int read_message(stream_socket& s, char* buffer)
return length; return length;
} }
void print_message(char const* buffer, int len)
{
char const* message_name[] = {"choke", "unchoke", "interested", "not_interested" char const* message_name[] = {"choke", "unchoke", "interested", "not_interested"
, "have", "bitfield", "request", "piece", "cancel", "dht_port", "", "", "" , "have", "bitfield", "request", "piece", "cancel", "dht_port", "", "", ""
, "suggest_piece", "have_all", "have_none", "reject_request", "allowed_fast"}; , "suggest_piece", "have_all", "have_none", "reject_request", "allowed_fast"};
char message[50];
char extra[300];
extra[0] = 0;
if (len == 0)
{
strcpy(message, "keepalive");
}
else
{
int msg = buffer[0];
if (msg >= 0 && msg < int(sizeof(message_name)/sizeof(message_name[0])))
strcpy(message, message_name[msg]);
else
snprintf(message, sizeof(message), "unknown[%d]", msg);
if (msg == 0x6 && len == 13)
{
peer_request r;
const char* ptr = buffer + 1;
r.piece = detail::read_int32(ptr);
r.start = detail::read_int32(ptr);
r.length = detail::read_int32(ptr);
snprintf(extra, sizeof(extra), "p: %d s: %d l: %d", r.piece, r.start, r.length);
}
else if (msg == 0x11 && len == 5)
{
const char* ptr = buffer + 1;
int index = detail::read_int32(ptr);
snprintf(extra, sizeof(extra), "p: %d", index);
}
}
fprintf(stderr, "%s <== %s %s\n", time_now_string(), message, extra);
}
void send_allow_fast(stream_socket& s, int piece) void send_allow_fast(stream_socket& s, int piece)
{ {
std::cout << time_now_string() << " ==> allow fast: " << piece << std::endl; std::cout << time_now_string() << " ==> allow fast: " << piece << std::endl;
@ -188,12 +225,9 @@ void test_reject_fast()
while (!allowed_fast.empty()) while (!allowed_fast.empty())
{ {
read_message(s, recv_buffer); int len = read_message(s, recv_buffer);
print_message(recv_buffer, len);
int msg = recv_buffer[0]; int msg = recv_buffer[0];
if (msg >= 0 && msg < int(sizeof(message_name)/sizeof(message_name[0])))
std::cerr << time_now_string() << " <== " << message_name[msg] << std::endl;
else
std::cerr << time_now_string() << " <== " << msg << std::endl;
if (recv_buffer[0] != 0x6) continue; if (recv_buffer[0] != 0x6) continue;
using namespace libtorrent::detail; using namespace libtorrent::detail;
@ -254,13 +288,9 @@ void test_respect_suggest()
int fail_counter = 100; int fail_counter = 100;
while (!suggested.empty() && fail_counter > 0) while (!suggested.empty() && fail_counter > 0)
{ {
read_message(s, recv_buffer); int len = read_message(s, recv_buffer);
std::cerr << time_now_string() << " <== "; print_message(recv_buffer, len);
int msg = recv_buffer[0]; int msg = recv_buffer[0];
if (msg >= 0 && msg < int(sizeof(message_name)/sizeof(message_name[0])))
std::cerr << message_name[msg] << std::endl;
else
std::cerr << msg << std::endl;
fail_counter--; fail_counter--;
if (recv_buffer[0] != 0x6) continue; if (recv_buffer[0] != 0x6) continue;