// Copyright (c) 2017, Baidu.com, Inc. All Rights Reserved // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, // software distributed under the License is distributed on an // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY // KIND, either express or implied. See the License for the // specific language governing permissions and limitations // under the License. #include "util/lru_cache.hpp" #include #include namespace palo { class LruCacheTest : public testing::Test { }; struct Foo { Foo(int num_param): num(num_param) { } int num; }; TEST_F(LruCacheTest, NormalTest) { LruCache> cache(10); for (int i = 0; i < 10; ++i) { cache.put(i, std::shared_ptr(new Foo(i * 10))); } ASSERT_EQ(10, cache.size()); std::shared_ptr ptr; for (int i = 0; i < 10; ++i) { ASSERT_TRUE(cache.get(i, &ptr)); ASSERT_EQ(i * 10, ptr->num); } } TEST_F(LruCacheTest, IteratorTest) { LruCache> cache(10); int keys = 0; int values = 0; for (int i = 0; i < 10; ++i) { keys += i; values += i * 10; cache.put(i, std::shared_ptr(new Foo(i * 10))); } ASSERT_EQ(10, cache.size()); int key_sum = 0; int value_sum = 0; for (auto& it : cache) { key_sum += it.first; value_sum += it.second->num; } ASSERT_EQ(keys, key_sum); ASSERT_EQ(values, value_sum); std::shared_ptr ptr; for (int i = 0; i < 10; ++i) { ASSERT_TRUE(cache.get(i, &ptr)); ASSERT_EQ(i * 10, ptr->num); } } TEST_F(LruCacheTest, OverSize) { LruCache> cache(10); for (int i = 0; i < 110; ++i) { cache.put(i, std::shared_ptr(new Foo(i * 10))); } ASSERT_EQ(10, cache.size()); std::shared_ptr ptr; for (int i = 100; i < 110; ++i) { ASSERT_TRUE(cache.get(i, &ptr)); ASSERT_EQ(i * 10, ptr->num); } } } int main(int argc, char** argv) { ::testing::InitGoogleTest(&argc, argv); return RUN_ALL_TESTS(); }