GSL/tests/utils_tests.cpp

131 lines
3.3 KiB
C++
Raw Normal View History

///////////////////////////////////////////////////////////////////////////////
//
// 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.
//
2015-08-20 21:09:14 -04:00
///////////////////////////////////////////////////////////////////////////////
2019-12-03 17:32:25 -05:00
#include <gtest/gtest.h>
#include <gsl/gsl_util> // for narrow, finally, narrow_cast, narrowing_e...
#include <algorithm> // for move
#include <functional> // for reference_wrapper, _Bind_helper<>::type
#include <limits> // for numeric_limits
#include <stdint.h> // for uint32_t, int32_t
#include <type_traits> // for is_same
#include <cstddef> // for std::ptrdiff_t
2015-08-20 21:09:14 -04:00
using namespace gsl;
2015-08-20 21:09:14 -04:00
2019-12-19 17:05:02 -05:00
namespace
{
static constexpr char deathstring[] = "Expected Death";
2019-12-03 17:32:25 -05:00
void f(int& i) { i += 1; }
static int j = 0;
void g() { j += 1; }
}
2019-12-03 17:32:25 -05:00
TEST(utils_tests, sanity_check_for_gsl_index_typedef)
{
2020-02-05 20:02:23 -05:00
static_assert(std::is_same<gsl::index, std::ptrdiff_t>::value,
"gsl::index represents wrong arithmetic type");
}
2019-12-03 17:32:25 -05:00
TEST(utils_tests, finally_lambda)
2015-08-20 21:09:14 -04:00
{
int i = 0;
{
auto _ = finally([&]() { f(i); });
EXPECT_TRUE(i == 0);
}
EXPECT_TRUE(i == 1);
}
2015-08-20 21:09:14 -04:00
2019-12-03 17:32:25 -05:00
TEST(utils_tests, finally_lambda_move)
{
int i = 0;
2015-08-20 21:09:14 -04:00
{
auto _1 = finally([&]() { f(i); });
2015-08-20 21:09:14 -04:00
{
auto _2 = std::move(_1);
EXPECT_TRUE(i == 0);
2015-08-20 21:09:14 -04:00
}
EXPECT_TRUE(i == 1);
{
auto _2 = std::move(_1);
EXPECT_TRUE(i == 1);
}
EXPECT_TRUE(i == 1);
}
EXPECT_TRUE(i == 1);
}
2019-12-03 17:32:25 -05:00
TEST(utils_tests, finally_function_with_bind)
{
int i = 0;
2015-08-20 21:09:14 -04:00
{
auto _ = finally(std::bind(&f, std::ref(i)));
EXPECT_TRUE(i == 0);
2015-08-20 21:09:14 -04:00
}
EXPECT_TRUE(i == 1);
}
2015-08-20 21:09:14 -04:00
2019-12-03 17:32:25 -05:00
TEST(utils_tests, finally_function_ptr)
{
j = 0;
2015-08-20 21:09:14 -04:00
{
auto _ = finally(&g);
EXPECT_TRUE(j == 0);
2015-08-20 21:09:14 -04:00
}
EXPECT_TRUE(j == 1);
}
2015-08-20 21:09:14 -04:00
2019-12-03 17:32:25 -05:00
TEST(utils_tests, narrow_cast)
{
int n = 120;
char c = narrow_cast<char>(n);
EXPECT_TRUE(c == 120);
2015-08-20 21:09:14 -04:00
n = 300;
unsigned char uc = narrow_cast<unsigned char>(n);
EXPECT_TRUE(uc == 44);
}
2015-08-20 21:09:14 -04:00
2019-12-03 17:32:25 -05:00
TEST(utils_tests, narrow)
2019-12-12 19:48:59 -05:00
{
int n = 120;
const char c = narrow<char>(n);
EXPECT_TRUE(c == 120);
2015-08-20 21:09:14 -04:00
n = 300;
EXPECT_DEATH(narrow<char>(n), deathstring);
const auto int32_max = std::numeric_limits<int32_t>::max();
const auto int32_min = std::numeric_limits<int32_t>::min();
2019-12-03 17:32:25 -05:00
EXPECT_TRUE(narrow<uint32_t>(int32_t(0)) == 0);
EXPECT_TRUE(narrow<uint32_t>(int32_t(1)) == 1);
EXPECT_TRUE(narrow<uint32_t>(int32_max) == static_cast<uint32_t>(int32_max));
EXPECT_THROW(narrow<uint32_t>(int32_t(-1)), narrowing_error);
EXPECT_THROW(narrow<uint32_t>(int32_min), narrowing_error);
n = -42;
EXPECT_THROW(narrow<unsigned>(n), narrowing_error);
2019-01-14 21:37:37 -05:00
#if GSL_CONSTEXPR_NARROW
static_assert(narrow<char>(120) == 120, "Fix GSL_CONSTEXPR_NARROW");
#endif
2015-08-20 21:09:14 -04:00
}