HashedStringTests.cpp 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #include "../Tests.hpp"
  2. #include "core/HashMap.hpp"
  3. #include "core/HashedString.hpp"
  4. #include "core/Test.hpp"
  5. template class Core::HashedString<32>;
  6. using HString = Core::HashedString<32>;
  7. static void testComparison() {
  8. HString a("test");
  9. TEST_STRING("test", static_cast<const char*>(a));
  10. HString b("testA");
  11. HString c("");
  12. HString d("Btest");
  13. TEST_TRUE(a == a);
  14. TEST_TRUE(b == b);
  15. TEST_TRUE(c == c);
  16. TEST_TRUE(d == d);
  17. TEST_TRUE(a != b);
  18. TEST_TRUE(a != c);
  19. TEST_TRUE(a != d);
  20. TEST_TRUE(b != a);
  21. TEST_TRUE(b != c);
  22. TEST_TRUE(b != d);
  23. TEST_TRUE(c != a);
  24. TEST_TRUE(c != b);
  25. TEST_TRUE(c != d);
  26. TEST_TRUE(d != a);
  27. TEST_TRUE(d != b);
  28. TEST_TRUE(d != c);
  29. }
  30. static void testLength() {
  31. HString s("test");
  32. TEST(4, s.getLength());
  33. TEST(31, s.getCapacity());
  34. }
  35. static void testHashCode() {
  36. HString a;
  37. HString b("wusi");
  38. TEST(a.hashCode(), 0lu);
  39. TEST_TRUE(b.hashCode() != 0u);
  40. }
  41. static void testAsHashMapKey() {
  42. Core::HashMap<HString, int> map;
  43. map.add("wusi", 3).add("hiThere", 7).add("baum123", 5);
  44. int* a = map.search("wusi");
  45. int* b = map.search("hiThere");
  46. int* c = map.search("baum123");
  47. TEST_NULL(map.search("423hifd"));
  48. if(TEST_NOT_NULL(a) && TEST_NOT_NULL(b) && TEST_NOT_NULL(c)) {
  49. TEST(3, *a);
  50. TEST(7, *b);
  51. TEST(5, *c);
  52. }
  53. }
  54. void testHashedString() {
  55. testComparison();
  56. testLength();
  57. testHashCode();
  58. testAsHashMapKey();
  59. }