Hristo Hristov 267945b665
[libc++][NFC] Refactored equality comparisons tests for pair and expected (#145668)
Refactored `std::expected` and `std::pair` tests to use the
canonicalized names from `test_comparisions.h`, which are shared between
tests.

This was split from https://github.com/llvm/llvm-project/pull/139368 as
per comment
https://github.com/llvm/llvm-project/pull/139368#pullrequestreview-2916040573

Towards implementing [P2944R3: Comparisons for
reference_wrapper](https://github.com/llvm/llvm-project/issues/105424)

---------

Co-authored-by: Hristo Hristov <zingam@outlook.com>
Co-authored-by: Nikolas Klauser <nikolasklauser@berlin.de>
2025-06-29 16:34:49 +03:00

86 lines
2.8 KiB
C++

//===----------------------------------------------------------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
// UNSUPPORTED: c++03, c++11, c++14, c++17, c++20
// template<class T2, class E2> requires (!is_void_v<T2>)
// friend constexpr bool operator==(const expected& x, const expected<T2, E2>& y);
#include <cassert>
#include <concepts>
#include <expected>
#include <type_traits>
#include <utility>
#include "test_comparisons.h"
#include "test_macros.h"
// Test constraint
static_assert(!HasOperatorEqual<NonComparable, NonComparable>);
static_assert(HasOperatorEqual<std::expected<int, int>, std::expected<int, int>>);
static_assert(HasOperatorEqual<std::expected<int, int>, std::expected<short, short>>);
#if TEST_STD_VER >= 26
// https://wg21.link/P3379R0
static_assert(!HasOperatorEqual<std::expected<int, int>, std::expected<void, int>>);
static_assert(HasOperatorEqual<std::expected<int, int>, std::expected<int, int>>);
static_assert(!HasOperatorEqual<std::expected<NonComparable, int>, std::expected<NonComparable, int>>);
static_assert(!HasOperatorEqual<std::expected<int, NonComparable>, std::expected<int, NonComparable>>);
static_assert(!HasOperatorEqual<std::expected<NonComparable, int>, std::expected<int, NonComparable>>);
static_assert(!HasOperatorEqual<std::expected<int, NonComparable>, std::expected<NonComparable, int>>);
#else
// Note this is true because other overloads in expected<non-void> are unconstrained
static_assert(HasOperatorEqual<std::expected<void, int>, std::expected<int, int>>);
#endif
constexpr bool test() {
// x.has_value() && y.has_value()
{
const std::expected<int, int> e1(5);
const std::expected<int, int> e2(10);
const std::expected<int, int> e3(5);
assert(e1 != e2);
assert(e1 == e3);
}
// !x.has_value() && y.has_value()
{
const std::expected<int, int> e1(std::unexpect, 5);
const std::expected<int, int> e2(10);
const std::expected<int, int> e3(5);
assert(e1 != e2);
assert(e1 != e3);
}
// x.has_value() && !y.has_value()
{
const std::expected<int, int> e1(5);
const std::expected<int, int> e2(std::unexpect, 10);
const std::expected<int, int> e3(std::unexpect, 5);
assert(e1 != e2);
assert(e1 != e3);
}
// !x.has_value() && !y.has_value()
{
const std::expected<int, int> e1(std::unexpect, 5);
const std::expected<int, int> e2(std::unexpect, 10);
const std::expected<int, int> e3(std::unexpect, 5);
assert(e1 != e2);
assert(e1 == e3);
}
return true;
}
int main(int, char**) {
test();
static_assert(test());
return 0;
}