From bd3306aecb3a15e8967143b8cdbbccf2b1b19b74 Mon Sep 17 00:00:00 2001 From: patrick Date: Sat, 14 Jan 2017 19:55:43 +0000 Subject: Import LLVM 3.9.1 including clang and lld. --- gnu/llvm/unittests/ADT/ArrayRefTest.cpp | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'gnu/llvm/unittests/ADT/ArrayRefTest.cpp') diff --git a/gnu/llvm/unittests/ADT/ArrayRefTest.cpp b/gnu/llvm/unittests/ADT/ArrayRefTest.cpp index 6cbadd6bc22..b5b71f06f65 100644 --- a/gnu/llvm/unittests/ADT/ArrayRefTest.cpp +++ b/gnu/llvm/unittests/ADT/ArrayRefTest.cpp @@ -65,6 +65,21 @@ TEST(ArrayRefTest, DropBack) { ArrayRef AR1(TheNumbers); ArrayRef AR2(TheNumbers, AR1.size() - 1); EXPECT_TRUE(AR1.drop_back().equals(AR2)); + + // Check that drop_back accepts size_t-sized numbers. + ArrayRef AR3((const char *)0x10000, SIZE_MAX - 0x10000); + EXPECT_EQ(1U, AR3.drop_back(AR3.size() - 1).size()); +} + +TEST(ArrayRefTest, DropFront) { + static const int TheNumbers[] = {4, 8, 15, 16, 23, 42}; + ArrayRef AR1(TheNumbers); + ArrayRef AR2(&TheNumbers[2], AR1.size() - 2); + EXPECT_TRUE(AR1.drop_front(2).equals(AR2)); + + // Check that drop_front accepts size_t-sized numbers. + ArrayRef AR3((const char *)0x10000, SIZE_MAX - 0x10000); + EXPECT_EQ(1U, AR3.drop_front(AR3.size() - 1).size()); } TEST(ArrayRefTest, Equals) { @@ -94,6 +109,13 @@ TEST(ArrayRefTest, EmptyEquals) { EXPECT_TRUE(ArrayRef() == ArrayRef()); } +TEST(ArrayRefTest, Slice) { + // Check that slice accepts size_t-sized numbers. + ArrayRef AR((const char *)0x10000, SIZE_MAX - 0x10000); + EXPECT_EQ(1U, AR.slice(AR.size() - 1).size()); + EXPECT_EQ(AR.size() - 1, AR.slice(1, AR.size() - 1).size()); +} + TEST(ArrayRefTest, ConstConvert) { int buf[4]; for (int i = 0; i < 4; ++i) -- cgit v1.2.3-59-g8ed1b