123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- #include "MetalinkEntry.h"
- #include <cppunit/extensions/HelperMacros.h>
- using namespace std;
- class MetalinkEntryTest:public CppUnit::TestFixture {
- CPPUNIT_TEST_SUITE(MetalinkEntryTest);
- CPPUNIT_TEST(testDropUnsupportedResource);
- CPPUNIT_TEST(testReorderResourcesByPreference);
- CPPUNIT_TEST_SUITE_END();
- private:
- public:
- void setUp() {
- }
- void tearDown() {
- }
- void testDropUnsupportedResource();
- void testReorderResourcesByPreference();
- };
- CPPUNIT_TEST_SUITE_REGISTRATION( MetalinkEntryTest );
- MetalinkEntry* createTestEntry() {
- MetalinkEntry* entry = new MetalinkEntry();
- MetalinkResource* res1 = new MetalinkResource();
- res1->url = "ftp://myhost/aria2.tar.bz2";
- res1->type = MetalinkResource::TYPE_FTP;
- res1->location = "RO";
- res1->preference = 50;
- MetalinkResource* res2 = new MetalinkResource();
- res2->url = "http://myhost/aria2.tar.bz2";
- res2->type = MetalinkResource::TYPE_HTTP;
- res2->location = "AT";
- res2->preference = 100;
- MetalinkResource* res3 = new MetalinkResource();
- res3->url = "http://myhost/aria2.torrent";
- res3->type = MetalinkResource::TYPE_BITTORRENT;
- res3->location = "al";
- res3->preference = 60;
- MetalinkResource* res4 = new MetalinkResource();
- res4->url = "http://myhost/aria2.ext";
- res4->type = MetalinkResource::TYPE_NOT_SUPPORTED;
- res4->location = "ad";
- res4->preference = 10;
- MetalinkResource* res5 = new MetalinkResource();
- res5->url = "https://myhost/aria2.tar.bz2";
- res5->type = MetalinkResource::TYPE_HTTPS;
- res5->location = "jp";
- res5->preference = 90;
- entry->resources.push_back(res1);
- entry->resources.push_back(res2);
- entry->resources.push_back(res3);
- entry->resources.push_back(res4);
- entry->resources.push_back(res5);
- return entry;
- }
- void MetalinkEntryTest::testDropUnsupportedResource() {
- MetalinkEntry* entry = createTestEntry();
- entry->dropUnsupportedResource();
- #if defined ENABLE_SSL && ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL(4, (int)entry->resources.size());
- #elif defined ENABLE_SSL || ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL(3, (int)entry->resources.size());
- #else
- CPPUNIT_ASSERT_EQUAL(2, (int)entry->resources.size());
- #endif // ENABLE_MESSAGE_DIGEST
-
- MetalinkResources::const_iterator itr = entry->resources.begin();
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_FTP,
- (*itr++)->type);
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_HTTP,
- (*itr++)->type);
- #ifdef ENABLE_BITTORRENT
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_BITTORRENT,
- (*itr++)->type);
- #endif // ENABLE_BITTORRENT
- #ifdef ENABLE_SSL
- CPPUNIT_ASSERT_EQUAL(MetalinkResource::TYPE_HTTPS,
- (*itr++)->type);
- #endif // ENABLE_SSL
- }
- void MetalinkEntryTest::testReorderResourcesByPreference() {
- MetalinkEntry* entry = createTestEntry();
-
- entry->reorderResourcesByPreference();
- CPPUNIT_ASSERT_EQUAL(100, entry->resources.at(0)->preference);
- CPPUNIT_ASSERT_EQUAL(90, entry->resources.at(1)->preference);
- CPPUNIT_ASSERT_EQUAL(60, entry->resources.at(2)->preference);
- CPPUNIT_ASSERT_EQUAL(50, entry->resources.at(3)->preference);
- CPPUNIT_ASSERT_EQUAL(10, entry->resources.at(4)->preference);
- }
|