fix auto-managed issue with torrents transitioning to 'slow' as they get paused, returning to life again later because of it

This commit is contained in:
arvidn 2016-02-22 20:07:29 -05:00
parent 46e22cf3fc
commit 57aa813135
2 changed files with 83 additions and 0 deletions

View File

@ -845,6 +845,79 @@ TORRENT_TEST(no_resume_when_started)
}); });
} }
// when setting active_seeds to 0, any completed torrent should be paused
TORRENT_TEST(pause_completed_torrents)
{
run_test(
[](settings_pack& sett) {
// session settings
sett.set_bool(settings_pack::dont_count_slow_torrents, true);
sett.set_int(settings_pack::active_downloads, 1);
sett.set_int(settings_pack::active_seeds, 0);
},
[](lt::session& ses) {
// add torrent
lt::add_torrent_params params = create_torrent(0, true);
params.flags |= add_torrent_params::flag_auto_managed;
params.flags |= add_torrent_params::flag_paused;
ses.async_add_torrent(params);
},
[](lt::session& ses) {
// verify result
// the torrent should have been paused immediately as it completed,
// since we don't allow any seeding torrents
std::vector<lt::alert*> alerts;
ses.pop_alerts(&alerts);
lt::time_point start_time = alerts[0]->timestamp();
int num_started = 0;
int num_finished = 0;
int num_paused = 0;
lt::time_point finished;
lt::time_point paused;
for (alert* a : alerts)
{
printf("%-3d %s\n", int(duration_cast<lt::seconds>(a->timestamp()
- start_time).count()), a->message().c_str());
if (alert_cast<torrent_resumed_alert>(a))
++num_started;
if (alert_cast<torrent_finished_alert>(a))
{
++num_finished;
finished = a->timestamp();
}
if (alert_cast<torrent_paused_alert>(a))
{
++num_paused;
paused = a->timestamp();
}
}
TEST_EQUAL(num_started, 1);
TEST_EQUAL(num_finished, 1);
TEST_EQUAL(num_paused, 1);
if (num_finished > 0 && num_paused > 0)
{
TEST_CHECK(paused >= finished);
TEST_CHECK(paused - finished < chrono::milliseconds(1));
}
num_paused = 0;
for (torrent_handle const& h : ses.get_torrents())
{
TEST_CHECK(h.status().auto_managed);
num_paused += h.status().paused;
}
TEST_EQUAL(num_paused, 1);
});
}
// TODO: assert that the torrent_paused_alert is posted when pausing // TODO: assert that the torrent_paused_alert is posted when pausing
// downloading, seeding, checking torrents as well as the graceful pause // downloading, seeding, checking torrents as well as the graceful pause
// TODO: test limits of tracker, DHT and LSD announces // TODO: test limits of tracker, DHT and LSD announces

View File

@ -9700,6 +9700,16 @@ namespace libtorrent
TORRENT_ASSERT(is_single_thread()); TORRENT_ASSERT(is_single_thread());
if (!is_paused()) return; if (!is_paused()) return;
// this torrent may be about to consider itself inactive. If so, we want
// to prevent it from doing so, since it's being paused unconditionally
// now. An illustrative example of this is a torrent that completes
// downloading when active_seeds = 0. It completes, it gets paused and it
// should not come back to life again.
if (m_pending_active_change)
{
m_inactivity_timer.cancel();
}
#ifndef TORRENT_DISABLE_EXTENSIONS #ifndef TORRENT_DISABLE_EXTENSIONS
for (extension_list_t::iterator i = m_extensions.begin() for (extension_list_t::iterator i = m_extensions.begin()
, end(m_extensions.end()); i != end; ++i) , end(m_extensions.end()); i != end; ++i)