| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 | 
							- #include "Metalink2RequestGroup.h"
 
- #include <algorithm>
 
- #include <cppunit/extensions/HelperMacros.h>
 
- #include "DownloadContext.h"
 
- #include "prefs.h"
 
- #include "Option.h"
 
- #include "RequestGroup.h"
 
- #include "FileEntry.h"
 
- #include "Signature.h"
 
- namespace aria2 {
 
- class Metalink2RequestGroupTest:public CppUnit::TestFixture {
 
-   CPPUNIT_TEST_SUITE(Metalink2RequestGroupTest);
 
-   CPPUNIT_TEST(testGenerate);
 
-   CPPUNIT_TEST(testGenerate_groupByMetaurl);
 
-   CPPUNIT_TEST(testGenerate_dosDirTraversal);
 
-   CPPUNIT_TEST_SUITE_END();
 
- private:
 
-   SharedHandle<Option> option_;
 
- public:
 
-   void setUp()
 
-   {
 
-     option_.reset(new Option());
 
-     option_->put(PREF_SPLIT, "1");
 
-   }
 
-   void testGenerate();
 
-   void testGenerate_groupByMetaurl();
 
-   void testGenerate_dosDirTraversal();
 
- };
 
- CPPUNIT_TEST_SUITE_REGISTRATION( Metalink2RequestGroupTest );
 
- void Metalink2RequestGroupTest::testGenerate()
 
- {
 
-   std::vector<SharedHandle<RequestGroup> > groups;
 
-   option_->put(PREF_DIR, "/tmp");
 
-   Metalink2RequestGroup().generate(groups, A2_TEST_DIR"/test.xml", option_);
 
-   // first file
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[0];
 
-     std::vector<std::string> uris;
 
-     rg->getDownloadContext()->getFirstFileEntry()->getUris(uris);
 
-     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]);
 
-     const SharedHandle<DownloadContext>& dctx = rg->getDownloadContext();
 
-     CPPUNIT_ASSERT(dctx);
 
-     CPPUNIT_ASSERT_EQUAL((uint64_t)0ULL, dctx->getTotalLength());
 
- #ifdef ENABLE_MESSAGE_DIGEST
 
-     CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), dctx->getHashType());
 
-     CPPUNIT_ASSERT_EQUAL
 
-       (std::string("a96cf3f0266b91d87d5124cf94326422800b627d"),
 
-        dctx->getDigest());
 
- #endif // ENABLE_MESSAGE_DIGEST
 
-     CPPUNIT_ASSERT(dctx->getSignature());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("pgp"), dctx->getSignature()->getType());
 
-   }
 
-   // second file
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[1];
 
-     std::vector<std::string> uris;
 
-     rg->getDownloadContext()->getFirstFileEntry()->getUris(uris);
 
-     CPPUNIT_ASSERT_EQUAL((size_t)2, uris.size());
 
-     const SharedHandle<DownloadContext>& dctx = rg->getDownloadContext();
 
-     CPPUNIT_ASSERT(dctx);
 
- #ifdef ENABLE_MESSAGE_DIGEST
 
-     CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), dctx->getPieceHashType());
 
-     CPPUNIT_ASSERT_EQUAL((size_t)2, dctx->getPieceHashes().size());
 
-     CPPUNIT_ASSERT_EQUAL((size_t)262144, dctx->getPieceLength());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), dctx->getHashType());
 
-     CPPUNIT_ASSERT_EQUAL
 
-       (std::string("4c255b0ed130f5ea880f0aa061c3da0487e251cc"),
 
-        dctx->getDigest());
 
- #endif // ENABLE_MESSAGE_DIGEST
 
-     CPPUNIT_ASSERT(!dctx->getSignature());
 
-   }
 
- #ifdef ENABLE_BITTORRENT
 
-   // fifth file <- downloading .torrent file
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[4];
 
-     std::vector<std::string> uris;
 
-     rg->getDownloadContext()->getFirstFileEntry()->getUris(uris);
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, uris.size());
 
-     CPPUNIT_ASSERT_EQUAL
 
-       (std::string("http://host/torrent-http.integrated.torrent"), uris[0]);
 
-     const SharedHandle<DownloadContext>& dctx = rg->getDownloadContext();
 
-     CPPUNIT_ASSERT(dctx);
 
-     CPPUNIT_ASSERT_EQUAL(groups[5]->getGID(), rg->belongsTo());
 
-   }
 
- #endif // ENABLE_BITTORRENT
 
-   // sixth file <- depends on fifth file to download .torrent file.
 
-   {
 
- #ifdef ENABLE_BITTORRENT
 
-     SharedHandle<RequestGroup> rg = groups[5];
 
- #else
 
-     SharedHandle<RequestGroup> rg = groups[4];
 
- #endif // ENABLE_BITTORRENT
 
-     std::vector<std::string> uris;
 
-     rg->getDownloadContext()->getFirstFileEntry()->getUris(uris);
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, uris.size());
 
-     CPPUNIT_ASSERT_EQUAL
 
-       (std::string("http://host/torrent-http.integrated"), uris[0]);
 
-     const SharedHandle<DownloadContext>& dctx = rg->getDownloadContext();
 
-     CPPUNIT_ASSERT(dctx);
 
-   }
 
- }
 
- void Metalink2RequestGroupTest::testGenerate_groupByMetaurl()
 
- {
 
-   std::vector<SharedHandle<RequestGroup> > groups;
 
-   Metalink2RequestGroup().generate(groups,
 
-                                    A2_TEST_DIR"/metalink4-groupbymetaurl.xml",
 
-                                    option_);
 
-   CPPUNIT_ASSERT_EQUAL((size_t)3, groups.size());
 
- #ifdef ENABLE_BITTORRENT
 
-   // first RequestGroup is torrent for second RequestGroup
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[0];
 
-     std::vector<std::string> uris;
 
-     rg->getDownloadContext()->getFirstFileEntry()->getUris(uris);
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, uris.size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("http://torrent"), uris[0]);
 
-   }
 
-   // second
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[1];
 
-     SharedHandle<DownloadContext> dctx = rg->getDownloadContext();
 
-     const std::vector<SharedHandle<FileEntry> >& fileEntries =
 
-       dctx->getFileEntries();
 
-     CPPUNIT_ASSERT_EQUAL((size_t)2, fileEntries.size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("./file1"), fileEntries[0]->getPath());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("file1"), fileEntries[0]->getOriginalName());
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, fileEntries[0]->getRemainingUris().size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("http://file1p1"),
 
-                          fileEntries[0]->getRemainingUris()[0]);
 
-     CPPUNIT_ASSERT_EQUAL(std::string("./file3"), fileEntries[1]->getPath());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("file3"), fileEntries[1]->getOriginalName());
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, fileEntries[1]->getRemainingUris().size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("http://file3p1"),
 
-                          fileEntries[1]->getRemainingUris()[0]);
 
-   }
 
-   // third
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[2];
 
-     SharedHandle<DownloadContext> dctx = rg->getDownloadContext();
 
-     const std::vector<SharedHandle<FileEntry> >& fileEntries =
 
-       dctx->getFileEntries();
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, fileEntries.size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("./file2"), fileEntries[0]->getPath());
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, fileEntries[0]->getRemainingUris().size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("http://file2p1"),
 
-                          fileEntries[0]->getRemainingUris()[0]);
 
-   }
 
- #else // !ENABLE_BITTORRENT
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[0];
 
-     std::vector<std::string> uris;
 
-     rg->getDownloadContext()->getFirstFileEntry()->getUris(uris);
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, uris.size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("http://file1p1"), uris[0]);
 
-   }
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[1];
 
-     std::vector<std::string> uris;
 
-     rg->getDownloadContext()->getFirstFileEntry()->getUris(uris);
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, uris.size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("http://file2p1"), uris[0]);
 
-   }
 
-   {
 
-     SharedHandle<RequestGroup> rg = groups[2];
 
-     std::vector<std::string> uris;
 
-     rg->getDownloadContext()->getFirstFileEntry()->getUris(uris);
 
-     CPPUNIT_ASSERT_EQUAL((size_t)1, uris.size());
 
-     CPPUNIT_ASSERT_EQUAL(std::string("http://file3p1"), uris[0]);
 
-   }
 
-   
 
- #endif // !ENABLE_BITTORRENT
 
- }
 
- void Metalink2RequestGroupTest::testGenerate_dosDirTraversal()
 
- {
 
- #ifdef __MINGW32__
 
- #ifdef ENABLE_BITTORRENT
 
-   std::vector<SharedHandle<RequestGroup> > groups;
 
-   option_->put(PREF_DIR, "/tmp");
 
-   Metalink2RequestGroup().generate
 
-     (groups, A2_TEST_DIR"/metalink4-dosdirtraversal.xml", option_);
 
-   CPPUNIT_ASSERT_EQUAL((size_t)3, groups.size());
 
-   SharedHandle<RequestGroup> rg = groups[0];
 
-   SharedHandle<FileEntry> file = rg->getDownloadContext()->getFirstFileEntry();
 
-   CPPUNIT_ASSERT_EQUAL(std::string("/tmp/..%5C..%5Cexample.ext"),
 
-                        file->getPath());
 
-   
 
-   rg = groups[2];
 
-   file = rg->getDownloadContext()->getFileEntries()[0];
 
-   CPPUNIT_ASSERT_EQUAL(std::string("/tmp/..%5C..%5Cfile1.ext"),
 
-                        file->getPath());
 
-   file = rg->getDownloadContext()->getFileEntries()[1];
 
-   CPPUNIT_ASSERT_EQUAL(std::string("/tmp/..%5C..%5Cfile2.ext"),
 
-                        file->getPath());
 
- #endif // ENABLE_BITTORRENT
 
- #endif // __MINGW32__
 
- }
 
- } // namespace aria2
 
 
  |