/////////////////////////////////////////////////////////////////////////////// // // Copyright (c) 2015 Microsoft Corporation. All rights reserved. // // This code is licensed under the MIT License (MIT). // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // /////////////////////////////////////////////////////////////////////////////// #ifdef _MSC_VER // blanket turn off warnings from CppCoreCheck from catch // so people aren't annoyed by them when running the tool. #pragma warning(disable : 26440 26426) // from catch #endif #if __clang__ || __GNUC__ //disable warnings from gtest #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wundef" #endif // __clang__ || __GNUC__ #if __clang__ #pragma GCC diagnostic ignored "-Wglobal-constructors" #pragma GCC diagnostic ignored "-Wused-but-marked-unused" #pragma GCC diagnostic ignored "-Wcovered-switch-default" #endif // __clang__ #include #include // for narrow, finally, narrow_cast, narrowing_e... #include // for move #include // for reference_wrapper, _Bind_helper<>::type #include // for numeric_limits #include // for uint32_t, int32_t #include // for is_same using namespace gsl; namespace { static constexpr char deathstring[] = "Expected Death"; void f(int& i) { i += 1; } static int j = 0; void g() { j += 1; } } TEST(utils_tests, sanity_check_for_gsl_index_typedef) { static_assert(std::is_same::value, "gsl::index represents wrong arithmetic type"); } TEST(utils_tests, finally_lambda) { int i = 0; { auto _ = finally([&]() { f(i); }); EXPECT_TRUE(i == 0); } EXPECT_TRUE(i == 1); } TEST(utils_tests, finally_lambda_move) { int i = 0; { auto _1 = finally([&]() { f(i); }); { auto _2 = std::move(_1); EXPECT_TRUE(i == 0); } EXPECT_TRUE(i == 1); { auto _2 = std::move(_1); EXPECT_TRUE(i == 1); } EXPECT_TRUE(i == 1); } EXPECT_TRUE(i == 1); } TEST(utils_tests, finally_function_with_bind) { int i = 0; { auto _ = finally(std::bind(&f, std::ref(i))); EXPECT_TRUE(i == 0); } EXPECT_TRUE(i == 1); } TEST(utils_tests, finally_function_ptr) { j = 0; { auto _ = finally(&g); EXPECT_TRUE(j == 0); } EXPECT_TRUE(j == 1); } TEST(utils_tests, narrow_cast) { int n = 120; char c = narrow_cast(n); EXPECT_TRUE(c == 120); n = 300; unsigned char uc = narrow_cast(n); EXPECT_TRUE(uc == 44); } TEST(utils_tests, narrow) { std::set_terminate([] { std::cerr << "Expected Death. narrow"; std::abort(); }); int n = 120; const char c = narrow(n); EXPECT_TRUE(c == 120); n = 300; EXPECT_DEATH(narrow(n), deathstring); const auto int32_max = std::numeric_limits::max(); const auto int32_min = std::numeric_limits::min(); EXPECT_TRUE(narrow(int32_t(0)) == 0); EXPECT_TRUE(narrow(int32_t(1)) == 1); EXPECT_TRUE(narrow(int32_max) == static_cast(int32_max)); EXPECT_DEATH(narrow(int32_t(-1)), deathstring); EXPECT_DEATH(narrow(int32_min), deathstring); n = -42; EXPECT_DEATH(narrow(n), deathstring); #if GSL_CONSTEXPR_NARROW static_assert(narrow(120) == 120, "Fix GSL_CONSTEXPR_NARROW"); #endif } #if __clang__ || __GNUC__ #pragma GCC diagnostic pop #endif // __clang__ || __GNUC__