fix assert when adding an empty file (as a torrent) (#729)
This commit is contained in:
parent
6dcbeae8bb
commit
0d27a0acdd
|
@ -4818,6 +4818,12 @@ namespace aux {
|
||||||
params.ti = t;
|
params.ti = t;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (params.ti && !params.ti->is_valid())
|
||||||
|
{
|
||||||
|
ec = errors::no_metadata;
|
||||||
|
return ptr_t();
|
||||||
|
}
|
||||||
|
|
||||||
if (params.ti && params.ti->is_valid() && params.ti->num_files() == 0)
|
if (params.ti && params.ti->is_valid() && params.ti->num_files() == 0)
|
||||||
{
|
{
|
||||||
ec = errors::no_files_in_torrent;
|
ec = errors::no_files_in_torrent;
|
||||||
|
|
|
@ -40,6 +40,7 @@ POSSIBILITY OF SUCH DAMAGE.
|
||||||
#include "libtorrent/performance_counters.hpp"
|
#include "libtorrent/performance_counters.hpp"
|
||||||
#include "libtorrent/bdecode.hpp"
|
#include "libtorrent/bdecode.hpp"
|
||||||
#include "libtorrent/bencode.hpp"
|
#include "libtorrent/bencode.hpp"
|
||||||
|
#include "libtorrent/torrent_info.hpp"
|
||||||
|
|
||||||
using namespace libtorrent;
|
using namespace libtorrent;
|
||||||
namespace lt = libtorrent;
|
namespace lt = libtorrent;
|
||||||
|
@ -143,6 +144,22 @@ TORRENT_TEST(async_add_torrent_duplicate)
|
||||||
TEST_CHECK(!a->error);
|
TEST_CHECK(!a->error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TORRENT_TEST(load_empty_file)
|
||||||
|
{
|
||||||
|
settings_pack p;
|
||||||
|
p.set_int(settings_pack::alert_mask, ~0);
|
||||||
|
lt::session ses(p);
|
||||||
|
|
||||||
|
add_torrent_params atp;
|
||||||
|
error_code ignore_errors;
|
||||||
|
atp.ti = boost::make_shared<torrent_info>("", 0, ignore_errors);
|
||||||
|
atp.save_path = ".";
|
||||||
|
error_code ec;
|
||||||
|
torrent_handle h = ses.add_torrent(atp, ec);
|
||||||
|
|
||||||
|
TEST_CHECK(!h.is_valid());
|
||||||
|
TEST_CHECK(ec == error_code(errors::no_metadata))
|
||||||
|
}
|
||||||
|
|
||||||
TORRENT_TEST(session_stats)
|
TORRENT_TEST(session_stats)
|
||||||
{
|
{
|
||||||
|
@ -158,8 +175,6 @@ TORRENT_TEST(session_stats)
|
||||||
TEST_EQUAL(stats[i].value_index, i);
|
TEST_EQUAL(stats[i].value_index, i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#if __cplusplus >= 201103L
|
|
||||||
|
|
||||||
template <typename Set, typename Save, typename Default, typename Load>
|
template <typename Set, typename Save, typename Default, typename Load>
|
||||||
void test_save_restore(Set setup, Save s, Default d, Load l)
|
void test_save_restore(Set setup, Save s, Default d, Load l)
|
||||||
{
|
{
|
||||||
|
@ -260,5 +275,3 @@ TORRENT_TEST(save_restore_state_load_filter)
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
|
@ -612,7 +612,7 @@ TORRENT_TEST(parse_torrents)
|
||||||
fprintf(stderr, "loading %s\n", test_torrents[i].file);
|
fprintf(stderr, "loading %s\n", test_torrents[i].file);
|
||||||
std::string filename = combine_path(combine_path(root_dir, "test_torrents")
|
std::string filename = combine_path(combine_path(root_dir, "test_torrents")
|
||||||
, test_torrents[i].file);
|
, test_torrents[i].file);
|
||||||
boost::shared_ptr<torrent_info> ti(new torrent_info(filename, ec));
|
auto ti = boost::make_shared<torrent_info>(filename, ec);
|
||||||
TEST_CHECK(!ec);
|
TEST_CHECK(!ec);
|
||||||
if (ec) fprintf(stderr, " loading(\"%s\") -> failed %s\n", filename.c_str()
|
if (ec) fprintf(stderr, " loading(\"%s\") -> failed %s\n", filename.c_str()
|
||||||
, ec.message().c_str());
|
, ec.message().c_str());
|
||||||
|
@ -751,8 +751,8 @@ TORRENT_TEST(parse_torrents)
|
||||||
{
|
{
|
||||||
error_code ec;
|
error_code ec;
|
||||||
fprintf(stderr, "loading %s\n", test_error_torrents[i].file);
|
fprintf(stderr, "loading %s\n", test_error_torrents[i].file);
|
||||||
boost::shared_ptr<torrent_info> ti(new torrent_info(combine_path(
|
auto ti = boost::make_shared<torrent_info>(combine_path(
|
||||||
combine_path(root_dir, "test_torrents"), test_error_torrents[i].file), ec));
|
combine_path(root_dir, "test_torrents"), test_error_torrents[i].file), ec);
|
||||||
fprintf(stderr, "E: \"%s\"\nexpected: \"%s\"\n", ec.message().c_str()
|
fprintf(stderr, "E: \"%s\"\nexpected: \"%s\"\n", ec.message().c_str()
|
||||||
, test_error_torrents[i].error.message().c_str());
|
, test_error_torrents[i].error.message().c_str());
|
||||||
TEST_CHECK(ec.message() == test_error_torrents[i].error.message());
|
TEST_CHECK(ec.message() == test_error_torrents[i].error.message());
|
||||||
|
@ -854,6 +854,26 @@ TORRENT_TEST(resolve_duplicates)
|
||||||
test_resolve_duplicates(i);
|
test_resolve_duplicates(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TORRENT_TEST(empty_file)
|
||||||
|
{
|
||||||
|
error_code ec;
|
||||||
|
auto ti = boost::make_shared<torrent_info>("", 0, ec);
|
||||||
|
TEST_CHECK(ec);
|
||||||
|
}
|
||||||
|
|
||||||
|
TORRENT_TEST(empty_file2)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
auto ti = boost::make_shared<torrent_info>("", 0);
|
||||||
|
TEST_ERROR("expected exception thrown");
|
||||||
|
}
|
||||||
|
catch (libtorrent_exception& e)
|
||||||
|
{
|
||||||
|
printf("Expected error: %s\n", e.error().message().c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
TORRENT_TEST(copy)
|
TORRENT_TEST(copy)
|
||||||
{
|
{
|
||||||
using namespace libtorrent;
|
using namespace libtorrent;
|
||||||
|
|
Loading…
Reference in New Issue