1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057 |
- #include "MetalinkProcessor.h"
- #include <iostream>
- #include <cppunit/extensions/HelperMacros.h>
- #include "MetalinkParserStateMachine.h"
- #include "Exception.h"
- #include "DefaultDiskWriter.h"
- #include "ByteArrayDiskWriter.h"
- #include "Metalinker.h"
- #include "MetalinkEntry.h"
- #include "MetalinkResource.h"
- #include "MetalinkMetaurl.h"
- #ifdef ENABLE_MESSAGE_DIGEST
- # include "MessageDigest.h"
- # include "ChunkChecksum.h"
- # include "Checksum.h"
- #endif // ENABLE_MESSAGE_DIGEST
- #include "Signature.h"
- #include "fmt.h"
- #include "RecoverableException.h"
- namespace aria2 {
- class MetalinkProcessorTest:public CppUnit::TestFixture {
- CPPUNIT_TEST_SUITE(MetalinkProcessorTest);
- CPPUNIT_TEST(testParseFileV4);
- CPPUNIT_TEST(testParseFileV4_attrs);
- CPPUNIT_TEST(testParseFile);
- CPPUNIT_TEST(testParseFile_dirtraversal);
- CPPUNIT_TEST(testParseFromBinaryStream);
- CPPUNIT_TEST(testMalformedXML);
- CPPUNIT_TEST(testMalformedXML2);
- CPPUNIT_TEST(testBadSize);
- CPPUNIT_TEST(testBadSizeV4);
- CPPUNIT_TEST(testBadMaxConn);
- CPPUNIT_TEST(testNoName);
- CPPUNIT_TEST(testBadURLPrefs);
- CPPUNIT_TEST(testBadURLMaxConn);
- #ifdef ENABLE_MESSAGE_DIGEST
- CPPUNIT_TEST(testUnsupportedType);
- CPPUNIT_TEST(testMultiplePieces);
- CPPUNIT_TEST(testBadPieceNo);
- CPPUNIT_TEST(testBadPieceLength);
- CPPUNIT_TEST(testUnsupportedType_piece);
- #endif // ENABLE_MESSAGE_DIGEST
- CPPUNIT_TEST(testLargeFileSize);
- CPPUNIT_TEST(testXmlPrefixV3);
- CPPUNIT_TEST_SUITE_END();
- private:
- public:
- void testParseFileV4();
- void testParseFileV4_attrs();
- void testParseFile();
- void testParseFile_dirtraversal();
- void testParseFromBinaryStream();
- void testMalformedXML();
- void testMalformedXML2();
- void testBadSize();
- void testBadSizeV4();
- void testBadMaxConn();
- void testNoName();
- void testBadURLPrefs();
- void testBadURLMaxConn();
- #ifdef ENABLE_MESSAGE_DIGEST
- void testUnsupportedType();
- void testMultiplePieces();
- void testBadPieceNo();
- void testBadPieceLength();
- void testUnsupportedType_piece();
- #endif // ENABLE_MESSAGE_DIGEST
- void testLargeFileSize();
- void testXmlPrefixV3();
- };
- CPPUNIT_TEST_SUITE_REGISTRATION( MetalinkProcessorTest );
- void MetalinkProcessorTest::testParseFileV4()
- {
- MetalinkProcessor proc;
- SharedHandle<Metalinker> m = proc.parseFile("metalink4.xml");
- SharedHandle<MetalinkEntry> e;
- SharedHandle<MetalinkResource> r;
- SharedHandle<MetalinkMetaurl> mu;
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- e = m->getEntries()[0];
- CPPUNIT_ASSERT_EQUAL(std::string("example.ext"), e->getPath());
- CPPUNIT_ASSERT_EQUAL((uint64_t)786430LL, e->getLength());
- CPPUNIT_ASSERT_EQUAL(-1, e->maxConnections);
- #ifdef ENABLE_MESSAGE_DIGEST
- CPPUNIT_ASSERT_EQUAL(std::string("0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33"),
- e->checksum->getMessageDigest());
- CPPUNIT_ASSERT(e->checksum);
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), e->checksum->getAlgo());
- CPPUNIT_ASSERT(e->chunkChecksum);
- if(MessageDigest::supports("sha-256")) {
- CPPUNIT_ASSERT_EQUAL(std::string("sha-256"), e->chunkChecksum->getAlgo());
- CPPUNIT_ASSERT_EQUAL((size_t)262144, e->chunkChecksum->getChecksumLength());
- CPPUNIT_ASSERT_EQUAL((size_t)3, e->chunkChecksum->countChecksum());
- CPPUNIT_ASSERT_EQUAL(std::string("0245178074fd042e19b7c3885b360fc21064b30e73f5626c7e3b005d048069c5"),
- e->chunkChecksum->getChecksum(0));
- CPPUNIT_ASSERT_EQUAL(std::string("487ba2299be7f759d7c7bf6a4ac3a32cee81f1bb9332fc485947e32918864fb2"),
- e->chunkChecksum->getChecksum(1));
- CPPUNIT_ASSERT_EQUAL(std::string("37290d74ac4d186e3a8e5785d259d2ec04fac91ae28092e7620ec8bc99e830aa"),
- e->chunkChecksum->getChecksum(2));
- } else {
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), e->chunkChecksum->getAlgo());
- CPPUNIT_ASSERT_EQUAL((size_t)262144, e->chunkChecksum->getChecksumLength());
- CPPUNIT_ASSERT_EQUAL((size_t)3, e->chunkChecksum->countChecksum());
- CPPUNIT_ASSERT_EQUAL
- (std::string("5bd9f7248df0f3a6a86ab6c95f48787d546efa14"),
- e->chunkChecksum->getChecksum(0));
- CPPUNIT_ASSERT_EQUAL
- (std::string("9413ee70957a09d55704123687478e07f18c7b29"),
- e->chunkChecksum->getChecksum(1));
- CPPUNIT_ASSERT_EQUAL
- (std::string("44213f9f4d59b557314fadcd233232eebcac8012"),
- e->chunkChecksum->getChecksum(2));
- }
- #endif // ENABLE_MESSAGE_DIGEST
- CPPUNIT_ASSERT(e->getSignature());
- CPPUNIT_ASSERT_EQUAL(std::string("application/pgp-signature"),
- e->getSignature()->getType());
- CPPUNIT_ASSERT_EQUAL(std::string("a signature"),
- e->getSignature()->getBody());
- CPPUNIT_ASSERT_EQUAL((size_t)2, e->resources.size());
- r = e->resources[0];
- CPPUNIT_ASSERT_EQUAL(std::string("ftp://ftp.example.com/example.ext"),
- r->url);
- CPPUNIT_ASSERT_EQUAL(std::string("de"), r->location);
- CPPUNIT_ASSERT_EQUAL(1, r->priority);
- CPPUNIT_ASSERT_EQUAL(std::string("ftp"),
- MetalinkResource::getTypeString(r->type));
- CPPUNIT_ASSERT_EQUAL(-1, r->maxConnections);
- #ifdef ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL((size_t)1, e->metaurls.size());
- mu = e->metaurls[0];
- CPPUNIT_ASSERT_EQUAL(std::string("http://example.com/example.ext.torrent"),
- mu->url);
- CPPUNIT_ASSERT_EQUAL(2, mu->priority);
- CPPUNIT_ASSERT_EQUAL(std::string("torrent"), mu->mediatype);
- #else // !ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL((size_t)0, e->metaurls.size());
- #endif // !ENABLE_BITTORRENT
- }
- void MetalinkProcessorTest::testParseFileV4_attrs()
- {
- MetalinkProcessor proc;
- SharedHandle<Metalinker> m;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- {
- // Testing file@name
- const char* tmpl = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"%s\">"
- "<url>http://example.org</url>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "foo"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- // empty name
- dw->setString(fmt(tmpl, ""));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- // dir traversing
- dw->setString(fmt(tmpl, "../doughnuts"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- }
- {
- // Testing url@priority
- const char* tmpl = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url priority=\"%s\">http://example.org</url>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "0"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- dw->setString(fmt(tmpl, "1"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- dw->setString(fmt(tmpl, "100"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- dw->setString(fmt(tmpl, "999999"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- dw->setString(fmt(tmpl, "1000000"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- dw->setString(fmt(tmpl, "A"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- }
- {
- // Testing metaurl@priority
- const char* tmpl =
- "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<metaurl priority=\"%s\" mediatype=\"torrent\">http://example.org</metaurl>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "0"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- dw->setString(fmt(tmpl, "1"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- dw->setString(fmt(tmpl, "100"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- dw->setString(fmt(tmpl, "999999"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- dw->setString(fmt(tmpl, "1000000"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- dw->setString(fmt(tmpl, "A"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- }
- {
- // Testing metaurl@mediatype
- // no mediatype
- dw->setString("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<metaurl>http://example.org</metaurl>"
- "</file>"
- "</metalink>");
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- const char* tmpl =
- "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<metaurl mediatype=\"%s\">http://example.org</metaurl>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "torrent"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- // empty mediatype
- dw->setString(fmt(tmpl, ""));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- }
- {
- // Testing metaurl@name
- const char* tmpl =
- "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<metaurl mediatype=\"torrent\" name=\"%s\">http://example.org</metaurl>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "foo"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- // dir traversing
- dw->setString(fmt(tmpl, "../doughnuts"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- // empty name
- dw->setString(fmt(tmpl, ""));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {
- // success
- }
- }
- #ifdef ENABLE_MESSAGE_DIGEST
- {
- // Testing pieces@length
- // No pieces@length
- dw->setString
- ("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url>http://example.org</url>"
- "<pieces type=\"sha-1\">"
- "<hash>0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33</hash>"
- "</pieces>"
- "</file>"
- "</metalink>");
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- const char* tmpl =
- "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url>http://example.org</url>"
- "<pieces length=\"%s\" type=\"sha-1\">"
- "<hash>0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33</hash>"
- "</pieces>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "262144"));
- m = proc.parseFromBinaryStream(dw);
- // empty
- try {
- dw->setString(fmt(tmpl, ""));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- // not a number
- try {
- dw->setString(fmt(tmpl, "A"));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- }
- {
- // Testing pieces@type
- // No pieces@type
- dw->setString
- ("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url>http://example.org</url>"
- "<pieces length=\"262144\">"
- "<hash>0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33</hash>"
- "</pieces>"
- "</file>"
- "</metalink>");
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- const char* tmpl =
- "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url>http://example.org</url>"
- "<pieces length=\"262144\" type=\"%s\">"
- "<hash>0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33</hash>"
- "</pieces>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "sha-1"));
- m = proc.parseFromBinaryStream(dw);
- // empty
- try {
- dw->setString(fmt(tmpl, ""));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- }
- {
- // Testing hash@type
- // No hash@type
- dw->setString
- ("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url>http://example.org</url>"
- "<hash>0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33</hash>"
- "</file>"
- "</metalink>");
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- const char* tmpl =
- "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url>http://example.org</url>"
- "<hash type=\"%s\">0beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33</hash>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "sha-1"));
- m = proc.parseFromBinaryStream(dw);
- // empty
- try {
- dw->setString(fmt(tmpl, ""));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- }
- #endif // ENABLE_MESSAGE_DIGEST
- {
- // Testing signature@mediatype
- // No hash@type
- dw->setString
- ("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url>http://example.org</url>"
- "<signature>sig</signature>"
- "</file>"
- "</metalink>");
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- const char* tmpl =
- "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"example.ext\">"
- "<url>http://example.org</url>"
- "<signature mediatype=\"%s\">sig</signature>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "application/pgp-signature"));
- m = proc.parseFromBinaryStream(dw);
- // empty
- try {
- dw->setString(fmt(tmpl, ""));
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- }
- }
- void MetalinkProcessorTest::testParseFile()
- {
- MetalinkProcessor proc;
- try {
- SharedHandle<Metalinker> metalinker = proc.parseFile("test.xml");
- std::vector<SharedHandle<MetalinkEntry> >::const_iterator entryItr =
- metalinker->getEntries().begin();
- SharedHandle<MetalinkEntry> entry1 = *entryItr;
- CPPUNIT_ASSERT_EQUAL(std::string("aria2-0.5.2.tar.bz2"), entry1->getPath());
- CPPUNIT_ASSERT_EQUAL((uint64_t)0ULL, entry1->getLength());
- CPPUNIT_ASSERT_EQUAL(std::string("0.5.2"), entry1->version);
- CPPUNIT_ASSERT_EQUAL(std::string("en-US"), entry1->languages[0]);
- CPPUNIT_ASSERT_EQUAL(std::string("Linux-x86"), entry1->oses[0]);
- CPPUNIT_ASSERT_EQUAL(1, entry1->maxConnections);
- #ifdef ENABLE_MESSAGE_DIGEST
- CPPUNIT_ASSERT_EQUAL(std::string("a96cf3f0266b91d87d5124cf94326422800b627d"),
- entry1->checksum->getMessageDigest());
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), entry1->checksum->getAlgo());
- #endif // ENABLE_MESSAGE_DIGEST
- CPPUNIT_ASSERT(entry1->getSignature());
- CPPUNIT_ASSERT_EQUAL(std::string("pgp"), entry1->getSignature()->getType());
- CPPUNIT_ASSERT_EQUAL(std::string("aria2-0.5.2.tar.bz2.sig"),
- entry1->getSignature()->getFile());
- // Note that last '\n' character is trimmed.
- CPPUNIT_ASSERT_EQUAL
- (std::string
- ("-----BEGIN PGP SIGNATURE-----\n"
- "Version: GnuPG v1.4.9 (GNU/Linux)\n"
- "\n"
- "ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff\n"
- "ffffffffffffffffffffffff\n"
- "fffff\n"
- "-----END PGP SIGNATURE-----"),
- entry1->getSignature()->getBody());
- std::vector<SharedHandle<MetalinkResource> >::iterator resourceItr1 =
- entry1->resources.begin();
- SharedHandle<MetalinkResource> resource1 = *resourceItr1;
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_FTP, resource1->type);
- CPPUNIT_ASSERT_EQUAL(std::string("jp"), resource1->location);
- CPPUNIT_ASSERT_EQUAL(1, resource1->priority);
- CPPUNIT_ASSERT_EQUAL(std::string("ftp://ftphost/aria2-0.5.2.tar.bz2"),
- resource1->url);
- CPPUNIT_ASSERT_EQUAL(1, resource1->maxConnections);
- resourceItr1++;
- SharedHandle<MetalinkResource> resource2 = *resourceItr1;
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_HTTP, resource2->type);
- CPPUNIT_ASSERT_EQUAL(std::string("us"), resource2->location);
- CPPUNIT_ASSERT_EQUAL(1, resource2->priority);
- CPPUNIT_ASSERT_EQUAL(std::string("http://httphost/aria2-0.5.2.tar.bz2"),
- resource2->url);
- CPPUNIT_ASSERT_EQUAL(-1, resource2->maxConnections);
- entryItr++;
- SharedHandle<MetalinkEntry> entry2 = *entryItr;
- CPPUNIT_ASSERT_EQUAL(std::string("aria2-0.5.1.tar.bz2"), entry2->getPath());
- CPPUNIT_ASSERT_EQUAL((uint64_t)345689ULL, entry2->getLength());
- CPPUNIT_ASSERT_EQUAL(std::string("0.5.1"), entry2->version);
- CPPUNIT_ASSERT_EQUAL(std::string("ja-JP"), entry2->languages[0]);
- CPPUNIT_ASSERT_EQUAL(std::string("Linux-m68k"), entry2->oses[0]);
- CPPUNIT_ASSERT_EQUAL(-1, entry2->maxConnections);
- #ifdef ENABLE_MESSAGE_DIGEST
- CPPUNIT_ASSERT_EQUAL(std::string("4c255b0ed130f5ea880f0aa061c3da0487e251cc"),
- entry2->checksum->getMessageDigest());
- CPPUNIT_ASSERT_EQUAL((size_t)2, entry2->chunkChecksum->countChecksum());
- CPPUNIT_ASSERT_EQUAL((size_t)262144, entry2->chunkChecksum->getChecksumLength());
- CPPUNIT_ASSERT_EQUAL(std::string("179463a88d79cbf0b1923991708aead914f26142"),
- entry2->chunkChecksum->getChecksum(0));
- CPPUNIT_ASSERT_EQUAL(std::string("fecf8bc9a1647505fe16746f94e97a477597dbf3"),
- entry2->chunkChecksum->getChecksum(1));
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), entry2->checksum->getAlgo());
- #endif // ENABLE_MESSAGE_DIGEST
- // See that signature is null
- CPPUNIT_ASSERT(!entry2->getSignature());
- entryItr++;
- // test case: verification hash is not provided
- SharedHandle<MetalinkEntry> entry3 = *entryItr;
- CPPUNIT_ASSERT_EQUAL(std::string("NoVerificationHash"), entry3->getPath());
- #ifdef ENABLE_MESSAGE_DIGEST
- CPPUNIT_ASSERT(!entry3->checksum);
- CPPUNIT_ASSERT(!entry3->chunkChecksum);
- #endif // ENABLE_MESSAGE_DIGEST
- entryItr++;
- // test case: unsupported verification hash is included
- SharedHandle<MetalinkEntry> entry4 = *entryItr;
- CPPUNIT_ASSERT_EQUAL(std::string("UnsupportedVerificationHashTypeIncluded"), entry4->getPath());
- #ifdef ENABLE_MESSAGE_DIGEST
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), entry4->checksum->getAlgo());
- CPPUNIT_ASSERT_EQUAL(std::string("4c255b0ed130f5ea880f0aa061c3da0487e251cc"),
- entry4->checksum->getMessageDigest());
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"),entry4->chunkChecksum->getAlgo());
- #endif // ENABLE_MESSAGE_DIGEST
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testParseFile_dirtraversal()
- {
- MetalinkProcessor proc;
- SharedHandle<Metalinker> metalinker =
- proc.parseFile("metalink3-dirtraversal.xml");
- CPPUNIT_ASSERT_EQUAL((size_t)1, metalinker->getEntries().size());
- SharedHandle<MetalinkEntry> e = metalinker->getEntries()[0];
- CPPUNIT_ASSERT_EQUAL(std::string("aria2-0.5.3.tar.bz2"), e->getPath());
- CPPUNIT_ASSERT(e->getSignature());
- CPPUNIT_ASSERT_EQUAL(std::string(""), e->getSignature()->getFile());
- }
- void MetalinkProcessorTest::testParseFromBinaryStream()
- {
- MetalinkProcessor proc;
- DefaultDiskWriterHandle dw(new DefaultDiskWriter("test.xml"));
- dw->openExistingFile();
-
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- std::vector<SharedHandle<MetalinkEntry> >::const_iterator entryItr =
- m->getEntries().begin();
- SharedHandle<MetalinkEntry> entry1 = *entryItr;
- CPPUNIT_ASSERT_EQUAL(std::string("aria2-0.5.2.tar.bz2"), entry1->getPath());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testMalformedXML()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\"><files></file></metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(Exception& e) {
- std::cerr << e.stackTrace() << std::endl;
- }
- }
- void MetalinkProcessorTest::testMalformedXML2()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\"><files></files>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(Exception& e) {
- std::cerr << e.stackTrace() << std::endl;
- }
- }
- void MetalinkProcessorTest::testBadSizeV4()
- {
- MetalinkProcessor proc;
- SharedHandle<Metalinker> m;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- const char* tmpl =
- "<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
- "<metalink xmlns=\"urn:ietf:params:xml:ns:metalink\">"
- "<file name=\"foo\">"
- "<size>%s</size>"
- "<url>http://example.org</url>"
- "</file>"
- "</metalink>";
- dw->setString(fmt(tmpl, "9223372036854775807"));
- m = proc.parseFromBinaryStream(dw);
- dw->setString(fmt(tmpl, "-1"));
- try {
- m = proc.parseFromBinaryStream(dw);
- CPPUNIT_FAIL("exception must be thrown.");
- } catch(RecoverableException& e) {}
- }
-
- void MetalinkProcessorTest::testBadSize()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2-0.5.2.tar.bz2\">"
- " <size>abc</size>"
- " <version>0.5.2</version>"
- " <language>en-US</language>"
- " <os>Linux-x86</os>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- std::vector<SharedHandle<MetalinkEntry> >::const_iterator entryItr =
- m->getEntries().begin();
- SharedHandle<MetalinkEntry> e = *entryItr;
- CPPUNIT_ASSERT_EQUAL(std::string("aria2-0.5.2.tar.bz2"), e->getPath());
- CPPUNIT_ASSERT_EQUAL((uint64_t)0ULL, e->getLength());
- CPPUNIT_ASSERT_EQUAL(std::string("0.5.2"), e->version);
- CPPUNIT_ASSERT_EQUAL(std::string("en-US"), e->languages[0]);
- CPPUNIT_ASSERT_EQUAL(std::string("Linux-x86"), e->oses[0]);
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testBadMaxConn()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2-0.5.2.tar.bz2\">"
- " <size>43743838</size>"
- " <version>0.5.2</version>"
- " <language>en-US</language>"
- " <os>Linux-x86</os>"
- " <resources maxconnections=\"abc\"/>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- std::vector<SharedHandle<MetalinkEntry> >::const_iterator entryItr =
- m->getEntries().begin();
- SharedHandle<MetalinkEntry> e = *entryItr;
- CPPUNIT_ASSERT_EQUAL((uint64_t)43743838ULL, e->getLength());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testNoName()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file>"
- " <size>1024</size>"
- " <version>0.0.1</version>"
- " <language>GB</language>"
- " <os>Linux-x64</os>"
- "</file>"
- "<file name=\"aria2-0.5.2.tar.bz2\">"
- " <size>43743838</size>"
- " <version>0.5.2</version>"
- " <language>en-US</language>"
- " <os>Linux-x86</os>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- std::vector<SharedHandle<MetalinkEntry> >::const_iterator entryItr =
- m->getEntries().begin();
- SharedHandle<MetalinkEntry> e = *entryItr;
- CPPUNIT_ASSERT_EQUAL(std::string("aria2-0.5.2.tar.bz2"), e->getPath());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testBadURLPrefs()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2-0.5.2.tar.bz2\">"
- " <size>43743838</size>"
- " <version>0.5.2</version>"
- " <language>en-US</language>"
- " <os>Linux-x86</os>"
- " <resources>"
- " <url type=\"ftp\" maxconnections=\"1\" preference=\"xyz\""
- " location=\"jp\">ftp://mirror/</url>"
- " </resources>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- SharedHandle<MetalinkResource> r = e->resources[0];
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_FTP, r->type);
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::getLowestPriority(), r->priority);
- CPPUNIT_ASSERT_EQUAL(1, r->maxConnections);
- CPPUNIT_ASSERT_EQUAL(std::string("jp"), r->location);
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testBadURLMaxConn()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2-0.5.2.tar.bz2\">"
- " <size>43743838</size>"
- " <version>0.5.2</version>"
- " <language>en-US</language>"
- " <os>Linux-x86</os>"
- " <resources>"
- " <url maxconnections=\"xyz\" type=\"ftp\""
- " preference=\"100\""
- " location=\"jp\">ftp://mirror/</url>"
- " </resources>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- SharedHandle<MetalinkResource> r = e->resources[0];
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_FTP, r->type);
- CPPUNIT_ASSERT_EQUAL(1, r->priority);
- CPPUNIT_ASSERT_EQUAL(-1, r->maxConnections);
- CPPUNIT_ASSERT_EQUAL(std::string("jp"), r->location);
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- #ifdef ENABLE_MESSAGE_DIGEST
- void MetalinkProcessorTest::testUnsupportedType()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2-0.5.2.tar.bz2\">"
- " <size>43743838</size>"
- " <version>0.5.2</version>"
- " <language>en-US</language>"
- " <os>Linux-x86</os>"
- " <resources>"
- " <url type=\"ftp\">ftp://mirror/</url>"
- " <url type=\"magnet\">magnet:xt=XYZ</url>"
- " <url type=\"http\">http://mirror/</url>"
- " </resources>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- CPPUNIT_ASSERT_EQUAL((size_t)3, e->resources.size());
- SharedHandle<MetalinkResource> r1 = e->resources[0];
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_FTP, r1->type);
- SharedHandle<MetalinkResource> r2 = e->resources[1];
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_NOT_SUPPORTED, r2->type);
- SharedHandle<MetalinkResource> r3 = e->resources[2];
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_HTTP, r3->type);
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testMultiplePieces()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2.tar.bz2\">"
- " <verification>"
- " <pieces length=\"1024\" type=\"sha1\">"
- " </pieces>"
- " <pieces length=\"512\" type=\"md5\">"
- " </pieces>"
- " </verification>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- // aria2 prefers sha1
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- SharedHandle<ChunkChecksum> c = e->chunkChecksum;
-
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), c->getAlgo());
- CPPUNIT_ASSERT_EQUAL((size_t)1024, c->getChecksumLength());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testBadPieceNo()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString
- ("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2.tar.bz2\">"
- " <verification>"
- " <pieces length=\"512\" type=\"sha1\">"
- " <hash piece=\"0\">44213f9f4d59b557314fadcd233232eebcac8012</hash>"
- " <hash piece=\"xyz\">44213f9f4d59b557314fadcd233232eebcac8012</hash>"
- " </pieces>"
- " <pieces length=\"1024\" type=\"sha1\">"
- " <hash piece=\"0\">44213f9f4d59b557314fadcd233232eebcac8012</hash>"
- " </pieces>"
- " </verification>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- SharedHandle<ChunkChecksum> c = e->chunkChecksum;
- CPPUNIT_ASSERT(c);
- CPPUNIT_ASSERT_EQUAL((size_t)1024, c->getChecksumLength());
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), c->getAlgo());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testBadPieceLength()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString
- ("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2.tar.bz2\">"
- " <verification>"
- " <pieces length=\"xyz\" type=\"sha1\">"
- " <hash piece=\"0\">44213f9f4d59b557314fadcd233232eebcac8012</hash>"
- " </pieces>"
- " <pieces length=\"1024\" type=\"sha1\">"
- " <hash piece=\"0\">44213f9f4d59b557314fadcd233232eebcac8012</hash>"
- " </pieces>"
- " </verification>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- SharedHandle<ChunkChecksum> c = e->chunkChecksum;
- CPPUNIT_ASSERT(c);
- CPPUNIT_ASSERT_EQUAL((size_t)1024, c->getChecksumLength());
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), c->getAlgo());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testUnsupportedType_piece()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString
- ("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"aria2.tar.bz2\">"
- " <verification>"
- " <pieces length=\"512\" type=\"ARIA2\">"
- " <hash piece=\"0\">44213f9f4d59b557314fadcd233232eebcac8012</hash>"
- " </pieces>"
- " <pieces length=\"1024\" type=\"sha1\">"
- " <hash piece=\"0\">44213f9f4d59b557314fadcd233232eebcac8012</hash>"
- " </pieces>"
- " </verification>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- SharedHandle<ChunkChecksum> c = e->chunkChecksum;
-
- CPPUNIT_ASSERT(c);
- CPPUNIT_ASSERT_EQUAL((size_t)1024, c->getChecksumLength());
- CPPUNIT_ASSERT_EQUAL(std::string("sha-1"), c->getAlgo());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- #endif // ENABLE_MESSAGE_DIGEST
- void MetalinkProcessorTest::testLargeFileSize()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<metalink version=\"3.0\" xmlns=\"http://www.metalinker.org/\">"
- "<files>"
- "<file name=\"dvd.iso\">"
- " <size>9223372036854775807</size>"
- " <resources>"
- " <url type=\"http\">ftp://mirror/</url>"
- " </resources>"
- "</file>"
- "</files>"
- "</metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- CPPUNIT_ASSERT_EQUAL((uint64_t)9223372036854775807ULL, e->getLength());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- void MetalinkProcessorTest::testXmlPrefixV3()
- {
- MetalinkProcessor proc;
- SharedHandle<ByteArrayDiskWriter> dw(new ByteArrayDiskWriter());
- dw->setString("<m:metalink version=\"3.0\" xmlns:m=\"http://www.metalinker.org/\">"
- "<m:files>"
- "<m:file name=\"dvd.iso\">"
- " <m:size>9223372036854775807</m:size>"
- " <m:resources>"
- " <m:url type=\"http\">ftp://mirror/</m:url>"
- " </m:resources>"
- "</m:file>"
- "</m:files>"
- "</m:metalink>");
- try {
- SharedHandle<Metalinker> m = proc.parseFromBinaryStream(dw);
- CPPUNIT_ASSERT_EQUAL((size_t)1, m->getEntries().size());
- SharedHandle<MetalinkEntry> e = m->getEntries()[0];
- CPPUNIT_ASSERT_EQUAL((uint64_t)9223372036854775807ULL, e->getLength());
- } catch(Exception& e) {
- CPPUNIT_FAIL(e.stackTrace());
- }
- }
- } // namespace aria2
|