123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292 |
- #include "RequestGroupMan.h"
- #include <fstream>
- #include <cppunit/extensions/HelperMacros.h>
- #include "TestUtil.h"
- #include "prefs.h"
- #include "DownloadContext.h"
- #include "RequestGroup.h"
- #include "Option.h"
- #include "DownloadResult.h"
- #include "FileEntry.h"
- #include "ServerStatMan.h"
- #include "ServerStat.h"
- #include "File.h"
- #include "array_fun.h"
- #include "RecoverableException.h"
- #include "util.h"
- #include "DownloadEngine.h"
- #include "SelectEventPoll.h"
- #include "UriListParser.h"
- namespace aria2 {
- class RequestGroupManTest : public CppUnit::TestFixture {
- CPPUNIT_TEST_SUITE(RequestGroupManTest);
- CPPUNIT_TEST(testIsSameFileBeingDownloaded);
- CPPUNIT_TEST(testGetInitialCommands);
- CPPUNIT_TEST(testLoadServerStat);
- CPPUNIT_TEST(testSaveServerStat);
- CPPUNIT_TEST(testChangeReservedGroupPosition);
- CPPUNIT_TEST(testFillRequestGroupFromReserver);
- CPPUNIT_TEST(testFillRequestGroupFromReserver_uriParser);
- CPPUNIT_TEST(testInsertReservedGroup);
- CPPUNIT_TEST_SUITE_END();
- private:
- SharedHandle<DownloadEngine> e_;
- SharedHandle<Option> option_;
- SharedHandle<RequestGroupMan> rgman_;
- public:
- void setUp()
- {
- option_.reset(new Option());
- option_->put(PREF_PIECE_LENGTH, "1048576");
- // To enable paused RequestGroup
- option_->put(PREF_ENABLE_RPC, A2_V_TRUE);
- File(option_->get(PREF_DIR)).mkdirs();
- e_.reset
- (new DownloadEngine(SharedHandle<EventPoll>(new SelectEventPoll())));
- e_->setOption(option_.get());
- rgman_ = SharedHandle<RequestGroupMan>
- (new RequestGroupMan(std::vector<SharedHandle<RequestGroup> >(),
- 3, option_.get()));
- e_->setRequestGroupMan(rgman_);
- }
- void testIsSameFileBeingDownloaded();
- void testGetInitialCommands();
- void testLoadServerStat();
- void testSaveServerStat();
- void testChangeReservedGroupPosition();
- void testFillRequestGroupFromReserver();
- void testFillRequestGroupFromReserver_uriParser();
- void testInsertReservedGroup();
- };
- CPPUNIT_TEST_SUITE_REGISTRATION( RequestGroupManTest );
- void RequestGroupManTest::testIsSameFileBeingDownloaded()
- {
- SharedHandle<RequestGroup> rg1(new RequestGroup(GroupId::create(),
- util::copy(option_)));
- SharedHandle<RequestGroup> rg2(new RequestGroup(GroupId::create(),
- util::copy(option_)));
- SharedHandle<DownloadContext> dctx1
- (new DownloadContext(0, 0, "aria2.tar.bz2"));
- SharedHandle<DownloadContext> dctx2
- (new DownloadContext(0, 0, "aria2.tar.bz2"));
- rg1->setDownloadContext(dctx1);
- rg2->setDownloadContext(dctx2);
- RequestGroupMan gm(std::vector<SharedHandle<RequestGroup> >(), 1,
- option_.get());
- gm.addRequestGroup(rg1);
- gm.addRequestGroup(rg2);
- CPPUNIT_ASSERT(gm.isSameFileBeingDownloaded(rg1.get()));
- dctx2->getFirstFileEntry()->setPath("aria2.tar.gz");
- CPPUNIT_ASSERT(!gm.isSameFileBeingDownloaded(rg1.get()));
- }
- void RequestGroupManTest::testGetInitialCommands()
- {
- // TODO implement later
- }
- void RequestGroupManTest::testSaveServerStat()
- {
- RequestGroupMan rm
- (std::vector<SharedHandle<RequestGroup> >(),0,option_.get());
- SharedHandle<ServerStat> ss_localhost(new ServerStat("localhost", "http"));
- rm.addServerStat(ss_localhost);
- File f(A2_TEST_OUT_DIR"/aria2_RequestGroupManTest_testSaveServerStat");
- if(f.exists()) {
- f.remove();
- }
- CPPUNIT_ASSERT(rm.saveServerStat(f.getPath()));
- CPPUNIT_ASSERT(f.isFile());
- f.remove();
- CPPUNIT_ASSERT(f.mkdirs());
- CPPUNIT_ASSERT(!rm.saveServerStat(f.getPath()));
- }
- void RequestGroupManTest::testLoadServerStat()
- {
- File f(A2_TEST_OUT_DIR"/aria2_RequestGroupManTest_testLoadServerStat");
- std::ofstream o(f.getPath().c_str(), std::ios::binary);
- o << "host=localhost, protocol=http, dl_speed=0, last_updated=1219505257,"
- << "status=OK";
- o.close();
- RequestGroupMan rm
- (std::vector<SharedHandle<RequestGroup> >(),0,option_.get());
- std::cerr << "testLoadServerStat" << std::endl;
- CPPUNIT_ASSERT(rm.loadServerStat(f.getPath()));
- SharedHandle<ServerStat> ss_localhost = rm.findServerStat("localhost",
- "http");
- CPPUNIT_ASSERT(ss_localhost);
- CPPUNIT_ASSERT_EQUAL(std::string("localhost"), ss_localhost->getHostname());
- }
- void RequestGroupManTest::testChangeReservedGroupPosition()
- {
- SharedHandle<RequestGroup> gs[] = {
- SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
- util::copy(option_))),
- SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
- util::copy(option_))),
- SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
- util::copy(option_))),
- SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
- util::copy(option_)))
- };
- std::vector<SharedHandle<RequestGroup> > groups(vbegin(gs), vend(gs));
- RequestGroupMan rm(groups, 0, option_.get());
- CPPUNIT_ASSERT_EQUAL
- ((size_t)0, rm.changeReservedGroupPosition(gs[0]->getGID(),
- 0, A2_POS_SET));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)1, rm.changeReservedGroupPosition(gs[0]->getGID(),
- 1, A2_POS_SET));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)3, rm.changeReservedGroupPosition(gs[0]->getGID(),
- 10,A2_POS_SET));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)0, rm.changeReservedGroupPosition(gs[0]->getGID(),
- -10, A2_POS_SET));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)1, rm.changeReservedGroupPosition(gs[1]->getGID(),
- 0, A2_POS_CUR));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)2, rm.changeReservedGroupPosition(gs[1]->getGID(),
- 1, A2_POS_CUR));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)1, rm.changeReservedGroupPosition(gs[1]->getGID(),
- -1,A2_POS_CUR));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)0, rm.changeReservedGroupPosition(gs[1]->getGID(),
- -10, A2_POS_CUR));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)1, rm.changeReservedGroupPosition(gs[1]->getGID(),
- 1, A2_POS_CUR));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)3, rm.changeReservedGroupPosition(gs[1]->getGID(),
- 10, A2_POS_CUR));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)1, rm.changeReservedGroupPosition(gs[1]->getGID(),
- -2,A2_POS_CUR));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)3, rm.changeReservedGroupPosition(gs[3]->getGID(),
- 0, A2_POS_END));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)2, rm.changeReservedGroupPosition(gs[3]->getGID(),
- -1,A2_POS_END));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)0, rm.changeReservedGroupPosition(gs[3]->getGID(),
- -10, A2_POS_END));
- CPPUNIT_ASSERT_EQUAL
- ((size_t)3, rm.changeReservedGroupPosition(gs[3]->getGID(),
- 10, A2_POS_END));
- CPPUNIT_ASSERT_EQUAL((size_t)4, rm.getReservedGroups().size());
- try {
- rm.changeReservedGroupPosition(GroupId::create()->getNumericId(),
- 0, A2_POS_CUR);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- }
- void RequestGroupManTest::testFillRequestGroupFromReserver()
- {
- SharedHandle<RequestGroup> rgs[] = {
- createRequestGroup(0, 0, "foo1", "http://host/foo1", util::copy(option_)),
- createRequestGroup(0, 0, "foo2", "http://host/foo2", util::copy(option_)),
- createRequestGroup(0, 0, "foo3", "http://host/foo3", util::copy(option_)),
- // Intentionally same path/URI for first RequestGroup and set
- // length explicitly to do duplicate filename check.
- createRequestGroup(0, 10, "foo1", "http://host/foo1", util::copy(option_)),
- createRequestGroup(0, 0, "foo4", "http://host/foo4", util::copy(option_)),
- createRequestGroup(0, 0, "foo5", "http://host/foo5", util::copy(option_))
- };
- rgs[1]->setPauseRequested(true);
- for(SharedHandle<RequestGroup>* i = vbegin(rgs); i != vend(rgs); ++i) {
- rgman_->addReservedGroup(*i);
- }
- rgman_->fillRequestGroupFromReserver(e_.get());
- CPPUNIT_ASSERT_EQUAL((size_t)2, rgman_->getReservedGroups().size());
- }
- void RequestGroupManTest::testFillRequestGroupFromReserver_uriParser()
- {
- SharedHandle<RequestGroup> rgs[] = {
- createRequestGroup(0, 0, "mem1", "http://mem1", util::copy(option_)),
- createRequestGroup(0, 0, "mem2", "http://mem2", util::copy(option_)),
- };
- rgs[0]->setPauseRequested(true);
- for(SharedHandle<RequestGroup>* i = vbegin(rgs); i != vend(rgs); ++i) {
- rgman_->addReservedGroup(*i);
- }
- SharedHandle<UriListParser> flp
- (new UriListParser(A2_TEST_DIR"/filelist2.txt"));
- rgman_->setUriListParser(flp);
- rgman_->fillRequestGroupFromReserver(e_.get());
- RequestGroupList::SeqType::const_iterator itr;
- CPPUNIT_ASSERT_EQUAL((size_t)1, rgman_->getReservedGroups().size());
- itr = rgman_->getReservedGroups().begin();
- CPPUNIT_ASSERT_EQUAL(rgs[0]->getGID(), (*itr).second->getGID());
- CPPUNIT_ASSERT_EQUAL((size_t)3, rgman_->getRequestGroups().size());
- }
- void RequestGroupManTest::testInsertReservedGroup()
- {
- SharedHandle<RequestGroup> rgs1[] = {
- SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
- util::copy(option_))),
- SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
- util::copy(option_)))
- };
- SharedHandle<RequestGroup> rgs2[] = {
- SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
- util::copy(option_))),
- SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
- util::copy(option_)))
- };
- std::vector<SharedHandle<RequestGroup> > groups(vbegin(rgs1), vend(rgs1));
- rgman_->insertReservedGroup(0, groups);
- CPPUNIT_ASSERT_EQUAL((size_t)2, rgman_->getReservedGroups().size());
- RequestGroupList::SeqType::const_iterator itr;
- itr = rgman_->getReservedGroups().begin();
- CPPUNIT_ASSERT_EQUAL(rgs1[0]->getGID(), (*itr++).second->getGID());
- CPPUNIT_ASSERT_EQUAL(rgs1[1]->getGID(), (*itr++).second->getGID());
- groups.assign(vbegin(rgs2), vend(rgs2));
- rgman_->insertReservedGroup(1, groups);
- CPPUNIT_ASSERT_EQUAL((size_t)4, rgman_->getReservedGroups().size());
- itr = rgman_->getReservedGroups().begin();
- ++itr;
- CPPUNIT_ASSERT_EQUAL(rgs2[0]->getGID(), (*itr++).second->getGID());
- CPPUNIT_ASSERT_EQUAL(rgs2[1]->getGID(), (*itr++).second->getGID());
- }
- } // namespace aria2
|