case_insensitive_test.cpp 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. // Copyright 2006-2009 Daniel James.
  2. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  3. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  4. #include "./case_insensitive.hpp"
  5. #include <boost/core/lightweight_test.hpp>
  6. #include <boost/unordered_map.hpp>
  7. struct word_info {
  8. int tag;
  9. explicit word_info(int t = 0) : tag(t) {}
  10. };
  11. void test1() {
  12. boost::unordered_map<std::string, word_info,
  13. hash_examples::ihash, hash_examples::iequal_to> idictionary;
  14. BOOST_TEST(idictionary.empty());
  15. idictionary["one"] = word_info(1);
  16. BOOST_TEST(idictionary.size() == 1);
  17. BOOST_TEST(idictionary.find("ONE") != idictionary.end() &&
  18. idictionary.find("ONE") == idictionary.find("one"));
  19. idictionary.insert(std::make_pair("ONE", word_info(2)));
  20. BOOST_TEST(idictionary.size() == 1);
  21. BOOST_TEST(idictionary.find("ONE") != idictionary.end() &&
  22. idictionary.find("ONE")->first == "one" &&
  23. idictionary.find("ONE")->second.tag == 1);
  24. idictionary["One"] = word_info(3);
  25. BOOST_TEST(idictionary.size() == 1);
  26. BOOST_TEST(idictionary.find("ONE") != idictionary.end() &&
  27. idictionary.find("ONE")->first == "one" &&
  28. idictionary.find("ONE")->second.tag == 3);
  29. idictionary["two"] = word_info(4);
  30. BOOST_TEST(idictionary.size() == 2);
  31. BOOST_TEST(idictionary.find("two") != idictionary.end() &&
  32. idictionary.find("TWO")->first == "two" &&
  33. idictionary.find("Two")->second.tag == 4);
  34. }
  35. void test2() {
  36. boost::unordered_map<std::wstring, word_info,
  37. hash_examples::ihash, hash_examples::iequal_to> idictionary;
  38. BOOST_TEST(idictionary.empty());
  39. idictionary[L"one"] = word_info(1);
  40. BOOST_TEST(idictionary.size() == 1);
  41. BOOST_TEST(idictionary.find(L"ONE") != idictionary.end() &&
  42. idictionary.find(L"ONE") == idictionary.find(L"one"));
  43. idictionary.insert(std::make_pair(L"ONE", word_info(2)));
  44. BOOST_TEST(idictionary.size() == 1);
  45. BOOST_TEST(idictionary.find(L"ONE") != idictionary.end() &&
  46. idictionary.find(L"ONE")->first == L"one" &&
  47. idictionary.find(L"ONE")->second.tag == 1);
  48. idictionary[L"One"] = word_info(3);
  49. BOOST_TEST(idictionary.size() == 1);
  50. BOOST_TEST(idictionary.find(L"ONE") != idictionary.end() &&
  51. idictionary.find(L"ONE")->first == L"one" &&
  52. idictionary.find(L"ONE")->second.tag == 3);
  53. idictionary[L"two"] = word_info(4);
  54. BOOST_TEST(idictionary.size() == 2);
  55. BOOST_TEST(idictionary.find(L"two") != idictionary.end() &&
  56. idictionary.find(L"TWO")->first == L"two" &&
  57. idictionary.find(L"Two")->second.tag == 4);
  58. }
  59. int main() {
  60. test1();
  61. test2();
  62. return boost::report_errors();
  63. }