From: Aina Niemetz Date: Thu, 3 Dec 2020 00:37:26 +0000 (-0800) Subject: google test: base: Migrate map_util_black. (#5580) X-Git-Tag: cvc5-1.0.0~2514 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3a8e2f4e52f4debfb8eb6fb9c49934a66d742ec9;p=cvc5.git google test: base: Migrate map_util_black. (#5580) --- diff --git a/test/unit/CMakeLists.txt b/test/unit/CMakeLists.txt index d65e022c9..a6291178b 100644 --- a/test/unit/CMakeLists.txt +++ b/test/unit/CMakeLists.txt @@ -32,15 +32,16 @@ add_custom_target(units COMMAND ctest --output-on-failure -L "unit" -j${CTEST_NTHREADS} $$ARGS DEPENDS build-units) -set(CVC4_CXXTEST_FLAGS_BLACK +set(CVC4_UNIT_TEST_FLAGS_BLACK -D__BUILDING_CVC4LIB_UNIT_TEST -D__BUILDING_CVC4PARSERLIB_UNIT_TEST -D__STDC_LIMIT_MACROS -D__STDC_FORMAT_MACROS) -set(CVC4_CXXTEST_FLAGS_WHITE -fno-access-control ${CVC4_CXXTEST_FLAGS_BLACK}) +set(CVC4_CXXTEST_FLAGS_WHITE -fno-access-control ${CVC4_UNIT_TEST_FLAGS_BLACK}) # Generate and add unit test. macro(cvc4_add_unit_test is_white name output_dir) set(test_src ${CMAKE_CURRENT_LIST_DIR}/${name}.cpp) add_executable(${name} ${test_src}) + target_compile_definitions(${name} PRIVATE ${CVC4_UNIT_TEST_FLAGS_BLACK}) gtest_add_tests(TARGET ${name}) target_link_libraries(${name} main-test) target_link_libraries(${name} GTest::GTest) @@ -110,7 +111,7 @@ macro(cvc4_add_cxx_unit_test is_white name output_dir) add_executable(${name} ${test_src} ${test_header}) target_link_libraries(${name} main-test) target_include_directories(${name} PRIVATE ${CxxTest_INCLUDE_DIR}) - target_compile_definitions(${name} PRIVATE ${CVC4_CXXTEST_FLAGS_BLACK}) + target_compile_definitions(${name} PRIVATE ${CVC4_UNIT_TEST_FLAGS_BLACK}) if(USE_LFSC) # We don't link against LFSC, because CVC4 is already linked against it. target_include_directories(${name} PRIVATE ${LFSC_INCLUDE_DIR}) diff --git a/test/unit/base/CMakeLists.txt b/test/unit/base/CMakeLists.txt index 8274a5a46..81d27c040 100644 --- a/test/unit/base/CMakeLists.txt +++ b/test/unit/base/CMakeLists.txt @@ -11,4 +11,4 @@ #-----------------------------------------------------------------------------# # Add unit tests -cvc4_add_cxx_unit_test_black(map_util_black base) +cvc4_add_unit_test_black(map_util_black base) diff --git a/test/unit/base/map_util_black.cpp b/test/unit/base/map_util_black.cpp new file mode 100644 index 000000000..db3474af2 --- /dev/null +++ b/test/unit/base/map_util_black.cpp @@ -0,0 +1,213 @@ +/********************* */ +/*! \file map_util_black.cpp + ** \verbatim + ** Top contributors (to current version): + ** Aina Niemetz, Tim King + ** This file is part of the CVC4 project. + ** Copyright (c) 2009-2020 by the authors listed in the file AUTHORS + ** in the top-level source directory and their institutional affiliations. + ** All rights reserved. See the file COPYING in the top-level source + ** directory for licensing information.\endverbatim + ** + ** \brief Black box testing of map utility functions. + ** + ** Black box testing of map utility functions. + **/ + +#include +#include +#include +#include +#include + +#include "base/map_util.h" +#include "context/cdhashmap.h" +#include "context/cdhashset.h" +#include "context/cdinsert_hashmap.h" +#include "context/context.h" +#include "test.h" + +using CVC4::ContainsKey; +using CVC4::FindOrDie; +using CVC4::FindOrNull; +using CVC4::context::CDHashMap; +using CVC4::context::CDInsertHashMap; +using CVC4::context::Context; + +class TestMapBlack : public TestInternal +{ + protected: + /** Returns a map containing {"key"->"value", "other"->"entry"}. */ + static const std::map& default_map() + { + static const std::map static_stored_map{ + {"key", "value"}, {"other", "entry"}}; + return static_stored_map; + } + + /** + * For each pair in source, inserts mapping from key to value + * using insert into dest. + */ + template + void insert_all(const std::map& source, M* dest) + { + for (const auto& key_value : source) + { + dest->insert(key_value.first, key_value.second); + } + } +}; + +TEST_F(TestMapBlack, map) +{ + std::map map = default_map(); + ASSERT_TRUE(CVC4::ContainsKey(map, "key")); + ASSERT_FALSE(CVC4::ContainsKey(map, "non key")); + + EXPECT_EQ(FindOrNull(map, "non key"), nullptr); + if (std::string* found_value = FindOrNull(map, "other")) + { + EXPECT_EQ(*found_value, "entry"); + *found_value = "new value"; + } + EXPECT_EQ(FindOrDie(map, "other"), "new value"); +} + +TEST_F(TestMapBlack, constant_map) +{ + const std::map map = default_map(); + ASSERT_TRUE(CVC4::ContainsKey(map, "key")); + ASSERT_FALSE(CVC4::ContainsKey(map, "non key")); + + if (const std::string* found_value = FindOrNull(map, "other")) + { + EXPECT_EQ(*found_value, "entry"); + } + EXPECT_EQ(FindOrNull(map, "non key"), nullptr); + EXPECT_EQ(FindOrDie(map, "other"), "entry"); + ASSERT_DEATH(FindOrDie(map, "asdf"), "The map does not contain the key."); +} + +TEST_F(TestMapBlack, unordered_map) +{ + std::unordered_map map(default_map().begin(), + default_map().end()); + ASSERT_TRUE(CVC4::ContainsKey(map, "key")); + ASSERT_FALSE(CVC4::ContainsKey(map, "non key")); + + EXPECT_EQ(FindOrNull(map, "non key"), nullptr); + if (std::string* found_value = FindOrNull(map, "other")) + { + EXPECT_EQ(*found_value, "entry"); + *found_value = "new value"; + } + EXPECT_EQ(FindOrDie(map, "other"), "new value"); +} + +TEST_F(TestMapBlack, const_unordered_map) +{ + const std::unordered_map map(default_map().begin(), + default_map().end()); + ASSERT_TRUE(CVC4::ContainsKey(map, "key")); + ASSERT_FALSE(CVC4::ContainsKey(map, "non key")); + + if (const std::string* found_value = FindOrNull(map, "other")) + { + EXPECT_EQ(*found_value, "entry"); + } + EXPECT_EQ(FindOrNull(map, "non key"), nullptr); + EXPECT_EQ(FindOrDie(map, "other"), "entry"); + ASSERT_DEATH(FindOrDie(map, "asdf"), "The map does not contain the key."); +} + +TEST_F(TestMapBlack, set) +{ + std::set set{"entry", "other"}; + ASSERT_TRUE(CVC4::ContainsKey(set, "entry")); + ASSERT_FALSE(CVC4::ContainsKey(set, "non member")); + + const std::set const_set{"entry", "other"}; + ASSERT_TRUE(CVC4::ContainsKey(const_set, "entry")); + ASSERT_FALSE(CVC4::ContainsKey(const_set, "non member")); +} + +TEST_F(TestMapBlack, unordered_set) +{ + std::unordered_set set{"entry", "other"}; + ASSERT_TRUE(CVC4::ContainsKey(set, "entry")); + ASSERT_FALSE(CVC4::ContainsKey(set, "non member")); + + const std::unordered_set const_set{"entry", "other"}; + ASSERT_TRUE(CVC4::ContainsKey(const_set, "entry")); + ASSERT_FALSE(CVC4::ContainsKey(const_set, "non member")); +} + +TEST_F(TestMapBlack, CDHashMap) +{ + Context context; + CDHashMap map(&context); + insert_all(default_map(), &map); + + ASSERT_TRUE(CVC4::ContainsKey(map, "key")); + ASSERT_FALSE(CVC4::ContainsKey(map, "non key")); + + if (const std::string* found_value = FindOrNull(map, "other")) + { + EXPECT_EQ(*found_value, "entry"); + } + EXPECT_EQ(FindOrNull(map, "non key"), nullptr); + EXPECT_EQ(FindOrDie(map, "other"), "entry"); +} + +TEST_F(TestMapBlack, const_CDHashMap) +{ + Context context; + CDHashMap store(&context); + insert_all(default_map(), &store); + const auto& map = store; + + ASSERT_TRUE(CVC4::ContainsKey(map, "key")); + ASSERT_FALSE(CVC4::ContainsKey(map, "non key")); + + if (const std::string* found_value = FindOrNull(map, "other")) + { + EXPECT_EQ(*found_value, "entry"); + } + EXPECT_EQ(FindOrNull(map, "non key"), nullptr); + EXPECT_EQ(FindOrDie(map, "other"), "entry"); +} + +TEST_F(TestMapBlack, CDInsertHashMap) +{ + Context context; + CDInsertHashMap map(&context); + insert_all(default_map(), &map); + + ASSERT_TRUE(CVC4::ContainsKey(map, "key")); + ASSERT_FALSE(CVC4::ContainsKey(map, "non key")); + + if (const std::string* found_value = FindOrNull(map, "other")) + { + EXPECT_EQ(*found_value, "entry"); + } + EXPECT_EQ(FindOrNull(map, "non key"), nullptr); + EXPECT_EQ(FindOrDie(map, "other"), "entry"); +} + +TEST_F(TestMapBlack, const_CDInsertHashMap) +{ + Context context; + CDInsertHashMap store(&context); + insert_all(default_map(), &store); + const auto& map = store; + + ASSERT_TRUE(CVC4::ContainsKey(map, "key")); + ASSERT_FALSE(CVC4::ContainsKey(map, "non key")); + if (const std::string* found_value = FindOrNull(map, "other")) + { + EXPECT_EQ(*found_value, "entry"); + } + EXPECT_EQ(FindOrNull(map, "non key"), nullptr); + EXPECT_EQ(FindOrDie(map, "other"), "entry"); +} diff --git a/test/unit/base/map_util_black.h b/test/unit/base/map_util_black.h deleted file mode 100644 index 95dfbbfbf..000000000 --- a/test/unit/base/map_util_black.h +++ /dev/null @@ -1,216 +0,0 @@ -/********************* */ -/*! \file map_util_black.h - ** \verbatim - ** Top contributors (to current version): - ** Tim King, Andres Noetzli - ** This file is part of the CVC4 project. - ** Copyright (c) 2009-2020 by the authors listed in the file AUTHORS - ** in the top-level source directory and their institutional affiliations. - ** All rights reserved. See the file COPYING in the top-level source - ** directory for licensing information.\endverbatim - ** - ** \brief Black box testing of map utility functions. - ** - ** Black box testing of map utility functions. - **/ - -#include -#include -#include -#include -#include -#include - -#include "base/map_util.h" -#include "context/cdhashmap.h" -#include "context/cdhashset.h" -#include "context/cdinsert_hashmap.h" -#include "context/context.h" - -using CVC4::ContainsKey; -using CVC4::FindOrDie; -using CVC4::FindOrNull; -using CVC4::context::CDHashMap; -using CVC4::context::CDInsertHashMap; -using CVC4::context::Context; -using std::string; - -class MapUtilBlack : public CxxTest::TestSuite -{ - public: - void setUp() override {} - void tearDown() override {} - - // Returns a map containing {"key"->"value", "other"->"entry"}. - static const std::map& DefaultMap() - { - static const std::map static_stored_map{{"key", "value"}, - {"other", "entry"}}; - return static_stored_map; - } - - void testMap() - { - std::map map = DefaultMap(); - TS_ASSERT(ContainsKey(map, "key")); - TS_ASSERT(!ContainsKey(map, "non key")); - - TS_ASSERT(FindOrNull(map, "non key") == nullptr); - if (string* found_value = FindOrNull(map, "other")) - { - TS_ASSERT_EQUALS(*found_value, "entry"); - *found_value = "new value"; - } - TS_ASSERT_EQUALS(FindOrDie(map, "other"), "new value"); - } - - void testConstantMap() - { - const std::map map = DefaultMap(); - TS_ASSERT(ContainsKey(map, "key")); - TS_ASSERT(!ContainsKey(map, "non key")); - - if (const string* found_value = FindOrNull(map, "other")) - { - TS_ASSERT_EQUALS(*found_value, "entry"); - } - TS_ASSERT(FindOrNull(map, "non key") == nullptr); - TS_ASSERT_EQUALS(FindOrDie(map, "other"), "entry"); - // Cannot do death tests for FindOrDie. - } - - void testUnorderedMap() - { - std::unordered_map map(DefaultMap().begin(), - DefaultMap().end()); - TS_ASSERT(ContainsKey(map, "key")); - TS_ASSERT(!ContainsKey(map, "non key")); - - TS_ASSERT(FindOrNull(map, "non key") == nullptr); - if (string* found_value = FindOrNull(map, "other")) - { - TS_ASSERT_EQUALS(*found_value, "entry"); - *found_value = "new value"; - } - TS_ASSERT_EQUALS(FindOrDie(map, "other"), "new value"); - } - - void testConstUnorderedMap() - { - const std::unordered_map map(DefaultMap().begin(), - DefaultMap().end()); - TS_ASSERT(ContainsKey(map, "key")); - TS_ASSERT(!ContainsKey(map, "non key")); - - if (const string* found_value = FindOrNull(map, "other")) - { - TS_ASSERT_EQUALS(*found_value, "entry"); - } - TS_ASSERT(FindOrNull(map, "non key") == nullptr); - TS_ASSERT_EQUALS(FindOrDie(map, "other"), "entry"); - // Cannot do death tests for FindOrDie. - } - - void testSet() - { - std::set set{"entry", "other"}; - TS_ASSERT(ContainsKey(set, "entry")); - TS_ASSERT(!ContainsKey(set, "non member")); - - const std::set const_set{"entry", "other"}; - TS_ASSERT(ContainsKey(const_set, "entry")); - TS_ASSERT(!ContainsKey(const_set, "non member")); - } - - void testUnorderedSet() - { - std::unordered_set set{"entry", "other"}; - TS_ASSERT(ContainsKey(set, "entry")); - TS_ASSERT(!ContainsKey(set, "non member")); - - const std::unordered_set const_set{"entry", "other"}; - TS_ASSERT(ContainsKey(const_set, "entry")); - TS_ASSERT(!ContainsKey(const_set, "non member")); - } - - // For each pair in source, inserts mapping from key to value - // using insert into dest. - template - void InsertAll(const std::map& source, M* dest) - { - for (const auto& key_value : source) - { - dest->insert(key_value.first, key_value.second); - } - } - - void testCDHashMap() - { - Context context; - CDHashMap map(&context); - InsertAll(DefaultMap(), &map); - - TS_ASSERT(ContainsKey(map, "key")); - TS_ASSERT(!ContainsKey(map, "non key")); - - if (const string* found_value = FindOrNull(map, "other")) - { - TS_ASSERT_EQUALS(*found_value, "entry"); - } - TS_ASSERT(FindOrNull(map, "non key") == nullptr); - TS_ASSERT_EQUALS(FindOrDie(map, "other"), "entry"); - } - - void testConstCDHashMap() - { - Context context; - CDHashMap store(&context); - InsertAll(DefaultMap(), &store); - const auto& map = store; - - TS_ASSERT(ContainsKey(map, "key")); - TS_ASSERT(!ContainsKey(map, "non key")); - - if (const string* found_value = FindOrNull(map, "other")) - { - TS_ASSERT_EQUALS(*found_value, "entry"); - } - TS_ASSERT(FindOrNull(map, "non key") == nullptr); - TS_ASSERT_EQUALS(FindOrDie(map, "other"), "entry"); - } - - void testCDInsertHashMap() - { - Context context; - CDInsertHashMap map(&context); - InsertAll(DefaultMap(), &map); - - TS_ASSERT(ContainsKey(map, "key")); - TS_ASSERT(!ContainsKey(map, "non key")); - - if (const string* found_value = FindOrNull(map, "other")) - { - TS_ASSERT_EQUALS(*found_value, "entry"); - } - TS_ASSERT(FindOrNull(map, "non key") == nullptr); - TS_ASSERT_EQUALS(FindOrDie(map, "other"), "entry"); - } - - void testConstCDInsertHashMap() - { - Context context; - CDInsertHashMap store(&context); - InsertAll(DefaultMap(), &store); - const auto& map = store; - - TS_ASSERT(ContainsKey(map, "key")); - TS_ASSERT(!ContainsKey(map, "non key")); - if (const string* found_value = FindOrNull(map, "other")) - { - TS_ASSERT_EQUALS(*found_value, "entry"); - } - TS_ASSERT(FindOrNull(map, "non key") == nullptr); - TS_ASSERT_EQUALS(FindOrDie(map, "other"), "entry"); - } - -}; /* class MapUtilBlack */ diff --git a/test/unit/test.h b/test/unit/test.h new file mode 100644 index 000000000..1664ae70d --- /dev/null +++ b/test/unit/test.h @@ -0,0 +1,24 @@ +/********************* */ +/*! \file test.h + ** \verbatim + ** Top contributors (to current version): + ** Aina Niemetz + ** This file is part of the CVC4 project. + ** Copyright (c) 2009-2020 by the authors listed in the file AUTHORS + ** in the top-level source directory and their institutional affiliations. + ** All rights reserved. See the file COPYING in the top-level source + ** directory for licensing information.\endverbatim + ** + ** \brief Common header for API unit test. + **/ + +#ifndef CVC4__TEST__UNIT__TEST_H +#define CVC4__TEST__UNIT__TEST_H + +#include "gtest/gtest.h" + +class TestInternal : public ::testing::Test +{ +}; + +#endif