#include #include #include template using OrderedDict = torch::OrderedDict; TEST(OrderedDictTest, IsEmptyAfterDefaultConstruction) { OrderedDict dict; ASSERT_EQ(dict.key_description(), "Key"); ASSERT_TRUE(dict.is_empty()); ASSERT_EQ(dict.size(), 0); } TEST(OrderedDictTest, InsertAddsElementsWhenTheyAreYetNotPresent) { OrderedDict dict; dict.insert("a", 1); dict.insert("b", 2); ASSERT_EQ(dict.size(), 2); } TEST(OrderedDictTest, GetReturnsValuesWhenTheyArePresent) { OrderedDict dict; dict.insert("a", 1); dict.insert("b", 2); ASSERT_EQ(dict["a"], 1); ASSERT_EQ(dict["b"], 2); } TEST(OrderedDictTest, GetThrowsWhenPassedKeysThatAreNotPresent) { OrderedDict dict; dict.insert("a", 1); dict.insert("b", 2); ASSERT_THROWS_WITH(dict["foo"], "Key 'foo' is not defined"); ASSERT_THROWS_WITH(dict[""], "Key '' is not defined"); } TEST(OrderedDictTest, CanInitializeFromList) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_EQ(dict.size(), 2); ASSERT_EQ(dict["a"], 1); ASSERT_EQ(dict["b"], 2); } TEST(OrderedDictTest, InsertThrowsWhenPassedElementsThatArePresent) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_THROWS_WITH(dict.insert("a", 1), "Key 'a' already defined"); ASSERT_THROWS_WITH(dict.insert("b", 1), "Key 'b' already defined"); } TEST(OrderedDictTest, FrontReturnsTheFirstItem) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_EQ(dict.front().key(), "a"); ASSERT_EQ(dict.front().value(), 1); } TEST(OrderedDictTest, FrontThrowsWhenEmpty) { OrderedDict dict; ASSERT_THROWS_WITH(dict.front(), "Called front() on an empty OrderedDict"); } TEST(OrderedDictTest, BackReturnsTheLastItem) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_EQ(dict.back().key(), "b"); ASSERT_EQ(dict.back().value(), 2); } TEST(OrderedDictTest, BackThrowsWhenEmpty) { OrderedDict dict; ASSERT_THROWS_WITH(dict.back(), "Called back() on an empty OrderedDict"); } TEST(OrderedDictTest, FindReturnsPointersToValuesWhenPresent) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_NE(dict.find("a"), nullptr); ASSERT_EQ(*dict.find("a"), 1); ASSERT_NE(dict.find("b"), nullptr); ASSERT_EQ(*dict.find("b"), 2); } TEST(OrderedDictTest, FindReturnsNullPointersWhenPasesdKeysThatAreNotPresent) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_EQ(dict.find("bar"), nullptr); ASSERT_EQ(dict.find(""), nullptr); } TEST(OrderedDictTest, SubscriptOperatorThrowsWhenPassedKeysThatAreNotPresent) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_EQ(dict["a"], 1); ASSERT_EQ(dict["b"], 2); } TEST( OrderedDictTest, SubscriptOperatorReturnsItemsPositionallyWhenPassedIntegers) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_EQ(dict[0].key(), "a"); ASSERT_EQ(dict[0].value(), 1); ASSERT_EQ(dict[1].key(), "b"); ASSERT_EQ(dict[1].value(), 2); } TEST(OrderedDictTest, SubscriptOperatorsThrowswhenPassedKeysThatAreNotPresent) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_THROWS_WITH(dict["foo"], "Key 'foo' is not defined"); ASSERT_THROWS_WITH(dict[""], "Key '' is not defined"); } TEST(OrderedDictTest, UpdateInsertsAllItemsFromAnotherOrderedDict) { OrderedDict dict = {{"a", 1}, {"b", 2}}; OrderedDict dict2 = {{"c", 3}}; dict2.update(dict); ASSERT_EQ(dict2.size(), 3); ASSERT_NE(dict2.find("a"), nullptr); ASSERT_NE(dict2.find("b"), nullptr); ASSERT_NE(dict2.find("c"), nullptr); } TEST(OrderedDictTest, UpdateAlsoChecksForDuplicates) { OrderedDict dict = {{"a", 1}, {"b", 2}}; OrderedDict dict2 = {{"a", 1}}; ASSERT_THROWS_WITH(dict2.update(dict), "Key 'a' already defined"); } TEST(OrderedDictTest, CanIterateItems) { OrderedDict dict = {{"a", 1}, {"b", 2}}; auto iterator = dict.begin(); ASSERT_NE(iterator, dict.end()); ASSERT_EQ(iterator->key(), "a"); ASSERT_EQ(iterator->value(), 1); ++iterator; ASSERT_NE(iterator, dict.end()); ASSERT_EQ(iterator->key(), "b"); ASSERT_EQ(iterator->value(), 2); ++iterator; ASSERT_EQ(iterator, dict.end()); } TEST(OrderedDictTest, EraseWorks) { OrderedDict dict = {{"a", 1}, {"b", 2}, {"c", 3}}; dict.erase("b"); ASSERT_FALSE(dict.contains("b")); ASSERT_EQ(dict["a"], 1); ASSERT_EQ(dict["c"], 3); dict.erase("a"); ASSERT_FALSE(dict.contains("a")); ASSERT_EQ(dict["c"], 3); dict.erase("c"); ASSERT_FALSE(dict.contains("c")); ASSERT_TRUE(dict.is_empty()); } TEST(OrderedDictTest, ClearMakesTheDictEmpty) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_FALSE(dict.is_empty()); dict.clear(); ASSERT_TRUE(dict.is_empty()); } TEST(OrderedDictTest, CanCopyConstruct) { OrderedDict dict = {{"a", 1}, {"b", 2}}; OrderedDict copy = dict; ASSERT_EQ(copy.size(), 2); ASSERT_EQ(*copy[0], 1); ASSERT_EQ(*copy[1], 2); } TEST(OrderedDictTest, CanCopyAssign) { OrderedDict dict = {{"a", 1}, {"b", 2}}; OrderedDict copy = {{"c", 1}}; ASSERT_NE(copy.find("c"), nullptr); copy = dict; ASSERT_EQ(copy.size(), 2); ASSERT_EQ(*copy[0], 1); ASSERT_EQ(*copy[1], 2); ASSERT_EQ(copy.find("c"), nullptr); } TEST(OrderedDictTest, CanMoveConstruct) { OrderedDict dict = {{"a", 1}, {"b", 2}}; OrderedDict copy = std::move(dict); ASSERT_EQ(copy.size(), 2); ASSERT_EQ(*copy[0], 1); ASSERT_EQ(*copy[1], 2); } TEST(OrderedDictTest, CanMoveAssign) { OrderedDict dict = {{"a", 1}, {"b", 2}}; OrderedDict copy = {{"c", 1}}; ASSERT_NE(copy.find("c"), nullptr); copy = std::move(dict); ASSERT_EQ(copy.size(), 2); ASSERT_EQ(*copy[0], 1); ASSERT_EQ(*copy[1], 2); ASSERT_EQ(copy.find("c"), nullptr); } TEST(OrderedDictTest, CanInsertWithBraces) { OrderedDict> dict; dict.insert("a", {1, 2}); ASSERT_FALSE(dict.is_empty()); ASSERT_EQ(dict["a"].first, 1); ASSERT_EQ(dict["a"].second, 2); } TEST(OrderedDictTest, ErrorMessagesIncludeTheKeyDescription) { OrderedDict dict("Penguin"); ASSERT_EQ(dict.key_description(), "Penguin"); dict.insert("a", 1); ASSERT_FALSE(dict.is_empty()); ASSERT_THROWS_WITH(dict["b"], "Penguin 'b' is not defined"); ASSERT_THROWS_WITH(dict.insert("a", 1), "Penguin 'a' already defined"); } TEST(OrderedDictTest, KeysReturnsAllKeys) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_EQ(dict.keys(), std::vector({"a", "b"})); } TEST(OrderedDictTest, ValuesReturnsAllValues) { OrderedDict dict = {{"a", 1}, {"b", 2}}; ASSERT_EQ(dict.values(), std::vector({1, 2})); } TEST(OrderedDictTest, ItemsReturnsAllItems) { OrderedDict dict = {{"a", 1}, {"b", 2}}; std::vector::Item> items = dict.items(); ASSERT_EQ(items.size(), 2); ASSERT_EQ(items[0].key(), "a"); ASSERT_EQ(items[0].value(), 1); ASSERT_EQ(items[1].key(), "b"); ASSERT_EQ(items[1].value(), 2); }