// Copyright (c) 2010, Amar Takhar // // Permission to use, copy, modify, and distribute this software for any // purpose with or without fee is hereby granted, provided that the above // copyright notice and this permission notice appear in all copies. // // THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES // WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR // ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES // WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN // ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF // OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include #include #include "main.h" class lagi_mru : public libagi { protected: std::string default_mru; std::string conf_ok; void SetUp() override { default_mru = "{\"Valid\" : []}"; conf_ok = "./data/mru_ok.json"; } }; TEST_F(lagi_mru, load_from_file) { ASSERT_NO_THROW(agi::MRUManager mru(conf_ok, default_mru)); agi::MRUManager mru(conf_ok, default_mru); ASSERT_NO_THROW(mru.Get("Valid")); ASSERT_EQ(2u, mru.Get("Valid")->size()); auto entry = mru.Get("Valid")->begin(); EXPECT_STREQ("Entry One", (*entry++).string().c_str()); EXPECT_STREQ("Entry Two", (*entry++).string().c_str()); EXPECT_TRUE(mru.Get("Valid")->end() == entry); } TEST_F(lagi_mru, load_from_default_string) { agi::fs::Remove("data/mru_tmp"); agi::MRUManager mru("data/mru_tmp", default_mru); } TEST_F(lagi_mru, load_from_invalid_file) { agi::fs::Copy("data/mru_invalid.json", "data/mru_tmp"); agi::MRUManager mru("data/mru_tmp", default_mru); EXPECT_TRUE(mru.Get("Invalid")->empty()); } TEST_F(lagi_mru, add_entry) { agi::fs::Copy("data/mru_ok.json", "data/mru_tmp"); agi::MRUManager mru("data/mru_tmp", default_mru); EXPECT_NO_THROW(mru.Add("Valid", "/path/to/file")); EXPECT_STREQ("/path/to/file", mru.Get("Valid")->front().string().c_str()); } TEST_F(lagi_mru, remove_entry) { agi::fs::Copy("data/mru_ok.json", "data/mru_tmp"); agi::MRUManager mru("data/mru_tmp", default_mru); EXPECT_NO_THROW(mru.Add("Valid", "/path/to/file")); EXPECT_NO_THROW(mru.Remove("Valid", "/path/to/file")); EXPECT_STRNE("/path/to/file", mru.Get("Valid")->front().string().c_str()); } TEST_F(lagi_mru, invalid_mru_key_throws) { agi::fs::Copy("data/mru_ok.json", "data/mru_tmp"); agi::MRUManager mru("data/mru_tmp", default_mru); EXPECT_THROW(mru.Add("Invalid", "/path/to/file"), agi::MRUErrorInvalidKey); EXPECT_THROW(mru.Get("Invalid"), agi::MRUErrorInvalidKey); } TEST_F(lagi_mru, valid_mru_key_doesnt_throw) { agi::fs::Copy("data/mru_ok.json", "data/mru_tmp"); agi::MRUManager mru("data/mru_tmp", default_mru); EXPECT_NO_THROW(mru.Add("Valid", "/path/to/file")); } TEST_F(lagi_mru, adding_existing_moves_to_front) { agi::fs::Remove("data/mru_tmp"); agi::MRUManager mru("data/mru_tmp", default_mru); EXPECT_NO_THROW(mru.Add("Valid", "/file/1")); EXPECT_NO_THROW(mru.Add("Valid", "/file/2")); EXPECT_NO_THROW(mru.Add("Valid", "/file/3")); EXPECT_NO_THROW(mru.Add("Valid", "/file/1")); EXPECT_NO_THROW(mru.Add("Valid", "/file/1")); EXPECT_NO_THROW(mru.Add("Valid", "/file/3")); EXPECT_STREQ("/file/3", mru.GetEntry("Valid", 0).string().c_str()); EXPECT_STREQ("/file/1", mru.GetEntry("Valid", 1).string().c_str()); EXPECT_STREQ("/file/2", mru.GetEntry("Valid", 2).string().c_str()); EXPECT_THROW(mru.GetEntry("Valid", 3), agi::MRUErrorIndexOutOfRange); } // Check to make sure an entry is really removed. This was fixed in // r4347, the entry was being removed from a copy of the map internally. TEST_F(lagi_mru, MRUEntryRemove_r4347) { agi::MRUManager mru(conf_ok, default_mru); EXPECT_NO_THROW(mru.Add("Valid", "/path/to/file")); EXPECT_NO_THROW(mru.Remove("Valid", "/path/to/file")); const agi::MRUManager::MRUListMap *map_list = mru.Get("Valid"); auto i_lst = map_list->begin(); if ((i_lst != map_list->end()) && (*i_lst == "/path/to/file")) FAIL() << "r4347 regression, Entry exists after remove"; }