// Copyright 2014 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include #include "src/utils.h" #include "testing/gtest-support.h" namespace v8 { namespace internal { template class UtilsTest : public ::testing::Test {}; typedef ::testing::Types IntegerTypes; TYPED_TEST_CASE(UtilsTest, IntegerTypes); TYPED_TEST(UtilsTest, SaturateSub) { TypeParam min = std::numeric_limits::min(); TypeParam max = std::numeric_limits::max(); EXPECT_EQ(SaturateSub(min, 0), min); EXPECT_EQ(SaturateSub(max, 0), max); EXPECT_EQ(SaturateSub(max, min), max); EXPECT_EQ(SaturateSub(min, max), min); EXPECT_EQ(SaturateSub(min, max / 3), min); EXPECT_EQ(SaturateSub(min + 1, 2), min); if (std::numeric_limits::is_signed) { EXPECT_EQ(SaturateSub(min, min), static_cast(0)); EXPECT_EQ(SaturateSub(0, min), max); EXPECT_EQ(SaturateSub(max / 3, min), max); EXPECT_EQ(SaturateSub(max / 5, min), max); EXPECT_EQ(SaturateSub(min / 3, max), min); EXPECT_EQ(SaturateSub(min / 9, max), min); EXPECT_EQ(SaturateSub(max, min / 3), max); EXPECT_EQ(SaturateSub(min, max / 3), min); EXPECT_EQ(SaturateSub(max / 3 * 2, min / 2), max); EXPECT_EQ(SaturateSub(min / 3 * 2, max / 2), min); } else { EXPECT_EQ(SaturateSub(min, min), min); EXPECT_EQ(SaturateSub(0, min), min); EXPECT_EQ(SaturateSub(0, max), min); EXPECT_EQ(SaturateSub(max / 3, max), min); EXPECT_EQ(SaturateSub(max - 3, max), min); } TypeParam test_cases[] = {static_cast(min / 23), static_cast(max / 3), 63, static_cast(min / 6), static_cast(max / 55), static_cast(min / 2), static_cast(max / 2), 0, 1, 2, 3, 4, 42}; TRACED_FOREACH(TypeParam, x, test_cases) { TRACED_FOREACH(TypeParam, y, test_cases) { if (std::numeric_limits::is_signed) { EXPECT_EQ(SaturateSub(x, y), x - y); } else { EXPECT_EQ(SaturateSub(x, y), y > x ? min : x - y); } } } } TYPED_TEST(UtilsTest, SaturateAdd) { TypeParam min = std::numeric_limits::min(); TypeParam max = std::numeric_limits::max(); EXPECT_EQ(SaturateAdd(min, min), min); EXPECT_EQ(SaturateAdd(max, max), max); EXPECT_EQ(SaturateAdd(min, min / 3), min); EXPECT_EQ(SaturateAdd(max / 8 * 7, max / 3 * 2), max); EXPECT_EQ(SaturateAdd(min / 3 * 2, min / 8 * 7), min); EXPECT_EQ(SaturateAdd(max / 20 * 18, max / 25 * 18), max); EXPECT_EQ(SaturateAdd(min / 3 * 2, min / 3 * 2), min); EXPECT_EQ(SaturateAdd(max - 1, 2), max); EXPECT_EQ(SaturateAdd(max - 100, 101), max); TypeParam test_cases[] = {static_cast(min / 23), static_cast(max / 3), 63, static_cast(min / 6), static_cast(max / 55), static_cast(min / 2), static_cast(max / 2), 0, 1, 2, 3, 4, 42}; TRACED_FOREACH(TypeParam, x, test_cases) { TRACED_FOREACH(TypeParam, y, test_cases) { EXPECT_EQ(SaturateAdd(x, y), x + y); } } } } // namespace internal } // namespace v8