forked from premiere/premiere-libtorrent
moved some tests to the correct place and factor out some tests from test_primitives.cpp in order to be able to track test coverage better
This commit is contained in:
parent
7f5aff9823
commit
647a6dba54
|
@ -97,6 +97,7 @@ feature launcher : none valgrind : composite ;
|
||||||
feature.compose <launcher>valgrind : <testing.launcher>"valgrind --tool=memcheck -v --num-callers=20 --read-var-info=yes --track-origins=yes --error-exitcode=222 --suppressions=valgrind_suppressions.txt" <use-valgrind>on ;
|
feature.compose <launcher>valgrind : <testing.launcher>"valgrind --tool=memcheck -v --num-callers=20 --read-var-info=yes --track-origins=yes --error-exitcode=222 --suppressions=valgrind_suppressions.txt" <use-valgrind>on ;
|
||||||
|
|
||||||
test-suite libtorrent :
|
test-suite libtorrent :
|
||||||
|
[ run test_timestamp_history.cpp ]
|
||||||
[ run test_sha1_hash.cpp ]
|
[ run test_sha1_hash.cpp ]
|
||||||
[ run test_bloom_filter.cpp ]
|
[ run test_bloom_filter.cpp ]
|
||||||
[ run test_identify_client.cpp ]
|
[ run test_identify_client.cpp ]
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
AUTOMAKE_OPTIONS = subdir-objects
|
AUTOMAKE_OPTIONS = subdir-objects
|
||||||
|
|
||||||
test_programs = \
|
test_programs = \
|
||||||
test_sha1_hash.cpp \
|
test_timestamp_history \
|
||||||
|
test_sha1_hash \
|
||||||
test_bloom_filter \
|
test_bloom_filter \
|
||||||
test_identify_client \
|
test_identify_client \
|
||||||
test_alert_manager \
|
test_alert_manager \
|
||||||
|
@ -145,6 +146,10 @@ libtest_la_SOURCES = main.cpp \
|
||||||
swarm_suite.cpp \
|
swarm_suite.cpp \
|
||||||
test_utils.cpp
|
test_utils.cpp
|
||||||
|
|
||||||
|
test_timestamp_history_SOURCES = test_timestamp_history.cpp
|
||||||
|
test_sha1_hash_SOURCES = test_sha1_hash.cpp
|
||||||
|
test_bloom_filter_SOURCES = test_bloom_filter.cpp
|
||||||
|
test_identify_client_SOURCES = test_identify_client.cpp
|
||||||
test_alert_manager_SOURCES = test_alert_manager.cpp
|
test_alert_manager_SOURCES = test_alert_manager.cpp
|
||||||
test_bitfield_SOURCES = test_bitfield.cpp
|
test_bitfield_SOURCES = test_bitfield.cpp
|
||||||
test_crc32_SOURCES = test_crc32.cpp
|
test_crc32_SOURCES = test_crc32.cpp
|
||||||
|
|
|
@ -38,7 +38,6 @@ POSSIBILITY OF SUCH DAMAGE.
|
||||||
#include "libtorrent/torrent_info.hpp"
|
#include "libtorrent/torrent_info.hpp"
|
||||||
#include "libtorrent/broadcast_socket.hpp"
|
#include "libtorrent/broadcast_socket.hpp"
|
||||||
#include "libtorrent/file.hpp"
|
#include "libtorrent/file.hpp"
|
||||||
#include "libtorrent/timestamp_history.hpp"
|
|
||||||
#include "libtorrent/aux_/session_impl.hpp"
|
#include "libtorrent/aux_/session_impl.hpp"
|
||||||
#include "libtorrent/enum_net.hpp"
|
#include "libtorrent/enum_net.hpp"
|
||||||
#include "libtorrent/socket_io.hpp"
|
#include "libtorrent/socket_io.hpp"
|
||||||
|
@ -164,28 +163,6 @@ int test_main()
|
||||||
TEST_CHECK(ipv2.external_address(rand_v6()) == real_external2);
|
TEST_CHECK(ipv2.external_address(rand_v6()) == real_external2);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// TODO: 3 move this out to its own test
|
|
||||||
// test timestamp_history
|
|
||||||
{
|
|
||||||
timestamp_history h;
|
|
||||||
TEST_EQUAL(h.add_sample(0x32, false), 0);
|
|
||||||
TEST_EQUAL(h.base(), 0x32);
|
|
||||||
TEST_EQUAL(h.add_sample(0x33, false), 0x1);
|
|
||||||
TEST_EQUAL(h.base(), 0x32);
|
|
||||||
TEST_EQUAL(h.add_sample(0x3433, false), 0x3401);
|
|
||||||
TEST_EQUAL(h.base(), 0x32);
|
|
||||||
TEST_EQUAL(h.add_sample(0x30, false), 0);
|
|
||||||
TEST_EQUAL(h.base(), 0x30);
|
|
||||||
|
|
||||||
// test that wrapping of the timestamp is properly handled
|
|
||||||
h.add_sample(0xfffffff3, false);
|
|
||||||
TEST_EQUAL(h.base(), 0xfffffff3);
|
|
||||||
|
|
||||||
|
|
||||||
// TODO: test the case where we have > 120 samples (and have the base delay actually be updated)
|
|
||||||
// TODO: test the case where a sample is lower than the history entry but not lower than the base
|
|
||||||
}
|
|
||||||
|
|
||||||
// test error codes
|
// test error codes
|
||||||
TEST_CHECK(error_code(errors::http_error).message() == "HTTP error");
|
TEST_CHECK(error_code(errors::http_error).message() == "HTTP error");
|
||||||
TEST_CHECK(error_code(errors::missing_file_sizes).message() == "missing or invalid 'file sizes' entry");
|
TEST_CHECK(error_code(errors::missing_file_sizes).message() == "missing or invalid 'file sizes' entry");
|
||||||
|
@ -203,71 +180,6 @@ int test_main()
|
||||||
snprintf(msg, sizeof(msg), "too %s format string", "long");
|
snprintf(msg, sizeof(msg), "too %s format string", "long");
|
||||||
TEST_CHECK(strcmp(msg, "too long ") == 0);
|
TEST_CHECK(strcmp(msg, "too long ") == 0);
|
||||||
|
|
||||||
std::string path;
|
|
||||||
sanitize_append_path_element(path, "a...", 4);
|
|
||||||
TEST_EQUAL(path, "a");
|
|
||||||
|
|
||||||
path.clear();
|
|
||||||
sanitize_append_path_element(path, "a ", 4);
|
|
||||||
TEST_EQUAL(path, "a");
|
|
||||||
|
|
||||||
path.clear();
|
|
||||||
sanitize_append_path_element(path, "a...b", 5);
|
|
||||||
TEST_EQUAL(path, "a...b");
|
|
||||||
|
|
||||||
path.clear();
|
|
||||||
sanitize_append_path_element(path, "a", 1);
|
|
||||||
sanitize_append_path_element(path, "..", 2);
|
|
||||||
sanitize_append_path_element(path, "c", 1);
|
|
||||||
#ifdef TORRENT_WINDOWS
|
|
||||||
TEST_EQUAL(path, "a\\c");
|
|
||||||
#else
|
|
||||||
TEST_EQUAL(path, "a/c");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
path.clear();
|
|
||||||
sanitize_append_path_element(path, "/..", 3);
|
|
||||||
sanitize_append_path_element(path, ".", 1);
|
|
||||||
sanitize_append_path_element(path, "c", 1);
|
|
||||||
TEST_EQUAL(path, "c");
|
|
||||||
|
|
||||||
path.clear();
|
|
||||||
sanitize_append_path_element(path, "dev:", 4);
|
|
||||||
#ifdef TORRENT_WINDOWS
|
|
||||||
TEST_EQUAL(path, "dev");
|
|
||||||
#else
|
|
||||||
TEST_EQUAL(path, "dev:");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
path.clear();
|
|
||||||
sanitize_append_path_element(path, "c:", 2);
|
|
||||||
sanitize_append_path_element(path, "b", 1);
|
|
||||||
#ifdef TORRENT_WINDOWS
|
|
||||||
TEST_EQUAL(path, "c\\b");
|
|
||||||
#else
|
|
||||||
TEST_EQUAL(path, "c:/b");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
path.clear();
|
|
||||||
sanitize_append_path_element(path, "c:", 2);
|
|
||||||
sanitize_append_path_element(path, ".", 1);
|
|
||||||
sanitize_append_path_element(path, "c", 1);
|
|
||||||
#ifdef TORRENT_WINDOWS
|
|
||||||
TEST_EQUAL(path, "c\\c");
|
|
||||||
#else
|
|
||||||
TEST_EQUAL(path, "c:/c");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
path.clear();
|
|
||||||
sanitize_append_path_element(path, "\\c", 2);
|
|
||||||
sanitize_append_path_element(path, ".", 1);
|
|
||||||
sanitize_append_path_element(path, "c", 1);
|
|
||||||
#ifdef TORRENT_WINDOWS
|
|
||||||
TEST_EQUAL(path, "c\\c");
|
|
||||||
#else
|
|
||||||
TEST_EQUAL(path, "c/c");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (supports_ipv6())
|
if (supports_ipv6())
|
||||||
{
|
{
|
||||||
// make sure the assumption we use in policy's peer list hold
|
// make sure the assumption we use in policy's peer list hold
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
|
||||||
|
Copyright (c) 2008-2015, Arvid Norberg
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions
|
||||||
|
are met:
|
||||||
|
|
||||||
|
* Redistributions of source code must retain the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer.
|
||||||
|
* Redistributions in binary form must reproduce the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer in
|
||||||
|
the documentation and/or other materials provided with the distribution.
|
||||||
|
* Neither the name of the author nor the names of its
|
||||||
|
contributors may be used to endorse or promote products derived
|
||||||
|
from this software without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "test.hpp"
|
||||||
|
#include "libtorrent/timestamp_history.hpp"
|
||||||
|
|
||||||
|
int test_main()
|
||||||
|
{
|
||||||
|
using namespace libtorrent;
|
||||||
|
|
||||||
|
timestamp_history h;
|
||||||
|
TEST_EQUAL(h.add_sample(0x32, false), 0);
|
||||||
|
TEST_EQUAL(h.base(), 0x32);
|
||||||
|
TEST_EQUAL(h.add_sample(0x33, false), 0x1);
|
||||||
|
TEST_EQUAL(h.base(), 0x32);
|
||||||
|
TEST_EQUAL(h.add_sample(0x3433, false), 0x3401);
|
||||||
|
TEST_EQUAL(h.base(), 0x32);
|
||||||
|
TEST_EQUAL(h.add_sample(0x30, false), 0);
|
||||||
|
TEST_EQUAL(h.base(), 0x30);
|
||||||
|
|
||||||
|
// test that wrapping of the timestamp is properly handled
|
||||||
|
h.add_sample(0xfffffff3, false);
|
||||||
|
TEST_EQUAL(h.base(), 0xfffffff3);
|
||||||
|
|
||||||
|
// TODO: test the case where we have > 120 samples (and have the base delay actually be updated)
|
||||||
|
// TODO: test the case where a sample is lower than the history entry but not lower than the base
|
||||||
|
}
|
||||||
|
|
|
@ -176,10 +176,8 @@ test_failing_torrent_t test_error_torrents[] =
|
||||||
// TODO: torrent_info constructor that takes an invalid bencoded buffer
|
// TODO: torrent_info constructor that takes an invalid bencoded buffer
|
||||||
// TODO: verify_encoding with a string that triggers character replacement
|
// TODO: verify_encoding with a string that triggers character replacement
|
||||||
|
|
||||||
int test_torrent_parse()
|
void test_sanitize_path()
|
||||||
{
|
{
|
||||||
error_code ec;
|
|
||||||
|
|
||||||
// test sanitize_append_path_element
|
// test sanitize_append_path_element
|
||||||
|
|
||||||
std::string path;
|
std::string path;
|
||||||
|
@ -221,6 +219,77 @@ int test_torrent_parse()
|
||||||
TEST_EQUAL(path, "a/b/c");
|
TEST_EQUAL(path, "a/b/c");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "a...", 4);
|
||||||
|
TEST_EQUAL(path, "a");
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "a ", 4);
|
||||||
|
TEST_EQUAL(path, "a");
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "a...b", 5);
|
||||||
|
TEST_EQUAL(path, "a...b");
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "a", 1);
|
||||||
|
sanitize_append_path_element(path, "..", 2);
|
||||||
|
sanitize_append_path_element(path, "c", 1);
|
||||||
|
#ifdef TORRENT_WINDOWS
|
||||||
|
TEST_EQUAL(path, "a\\c");
|
||||||
|
#else
|
||||||
|
TEST_EQUAL(path, "a/c");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "/..", 3);
|
||||||
|
sanitize_append_path_element(path, ".", 1);
|
||||||
|
sanitize_append_path_element(path, "c", 1);
|
||||||
|
TEST_EQUAL(path, "c");
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "dev:", 4);
|
||||||
|
#ifdef TORRENT_WINDOWS
|
||||||
|
TEST_EQUAL(path, "dev");
|
||||||
|
#else
|
||||||
|
TEST_EQUAL(path, "dev:");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "c:", 2);
|
||||||
|
sanitize_append_path_element(path, "b", 1);
|
||||||
|
#ifdef TORRENT_WINDOWS
|
||||||
|
TEST_EQUAL(path, "c\\b");
|
||||||
|
#else
|
||||||
|
TEST_EQUAL(path, "c:/b");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "c:", 2);
|
||||||
|
sanitize_append_path_element(path, ".", 1);
|
||||||
|
sanitize_append_path_element(path, "c", 1);
|
||||||
|
#ifdef TORRENT_WINDOWS
|
||||||
|
TEST_EQUAL(path, "c\\c");
|
||||||
|
#else
|
||||||
|
TEST_EQUAL(path, "c:/c");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
path.clear();
|
||||||
|
sanitize_append_path_element(path, "\\c", 2);
|
||||||
|
sanitize_append_path_element(path, ".", 1);
|
||||||
|
sanitize_append_path_element(path, "c", 1);
|
||||||
|
#ifdef TORRENT_WINDOWS
|
||||||
|
TEST_EQUAL(path, "c\\c");
|
||||||
|
#else
|
||||||
|
TEST_EQUAL(path, "c/c");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_torrent_parse()
|
||||||
|
{
|
||||||
|
error_code ec;
|
||||||
|
|
||||||
// test torrent parsing
|
// test torrent parsing
|
||||||
|
|
||||||
entry info;
|
entry info;
|
||||||
|
@ -644,7 +713,6 @@ void test_copy()
|
||||||
|
|
||||||
TEST_EQUAL(b->files().hash(i), file_hashes[i]);
|
TEST_EQUAL(b->files().hash(i), file_hashes[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int test_main()
|
int test_main()
|
||||||
|
@ -657,6 +725,7 @@ int test_main()
|
||||||
test_mutable_torrents();
|
test_mutable_torrents();
|
||||||
#endif
|
#endif
|
||||||
test_torrent_parse();
|
test_torrent_parse();
|
||||||
|
test_sanitize_path();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue