AnnounceListTest.cc 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315
  1. #include "AnnounceList.h"
  2. #include <cppunit/extensions/HelperMacros.h>
  3. #include "Exception.h"
  4. #include "bencode.h"
  5. namespace aria2 {
  6. class AnnounceListTest:public CppUnit::TestFixture {
  7. CPPUNIT_TEST_SUITE(AnnounceListTest);
  8. CPPUNIT_TEST(testSingleElementList);
  9. CPPUNIT_TEST(testMultiElementList);
  10. CPPUNIT_TEST(testSingleAndMulti);
  11. CPPUNIT_TEST(testNoGroup);
  12. CPPUNIT_TEST(testEvent);
  13. CPPUNIT_TEST(testNextEventIfAfterStarted);
  14. CPPUNIT_TEST(testCountStoppedAllowedTier);
  15. CPPUNIT_TEST(testCountCompletedAllowedTier);
  16. CPPUNIT_TEST(testMoveToStoppedAllowedTier);
  17. CPPUNIT_TEST(testMoveToCompletedAllowedTier);
  18. CPPUNIT_TEST_SUITE_END();
  19. private:
  20. public:
  21. void setUp() {
  22. }
  23. void testSingleElementList();
  24. void testMultiElementList();
  25. void testSingleAndMulti();
  26. void testNoGroup();
  27. void testEvent();
  28. void testNextEventIfAfterStarted();
  29. void testCountStoppedAllowedTier();
  30. void testCountCompletedAllowedTier();
  31. void testMoveToStoppedAllowedTier();
  32. void testMoveToCompletedAllowedTier();
  33. };
  34. CPPUNIT_TEST_SUITE_REGISTRATION( AnnounceListTest );
  35. void AnnounceListTest::testSingleElementList() {
  36. std::string peersString = "ll8:tracker1el8:tracker2el8:tracker3ee";
  37. const BDE announcesList = bencode::decode(peersString);
  38. // ANNOUNCE_LIST
  39. // [ [ tracker1 ], [ tracker2 ], [ tracker3 ] ]
  40. AnnounceList announceList(announcesList);
  41. CPPUNIT_ASSERT(!announceList.allTiersFailed());
  42. std::string url = announceList.getAnnounce();
  43. std::string event = announceList.getEventString();
  44. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), url);
  45. CPPUNIT_ASSERT_EQUAL(std::string("started"), event);
  46. announceList.announceFailure();
  47. url = announceList.getAnnounce();
  48. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), url);
  49. announceList.announceFailure();
  50. url = announceList.getAnnounce();
  51. CPPUNIT_ASSERT_EQUAL(std::string("tracker3"), url);
  52. announceList.announceFailure();
  53. CPPUNIT_ASSERT(announceList.allTiersFailed());
  54. announceList.resetTier();
  55. CPPUNIT_ASSERT(!announceList.allTiersFailed());
  56. // back to the first list
  57. url = announceList.getAnnounce();
  58. event = announceList.getEventString();
  59. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), url);
  60. CPPUNIT_ASSERT_EQUAL(std::string("started"), event);
  61. announceList.announceFailure();
  62. url = announceList.getAnnounce();
  63. event = announceList.getEventString();
  64. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), url);
  65. CPPUNIT_ASSERT_EQUAL(std::string("started"), event);
  66. announceList.announceSuccess();
  67. // back to the first list because announce to tracker2 succeeded.
  68. url = announceList.getAnnounce();
  69. event = announceList.getEventString();
  70. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), url);
  71. CPPUNIT_ASSERT_EQUAL(std::string("started"), event);
  72. announceList.announceFailure();
  73. url = announceList.getAnnounce();
  74. event = announceList.getEventString();
  75. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), url);
  76. CPPUNIT_ASSERT_EQUAL(std::string(""), event);
  77. }
  78. void AnnounceListTest::testMultiElementList() {
  79. std::string peersString = "ll8:tracker18:tracker28:tracker3ee";
  80. const BDE announcesList = bencode::decode(peersString);
  81. // ANNOUNCE_LIST
  82. // [ [ tracker1, tracker2, tracker3 ] ]
  83. AnnounceList announceList(announcesList);
  84. CPPUNIT_ASSERT(!announceList.allTiersFailed());
  85. std::string url = announceList.getAnnounce();
  86. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), url);
  87. announceList.announceFailure();
  88. url = announceList.getAnnounce();
  89. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), url);
  90. announceList.announceSuccess();
  91. url = announceList.getAnnounce();
  92. // tracker2 returns because tracker2 is now first.
  93. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), url);
  94. announceList.announceFailure();
  95. url = announceList.getAnnounce();
  96. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), url);
  97. announceList.announceFailure();
  98. url = announceList.getAnnounce();
  99. CPPUNIT_ASSERT_EQUAL(std::string("tracker3"), url);
  100. announceList.announceFailure();
  101. CPPUNIT_ASSERT(announceList.allTiersFailed());
  102. announceList.resetTier();
  103. CPPUNIT_ASSERT(!announceList.allTiersFailed());
  104. // back to the first list because there is no other list.
  105. url = announceList.getAnnounce();
  106. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), url);
  107. }
  108. void AnnounceListTest::testSingleAndMulti() {
  109. std::string peersString = "ll8:tracker18:tracker2el8:tracker3ee";
  110. const BDE announcesList = bencode::decode(peersString);
  111. // ANNOUNCE_LIST
  112. // [ [ tracker1, tracker2 ], [ tracker3 ] ]
  113. AnnounceList announceList(announcesList);
  114. std::string url = announceList.getAnnounce();
  115. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), url);
  116. announceList.announceSuccess();
  117. url = announceList.getAnnounce();
  118. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), url);
  119. announceList.announceFailure();
  120. url = announceList.getAnnounce();
  121. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), url);
  122. announceList.announceFailure();
  123. url = announceList.getAnnounce();
  124. CPPUNIT_ASSERT_EQUAL(std::string("tracker3"), url);
  125. announceList.announceSuccess();
  126. url = announceList.getAnnounce();
  127. // tracker1 returns because after the announce to tracker3 succeeds, list
  128. // pointer points to the first list.
  129. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), url);
  130. }
  131. void AnnounceListTest::testNoGroup() {
  132. std::string peersString = "llee";
  133. const BDE announcesList = bencode::decode(peersString);
  134. AnnounceList announceList(announcesList);
  135. CPPUNIT_ASSERT(announceList.countTier() == 0);
  136. }
  137. void AnnounceListTest::testNextEventIfAfterStarted() {
  138. std::string peersString = "ll8:tracker1ee";
  139. const BDE announcesList = bencode::decode(peersString);
  140. // ANNOUNCE_LIST
  141. // [ [ tracker1 ] ]
  142. AnnounceList announceList(announcesList);
  143. announceList.setEvent(AnnounceTier::STOPPED);
  144. announceList.announceFailure();
  145. announceList.resetTier();
  146. CPPUNIT_ASSERT_EQUAL(std::string(""), announceList.getEventString());
  147. CPPUNIT_ASSERT_EQUAL(AnnounceTier::HALTED, announceList.getEvent());
  148. announceList.setEvent(AnnounceTier::COMPLETED);
  149. announceList.announceFailure();
  150. announceList.resetTier();
  151. CPPUNIT_ASSERT_EQUAL(std::string(""), announceList.getEventString());
  152. CPPUNIT_ASSERT_EQUAL(AnnounceTier::SEEDING, announceList.getEvent());
  153. }
  154. void AnnounceListTest::testEvent() {
  155. std::string peersString = "ll8:tracker1el8:tracker2el8:tracker3ee";
  156. const BDE announcesList = bencode::decode(peersString);
  157. // ANNOUNCE_LIST
  158. // [ [ tracker1 ], [ tracker2 ], [ tracker3 ] ]
  159. AnnounceList announceList(announcesList);
  160. announceList.setEvent(AnnounceTier::STOPPED);
  161. announceList.announceSuccess();
  162. CPPUNIT_ASSERT_EQUAL(std::string(""), announceList.getEventString());
  163. CPPUNIT_ASSERT_EQUAL(AnnounceTier::HALTED, announceList.getEvent());
  164. announceList.setEvent(AnnounceTier::COMPLETED);
  165. announceList.announceSuccess();
  166. CPPUNIT_ASSERT_EQUAL(std::string(""), announceList.getEventString());
  167. CPPUNIT_ASSERT_EQUAL(AnnounceTier::SEEDING, announceList.getEvent());
  168. announceList.setEvent(AnnounceTier::STARTED_AFTER_COMPLETION);
  169. CPPUNIT_ASSERT_EQUAL(std::string("started"), announceList.getEventString());
  170. announceList.announceSuccess();
  171. CPPUNIT_ASSERT_EQUAL(AnnounceTier::SEEDING, announceList.getEvent());
  172. }
  173. void AnnounceListTest::testCountStoppedAllowedTier() {
  174. std::string peersString = "ll8:tracker1el8:tracker2el8:tracker3ee";
  175. const BDE announcesList = bencode::decode(peersString);
  176. // ANNOUNCE_LIST
  177. // [ [ tracker1 ], [ tracker2 ], [ tracker3 ] ]
  178. AnnounceList announceList(announcesList);
  179. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countStoppedAllowedTier());
  180. announceList.setEvent(AnnounceTier::STARTED);
  181. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countStoppedAllowedTier());
  182. announceList.setEvent(AnnounceTier::STARTED_AFTER_COMPLETION);
  183. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countStoppedAllowedTier());
  184. announceList.setEvent(AnnounceTier::HALTED);
  185. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countStoppedAllowedTier());
  186. announceList.setEvent(AnnounceTier::DOWNLOADING);
  187. CPPUNIT_ASSERT_EQUAL((size_t)1, announceList.countStoppedAllowedTier());
  188. announceList.setEvent(AnnounceTier::STOPPED);
  189. CPPUNIT_ASSERT_EQUAL((size_t)1, announceList.countStoppedAllowedTier());
  190. announceList.setEvent(AnnounceTier::COMPLETED);
  191. CPPUNIT_ASSERT_EQUAL((size_t)1, announceList.countStoppedAllowedTier());
  192. announceList.setEvent(AnnounceTier::SEEDING);
  193. CPPUNIT_ASSERT_EQUAL((size_t)1, announceList.countStoppedAllowedTier());
  194. }
  195. void AnnounceListTest::testCountCompletedAllowedTier() {
  196. std::string peersString = "ll8:tracker1el8:tracker2el8:tracker3ee";
  197. const BDE announcesList = bencode::decode(peersString);
  198. // ANNOUNCE_LIST
  199. // [ [ tracker1 ], [ tracker2 ], [ tracker3 ] ]
  200. AnnounceList announceList(announcesList);
  201. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countCompletedAllowedTier());
  202. announceList.setEvent(AnnounceTier::STARTED);
  203. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countCompletedAllowedTier());
  204. announceList.setEvent(AnnounceTier::STARTED_AFTER_COMPLETION);
  205. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countCompletedAllowedTier());
  206. announceList.setEvent(AnnounceTier::STOPPED);
  207. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countCompletedAllowedTier());
  208. announceList.setEvent(AnnounceTier::SEEDING);
  209. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countCompletedAllowedTier());
  210. announceList.setEvent(AnnounceTier::HALTED);
  211. CPPUNIT_ASSERT_EQUAL((size_t)0, announceList.countCompletedAllowedTier());
  212. announceList.setEvent(AnnounceTier::DOWNLOADING);
  213. CPPUNIT_ASSERT_EQUAL((size_t)1, announceList.countCompletedAllowedTier());
  214. announceList.setEvent(AnnounceTier::COMPLETED);
  215. CPPUNIT_ASSERT_EQUAL((size_t)1, announceList.countCompletedAllowedTier());
  216. }
  217. std::deque<std::string> createUrls(const std::string& url) {
  218. std::deque<std::string> urls;
  219. urls.push_back(url);
  220. return urls;
  221. }
  222. void AnnounceListTest::testMoveToStoppedAllowedTier() {
  223. SharedHandle<AnnounceTier> t1(new AnnounceTier(createUrls("tracker1")));
  224. SharedHandle<AnnounceTier> t2(new AnnounceTier(createUrls("tracker2")));
  225. t2->event = AnnounceTier::COMPLETED;
  226. SharedHandle<AnnounceTier> t3(new AnnounceTier(createUrls("tracker3")));
  227. std::deque<SharedHandle<AnnounceTier> > tiers;
  228. tiers.push_back(t1);
  229. tiers.push_back(t2);
  230. tiers.push_back(t3);
  231. AnnounceList announceList(tiers);
  232. CPPUNIT_ASSERT(!announceList.currentTierAcceptsStoppedEvent());
  233. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), announceList.getAnnounce());
  234. announceList.moveToStoppedAllowedTier();
  235. CPPUNIT_ASSERT(announceList.currentTierAcceptsStoppedEvent());
  236. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), announceList.getAnnounce());
  237. announceList.announceFailure();
  238. CPPUNIT_ASSERT(!announceList.currentTierAcceptsStoppedEvent());
  239. CPPUNIT_ASSERT_EQUAL(std::string("tracker3"), announceList.getAnnounce());
  240. // test wrapped search
  241. announceList.moveToStoppedAllowedTier();
  242. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), announceList.getAnnounce());
  243. }
  244. void AnnounceListTest::testMoveToCompletedAllowedTier() {
  245. SharedHandle<AnnounceTier> t1(new AnnounceTier(createUrls("tracker1")));
  246. SharedHandle<AnnounceTier> t2(new AnnounceTier(createUrls("tracker2")));
  247. t2->event = AnnounceTier::COMPLETED;
  248. SharedHandle<AnnounceTier> t3(new AnnounceTier(createUrls("tracker3")));
  249. std::deque<SharedHandle<AnnounceTier> > tiers;
  250. tiers.push_back(t1);
  251. tiers.push_back(t2);
  252. tiers.push_back(t3);
  253. AnnounceList announceList(tiers);
  254. CPPUNIT_ASSERT(!announceList.currentTierAcceptsCompletedEvent());
  255. CPPUNIT_ASSERT_EQUAL(std::string("tracker1"), announceList.getAnnounce());
  256. announceList.moveToStoppedAllowedTier();
  257. CPPUNIT_ASSERT(announceList.currentTierAcceptsCompletedEvent());
  258. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), announceList.getAnnounce());
  259. announceList.announceFailure();
  260. CPPUNIT_ASSERT(!announceList.currentTierAcceptsCompletedEvent());
  261. CPPUNIT_ASSERT_EQUAL(std::string("tracker3"), announceList.getAnnounce());
  262. // test wrapped search
  263. announceList.moveToStoppedAllowedTier();
  264. CPPUNIT_ASSERT_EQUAL(std::string("tracker2"), announceList.getAnnounce());
  265. }
  266. } // namespace aria2