#include "DHTNode.h"
#include "DHTNodeLookupEntry.h"
#include "DHTIDCloser.h"
#include "Exception.h"
#include "util.h"
#include <cstring>
#include <algorithm>
#include <cppunit/extensions/HelperMacros.h>

namespace aria2 {

class DHTIDCloserTest:public CppUnit::TestFixture {

  CPPUNIT_TEST_SUITE(DHTIDCloserTest);
  CPPUNIT_TEST(testOperator);
  CPPUNIT_TEST_SUITE_END();
public:
  void setUp() {}

  void tearDown() {}

  void testOperator();
};


CPPUNIT_TEST_SUITE_REGISTRATION(DHTIDCloserTest);

void DHTIDCloserTest::testOperator()
{
  unsigned char id[DHT_ID_LENGTH];
  memset(id, 0xf0, DHT_ID_LENGTH);

  SharedHandle<DHTNodeLookupEntry> e1
    (new DHTNodeLookupEntry(SharedHandle<DHTNode>(new DHTNode(id))));

  id[0] = 0xb0;
  SharedHandle<DHTNodeLookupEntry> e2
    (new DHTNodeLookupEntry(SharedHandle<DHTNode>(new DHTNode(id))));

  id[0] = 0xa0;
  SharedHandle<DHTNodeLookupEntry> e3
    (new DHTNodeLookupEntry(SharedHandle<DHTNode>(new DHTNode(id))));

  id[0] = 0x80;
  SharedHandle<DHTNodeLookupEntry> e4
    (new DHTNodeLookupEntry(SharedHandle<DHTNode>(new DHTNode(id))));

  id[0] = 0x00;
  SharedHandle<DHTNodeLookupEntry> e5
    (new DHTNodeLookupEntry(SharedHandle<DHTNode>(new DHTNode(id))));

  std::deque<SharedHandle<DHTNodeLookupEntry> > entries;
  entries.push_back(e1);
  entries.push_back(e2);
  entries.push_back(e3);
  entries.push_back(e4);
  entries.push_back(e5);

  std::sort(entries.begin(), entries.end(), DHTIDCloser(e3->node->getID()));

  CPPUNIT_ASSERT(*e3 == *entries[0]);
  CPPUNIT_ASSERT(*e2 == *entries[1]);
  CPPUNIT_ASSERT(*e4 == *entries[2]);
  CPPUNIT_ASSERT(*e1 == *entries[3]);
  CPPUNIT_ASSERT(*e5 == *entries[4]);
}

} // namespace aria2