mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 15:36:09 +00:00

This is part of an effort to migrate from llvm::Optional to std::optional: https://discourse.llvm.org/t/deprecating-llvm-optional-x-hasvalue-getvalue-getvalueor/63716
123 lines
3.7 KiB
C++
123 lines
3.7 KiB
C++
//===- STLForwardCompatTest.cpp - Unit tests for STLForwardCompat ---------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/ADT/STLForwardCompat.h"
|
|
#include "MoveOnly.h"
|
|
#include "gtest/gtest.h"
|
|
|
|
namespace {
|
|
|
|
template <typename T>
|
|
class STLForwardCompatRemoveCVRefTest : public ::testing::Test {};
|
|
|
|
using STLForwardCompatRemoveCVRefTestTypes = ::testing::Types<
|
|
// clang-format off
|
|
std::pair<int, int>,
|
|
std::pair<int &, int>,
|
|
std::pair<const int, int>,
|
|
std::pair<volatile int, int>,
|
|
std::pair<const volatile int &, int>,
|
|
std::pair<int *, int *>,
|
|
std::pair<int *const, int *>,
|
|
std::pair<const int *, const int *>,
|
|
std::pair<int *&, int *>
|
|
// clang-format on
|
|
>;
|
|
|
|
TYPED_TEST_SUITE(STLForwardCompatRemoveCVRefTest,
|
|
STLForwardCompatRemoveCVRefTestTypes, );
|
|
|
|
TYPED_TEST(STLForwardCompatRemoveCVRefTest, RemoveCVRef) {
|
|
using From = typename TypeParam::first_type;
|
|
using To = typename TypeParam::second_type;
|
|
EXPECT_TRUE(
|
|
(std::is_same<typename llvm::remove_cvref<From>::type, To>::value));
|
|
}
|
|
|
|
TYPED_TEST(STLForwardCompatRemoveCVRefTest, RemoveCVRefT) {
|
|
using From = typename TypeParam::first_type;
|
|
EXPECT_TRUE((std::is_same<typename llvm::remove_cvref<From>::type,
|
|
llvm::remove_cvref_t<From>>::value));
|
|
}
|
|
|
|
TEST(TransformTest, TransformStd) {
|
|
std::optional<int> A;
|
|
|
|
std::optional<int> B = llvm::transformOptional(A, [&](int N) { return N + 1; });
|
|
EXPECT_FALSE(B.has_value());
|
|
|
|
A = 3;
|
|
std::optional<int> C = llvm::transformOptional(A, [&](int N) { return N + 1; });
|
|
EXPECT_TRUE(C.has_value());
|
|
EXPECT_EQ(4, *C);
|
|
}
|
|
|
|
TEST(TransformTest, MoveTransformStd) {
|
|
using llvm::MoveOnly;
|
|
|
|
std::optional<MoveOnly> A;
|
|
|
|
MoveOnly::ResetCounts();
|
|
std::optional<int> B = llvm::transformOptional(
|
|
std::move(A), [&](const MoveOnly &M) { return M.val + 2; });
|
|
EXPECT_FALSE(B.has_value());
|
|
EXPECT_EQ(0u, MoveOnly::MoveConstructions);
|
|
EXPECT_EQ(0u, MoveOnly::MoveAssignments);
|
|
EXPECT_EQ(0u, MoveOnly::Destructions);
|
|
|
|
A = MoveOnly(5);
|
|
MoveOnly::ResetCounts();
|
|
std::optional<int> C = llvm::transformOptional(
|
|
std::move(A), [&](const MoveOnly &M) { return M.val + 2; });
|
|
EXPECT_TRUE(C.has_value());
|
|
EXPECT_EQ(7, *C);
|
|
EXPECT_EQ(0u, MoveOnly::MoveConstructions);
|
|
EXPECT_EQ(0u, MoveOnly::MoveAssignments);
|
|
EXPECT_EQ(0u, MoveOnly::Destructions);
|
|
}
|
|
|
|
TEST(TransformTest, TransformLlvm) {
|
|
std::optional<int> A;
|
|
|
|
std::optional<int> B =
|
|
llvm::transformOptional(A, [&](int N) { return N + 1; });
|
|
EXPECT_FALSE(B.has_value());
|
|
|
|
A = 3;
|
|
std::optional<int> C =
|
|
llvm::transformOptional(A, [&](int N) { return N + 1; });
|
|
EXPECT_TRUE(C.has_value());
|
|
EXPECT_EQ(4, *C);
|
|
}
|
|
|
|
TEST(TransformTest, MoveTransformLlvm) {
|
|
using llvm::MoveOnly;
|
|
|
|
std::optional<MoveOnly> A;
|
|
|
|
MoveOnly::ResetCounts();
|
|
std::optional<int> B = llvm::transformOptional(
|
|
std::move(A), [&](const MoveOnly &M) { return M.val + 2; });
|
|
EXPECT_FALSE(B.has_value());
|
|
EXPECT_EQ(0u, MoveOnly::MoveConstructions);
|
|
EXPECT_EQ(0u, MoveOnly::MoveAssignments);
|
|
EXPECT_EQ(0u, MoveOnly::Destructions);
|
|
|
|
A = MoveOnly(5);
|
|
MoveOnly::ResetCounts();
|
|
std::optional<int> C = llvm::transformOptional(
|
|
std::move(A), [&](const MoveOnly &M) { return M.val + 2; });
|
|
EXPECT_TRUE(C.has_value());
|
|
EXPECT_EQ(7, *C);
|
|
EXPECT_EQ(0u, MoveOnly::MoveConstructions);
|
|
EXPECT_EQ(0u, MoveOnly::MoveAssignments);
|
|
EXPECT_EQ(0u, MoveOnly::Destructions);
|
|
}
|
|
|
|
} // namespace
|