XORCloserTest.cc 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. #include "XORCloser.h"
  2. #include "Exception.h"
  3. #include "Util.h"
  4. #include "DHTNodeLookupEntry.h"
  5. #include "DHTNode.h"
  6. #include <cstring>
  7. #include <algorithm>
  8. #include <cppunit/extensions/HelperMacros.h>
  9. namespace aria2 {
  10. class XORCloserTest:public CppUnit::TestFixture {
  11. CPPUNIT_TEST_SUITE(XORCloserTest);
  12. CPPUNIT_TEST(testOperator);
  13. CPPUNIT_TEST_SUITE_END();
  14. public:
  15. void setUp() {}
  16. void tearDown() {}
  17. void testOperator();
  18. };
  19. CPPUNIT_TEST_SUITE_REGISTRATION(XORCloserTest);
  20. void XORCloserTest::testOperator()
  21. {
  22. const size_t NUM_KEY = 6;
  23. unsigned char keys[NUM_KEY][DHT_ID_LENGTH];
  24. memset(keys, 0, 6*DHT_ID_LENGTH);
  25. keys[0][0] = 0xf0;
  26. keys[1][0] = 0xb0;
  27. keys[2][0] = 0xa0;
  28. keys[3][0] = 0x80;
  29. keys[4][0] = 0x00;
  30. keys[4][DHT_ID_LENGTH-1] = 0x01;
  31. keys[5][0] = 0x00;
  32. std::deque<unsigned char*> l(&keys[0], &keys[NUM_KEY]);
  33. std::sort(l.begin(), l.end(), XORCloser(keys[2], DHT_ID_LENGTH));
  34. CPPUNIT_ASSERT(memcmp(keys[2], l[0], DHT_ID_LENGTH) == 0);
  35. CPPUNIT_ASSERT(memcmp(keys[1], l[1], DHT_ID_LENGTH) == 0);
  36. CPPUNIT_ASSERT(memcmp(keys[3], l[2], DHT_ID_LENGTH) == 0);
  37. CPPUNIT_ASSERT(memcmp(keys[0], l[3], DHT_ID_LENGTH) == 0);
  38. CPPUNIT_ASSERT(memcmp(keys[5], l[4], DHT_ID_LENGTH) == 0);
  39. CPPUNIT_ASSERT(memcmp(keys[4], l[5], DHT_ID_LENGTH) == 0);
  40. }
  41. } // namespace aria2