123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371 |
- #include "download_helper.h"
- #include <iostream>
- #include <string>
- #include <algorithm>
- #include <cppunit/extensions/HelperMacros.h>
- #include "RequestGroup.h"
- #include "DownloadContext.h"
- #include "Option.h"
- #include "array_fun.h"
- #include "prefs.h"
- #include "Exception.h"
- #include "util.h"
- #include "FileEntry.h"
- #ifdef ENABLE_BITTORRENT
- #include "bittorrent_helper.h"
- #endif // ENABLE_BITTORRENT
- namespace aria2 {
- class DownloadHelperTest : public CppUnit::TestFixture {
- CPPUNIT_TEST_SUITE(DownloadHelperTest);
- CPPUNIT_TEST(testCreateRequestGroupForUri);
- CPPUNIT_TEST(testCreateRequestGroupForUri_parameterized);
- CPPUNIT_TEST(testCreateRequestGroupForUriList);
- #ifdef ENABLE_BITTORRENT
- CPPUNIT_TEST(testCreateRequestGroupForUri_BitTorrent);
- CPPUNIT_TEST(testCreateRequestGroupForBitTorrent);
- #endif // ENABLE_BITTORRENT
- #ifdef ENABLE_METALINK
- CPPUNIT_TEST(testCreateRequestGroupForUri_Metalink);
- CPPUNIT_TEST(testCreateRequestGroupForMetalink);
- #endif // ENABLE_METALINK
- CPPUNIT_TEST_SUITE_END();
- private:
- std::shared_ptr<Option> option_;
- public:
- void setUp() { option_.reset(new Option()); }
- void tearDown() {}
- void testCreateRequestGroupForUri();
- void testCreateRequestGroupForUri_parameterized();
- void testCreateRequestGroupForUriList();
- #ifdef ENABLE_BITTORRENT
- void testCreateRequestGroupForUri_BitTorrent();
- void testCreateRequestGroupForBitTorrent();
- #endif // ENABLE_BITTORRENT
- #ifdef ENABLE_METALINK
- void testCreateRequestGroupForUri_Metalink();
- void testCreateRequestGroupForMetalink();
- #endif // ENABLE_METALINK
- };
- CPPUNIT_TEST_SUITE_REGISTRATION(DownloadHelperTest);
- void DownloadHelperTest::testCreateRequestGroupForUri()
- {
- std::vector<std::string> uris{"http://alpha/file", "http://bravo/file",
- "http://charlie/file"};
- option_->put(PREF_SPLIT, "7");
- option_->put(PREF_MAX_CONNECTION_PER_SERVER, "2");
- option_->put(PREF_DIR, "/tmp");
- option_->put(PREF_OUT, "file.out");
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForUri(result, option_, uris);
- CPPUNIT_ASSERT_EQUAL((size_t)1, result.size());
- std::shared_ptr<RequestGroup> group = result[0];
- auto xuris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL((size_t)6, xuris.size());
- for (size_t i = 0; i < 6; ++i) {
- CPPUNIT_ASSERT_EQUAL(uris[i % 3], xuris[i]);
- }
- CPPUNIT_ASSERT_EQUAL(7, group->getNumConcurrentCommand());
- std::shared_ptr<DownloadContext> ctx = group->getDownloadContext();
- CPPUNIT_ASSERT_EQUAL(std::string("/tmp/file.out"), ctx->getBasePath());
- }
- option_->put(PREF_SPLIT, "5");
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForUri(result, option_, uris);
- CPPUNIT_ASSERT_EQUAL((size_t)1, result.size());
- std::shared_ptr<RequestGroup> group = result[0];
- auto xuris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL((size_t)5, xuris.size());
- for (size_t i = 0; i < 5; ++i) {
- CPPUNIT_ASSERT_EQUAL(uris[i % 3], xuris[i]);
- }
- }
- option_->put(PREF_SPLIT, "2");
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForUri(result, option_, uris);
- CPPUNIT_ASSERT_EQUAL((size_t)1, result.size());
- std::shared_ptr<RequestGroup> group = result[0];
- auto xuris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL((size_t)3, xuris.size());
- for (size_t i = 0; i < 3; ++i) {
- CPPUNIT_ASSERT_EQUAL(uris[i % 3], xuris[i]);
- }
- }
- option_->put(PREF_FORCE_SEQUENTIAL, A2_V_TRUE);
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForUri(result, option_, uris);
- CPPUNIT_ASSERT_EQUAL((size_t)3, result.size());
- // for alpha server
- std::shared_ptr<RequestGroup> alphaGroup = result[0];
- auto alphaURIs =
- alphaGroup->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL((size_t)2, alphaURIs.size());
- for (size_t i = 0; i < 2; ++i) {
- CPPUNIT_ASSERT_EQUAL(uris[0], alphaURIs[i]);
- }
- CPPUNIT_ASSERT_EQUAL(2, alphaGroup->getNumConcurrentCommand());
- std::shared_ptr<DownloadContext> alphaCtx =
- alphaGroup->getDownloadContext();
- // See filename is not assigned yet
- CPPUNIT_ASSERT_EQUAL(std::string(""), alphaCtx->getBasePath());
- }
- }
- void DownloadHelperTest::testCreateRequestGroupForUri_parameterized()
- {
- std::vector<std::string> uris{"http://{alpha, bravo}/file",
- "http://charlie/file"};
- option_->put(PREF_MAX_CONNECTION_PER_SERVER, "1");
- option_->put(PREF_SPLIT, "3");
- option_->put(PREF_DIR, "/tmp");
- option_->put(PREF_OUT, "file.out");
- option_->put(PREF_PARAMETERIZED_URI, A2_V_TRUE);
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForUri(result, option_, uris);
- CPPUNIT_ASSERT_EQUAL((size_t)1, result.size());
- std::shared_ptr<RequestGroup> group = result[0];
- auto uris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL((size_t)3, uris.size());
- CPPUNIT_ASSERT_EQUAL(std::string("http://alpha/file"), uris[0]);
- CPPUNIT_ASSERT_EQUAL(std::string("http://bravo/file"), uris[1]);
- CPPUNIT_ASSERT_EQUAL(std::string("http://charlie/file"), uris[2]);
- CPPUNIT_ASSERT_EQUAL(3, group->getNumConcurrentCommand());
- std::shared_ptr<DownloadContext> ctx = group->getDownloadContext();
- CPPUNIT_ASSERT_EQUAL(std::string("/tmp/file.out"), ctx->getBasePath());
- }
- }
- #ifdef ENABLE_BITTORRENT
- void DownloadHelperTest::testCreateRequestGroupForUri_BitTorrent()
- {
- std::vector<std::string> uris{"http://alpha/file",
- A2_TEST_DIR "/test.torrent",
- "http://bravo/file", "http://charlie/file"};
- option_->put(PREF_MAX_CONNECTION_PER_SERVER, "1");
- option_->put(PREF_SPLIT, "3");
- option_->put(PREF_DIR, "/tmp");
- option_->put(PREF_OUT, "file.out");
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForUri(result, option_, uris);
- CPPUNIT_ASSERT_EQUAL((size_t)2, result.size());
- std::shared_ptr<RequestGroup> group = result[0];
- auto xuris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL((size_t)3, xuris.size());
- CPPUNIT_ASSERT_EQUAL(uris[0], xuris[0]);
- CPPUNIT_ASSERT_EQUAL(uris[2], xuris[1]);
- CPPUNIT_ASSERT_EQUAL(uris[3], xuris[2]);
- CPPUNIT_ASSERT_EQUAL(3, group->getNumConcurrentCommand());
- std::shared_ptr<DownloadContext> ctx = group->getDownloadContext();
- CPPUNIT_ASSERT_EQUAL(std::string("/tmp/file.out"), ctx->getBasePath());
- std::shared_ptr<RequestGroup> torrentGroup = result[1];
- auto auxURIs =
- torrentGroup->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT(auxURIs.empty());
- CPPUNIT_ASSERT_EQUAL(3, torrentGroup->getNumConcurrentCommand());
- std::shared_ptr<DownloadContext> btctx = torrentGroup->getDownloadContext();
- CPPUNIT_ASSERT_EQUAL(std::string("/tmp/aria2-test"), btctx->getBasePath());
- }
- }
- #endif // ENABLE_BITTORRENT
- #ifdef ENABLE_METALINK
- void DownloadHelperTest::testCreateRequestGroupForUri_Metalink()
- {
- std::vector<std::string> uris{"http://alpha/file", "http://bravo/file",
- "http://charlie/file", A2_TEST_DIR "/test.xml"};
- option_->put(PREF_MAX_CONNECTION_PER_SERVER, "1");
- option_->put(PREF_SPLIT, "2");
- option_->put(PREF_DIR, "/tmp");
- option_->put(PREF_OUT, "file.out");
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForUri(result, option_, uris);
- // group1: http://alpha/file, ...
- // group2-7: 6 file entry in Metalink and 1 torrent file download
- #ifdef ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL((size_t)7, result.size());
- #else // !ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL((size_t)6, result.size());
- #endif // !ENABLE_BITTORRENT
- std::shared_ptr<RequestGroup> group = result[0];
- auto xuris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL((size_t)3, xuris.size());
- for (size_t i = 0; i < 3; ++i) {
- CPPUNIT_ASSERT_EQUAL(uris[i], xuris[i]);
- }
- CPPUNIT_ASSERT_EQUAL(2, group->getNumConcurrentCommand());
- std::shared_ptr<DownloadContext> ctx = group->getDownloadContext();
- CPPUNIT_ASSERT_EQUAL(std::string("/tmp/file.out"), ctx->getBasePath());
- std::shared_ptr<RequestGroup> aria2052Group = result[1];
- CPPUNIT_ASSERT_EQUAL(1, // because of maxconnections attribute
- aria2052Group->getNumConcurrentCommand());
- std::shared_ptr<DownloadContext> aria2052Ctx =
- aria2052Group->getDownloadContext();
- CPPUNIT_ASSERT_EQUAL(std::string("/tmp/aria2-0.5.2.tar.bz2"),
- aria2052Ctx->getBasePath());
- std::shared_ptr<RequestGroup> aria2051Group = result[2];
- CPPUNIT_ASSERT_EQUAL(2, aria2051Group->getNumConcurrentCommand());
- }
- }
- #endif // ENABLE_METALINK
- void DownloadHelperTest::testCreateRequestGroupForUriList()
- {
- option_->put(PREF_MAX_CONNECTION_PER_SERVER, "3");
- option_->put(PREF_SPLIT, "3");
- option_->put(PREF_INPUT_FILE, A2_TEST_DIR "/input_uris.txt");
- option_->put(PREF_DIR, "/tmp");
- option_->put(PREF_OUT, "file.out");
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForUriList(result, option_);
- CPPUNIT_ASSERT_EQUAL((size_t)2, result.size());
- std::shared_ptr<RequestGroup> fileGroup = result[0];
- auto fileURIs =
- fileGroup->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL(std::string("http://alpha/file"), fileURIs[0]);
- CPPUNIT_ASSERT_EQUAL(std::string("http://bravo/file"), fileURIs[1]);
- CPPUNIT_ASSERT_EQUAL(std::string("http://charlie/file"), fileURIs[2]);
- CPPUNIT_ASSERT_EQUAL(3, fileGroup->getNumConcurrentCommand());
- std::shared_ptr<DownloadContext> fileCtx = fileGroup->getDownloadContext();
- CPPUNIT_ASSERT_EQUAL(std::string("/mydownloads/myfile.out"),
- fileCtx->getBasePath());
- std::shared_ptr<RequestGroup> fileISOGroup = result[1];
- std::shared_ptr<DownloadContext> fileISOCtx =
- fileISOGroup->getDownloadContext();
- // PREF_OUT in option_ must be ignored.
- CPPUNIT_ASSERT_EQUAL(std::string(), fileISOCtx->getBasePath());
- }
- #ifdef ENABLE_BITTORRENT
- void DownloadHelperTest::testCreateRequestGroupForBitTorrent()
- {
- std::vector<std::string> auxURIs{"http://alpha/file", "http://bravo/file",
- "http://charlie/file"};
- option_->put(PREF_MAX_CONNECTION_PER_SERVER, "2");
- option_->put(PREF_SPLIT, "5");
- option_->put(PREF_TORRENT_FILE, A2_TEST_DIR "/test.torrent");
- option_->put(PREF_DIR, "/tmp");
- option_->put(PREF_OUT, "file.out");
- option_->put(PREF_BT_EXCLUDE_TRACKER, "http://tracker1");
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForBitTorrent(result, option_, auxURIs,
- option_->get(PREF_TORRENT_FILE));
- CPPUNIT_ASSERT_EQUAL((size_t)1, result.size());
- std::shared_ptr<RequestGroup> group = result[0];
- auto uris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- std::sort(std::begin(uris), std::end(uris));
- // See -s option is ignored. See processRootDictionary() in
- // bittorrent_helper.cc
- CPPUNIT_ASSERT_EQUAL((size_t)3, uris.size());
- for (size_t i = 0; i < auxURIs.size(); ++i) {
- CPPUNIT_ASSERT_EQUAL(auxURIs[i] + "/aria2-test/aria2/src/aria2c",
- uris[i]);
- }
- CPPUNIT_ASSERT_EQUAL(5, group->getNumConcurrentCommand());
- auto attrs = bittorrent::getTorrentAttrs(group->getDownloadContext());
- // http://tracker1 was deleted.
- CPPUNIT_ASSERT_EQUAL((size_t)2, attrs->announceList.size());
- }
- {
- // no URIs are given
- std::vector<std::shared_ptr<RequestGroup>> result;
- std::vector<std::string> emptyURIs;
- createRequestGroupForBitTorrent(result, option_, emptyURIs,
- option_->get(PREF_TORRENT_FILE));
- CPPUNIT_ASSERT_EQUAL((size_t)1, result.size());
- std::shared_ptr<RequestGroup> group = result[0];
- auto uris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- CPPUNIT_ASSERT_EQUAL((size_t)0, uris.size());
- }
- option_->put(PREF_FORCE_SEQUENTIAL, A2_V_TRUE);
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForBitTorrent(result, option_, auxURIs,
- option_->get(PREF_TORRENT_FILE));
- // See --force-requencial is ignored
- CPPUNIT_ASSERT_EQUAL((size_t)1, result.size());
- }
- }
- #endif // ENABLE_BITTORRENT
- #ifdef ENABLE_METALINK
- void DownloadHelperTest::testCreateRequestGroupForMetalink()
- {
- option_->put(PREF_SPLIT, "5");
- option_->put(PREF_METALINK_FILE, A2_TEST_DIR "/test.xml");
- option_->put(PREF_DIR, "/tmp");
- option_->put(PREF_OUT, "file.out");
- {
- std::vector<std::shared_ptr<RequestGroup>> result;
- createRequestGroupForMetalink(result, option_);
- #ifdef ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL((size_t)6, result.size());
- #else // !ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL((size_t)5, result.size());
- #endif // !ENABLE_BITTORRENT
- std::shared_ptr<RequestGroup> group = result[0];
- auto uris = group->getDownloadContext()->getFirstFileEntry()->getUris();
- std::sort(uris.begin(), uris.end());
- CPPUNIT_ASSERT_EQUAL((size_t)2, uris.size());
- CPPUNIT_ASSERT_EQUAL(std::string("ftp://ftphost/aria2-0.5.2.tar.bz2"),
- uris[0]);
- CPPUNIT_ASSERT_EQUAL(std::string("http://httphost/aria2-0.5.2.tar.bz2"),
- uris[1]);
- // See numConcurrentCommand is 1 because of maxconnections attribute.
- CPPUNIT_ASSERT_EQUAL(1, group->getNumConcurrentCommand());
- }
- }
- #endif // ENABLE_METALINK
- } // namespace aria2
|