[libc++][test] Fix iterator assertion in span.cons/deduct.pass.cpp

Two tests in span.cons/deduct.pass.cpp accidentally check whether the
iterator range from member begin and member end are equivalent to the
ones from free begin and free end. This is obviously true and not
intended. Correct the intent by comparing the size/data from the span
with the source input.

While in the neighborhood, add test for const int arr[N], remove extraneous
type aliases, unused <type_traits> header, and the
disable_missing_braces_warning.h include.

Reviewed By: Quuxplusone, ldionne, #libc

Differential Revision: https://reviews.llvm.org/D109668
This commit is contained in:
Joe Loser 2021-09-21 22:45:32 -04:00
parent 4c2ee57148
commit bc4a23811b
No known key found for this signature in database
GPG Key ID: 1CDBEBC050EA230D
1 changed files with 24 additions and 23 deletions

View File

@ -28,60 +28,61 @@
#include <span> #include <span>
#include <algorithm>
#include <array> #include <array>
#include <cassert> #include <cassert>
#include <memory>
#include <string> #include <string>
#include <type_traits>
#include "test_macros.h" #include "test_macros.h"
// std::array is explicitly allowed to be initialized with A a = { init-list };.
// Disable the missing braces warning for this reason.
#include "disable_missing_braces_warning.h"
int main(int, char**) int main(int, char**)
{ {
{ {
int arr[] = {1,2,3}; int arr[] = {1,2,3};
std::span s{arr}; std::span s{arr};
using S = decltype(s); ASSERT_SAME_TYPE(decltype(s), std::span<int, 3>);
ASSERT_SAME_TYPE(S, std::span<int, 3>); assert(s.size() == std::size(arr));
assert((std::equal(std::begin(arr), std::end(arr), s.begin(), s.end()))); assert(s.data() == std::data(arr));
}
{
const int arr[] = {1,2,3};
std::span s{arr};
ASSERT_SAME_TYPE(decltype(s), std::span<const int, 3>);
assert(s.size() == std::size(arr));
assert(s.data() == std::data(arr));
} }
{ {
std::array<double, 4> arr = {1.0, 2.0, 3.0, 4.0}; std::array<double, 4> arr = {1.0, 2.0, 3.0, 4.0};
std::span s{arr}; std::span s{arr};
using S = decltype(s); ASSERT_SAME_TYPE(decltype(s), std::span<double, 4>);
ASSERT_SAME_TYPE(S, std::span<double, 4>); assert(s.size() == arr.size());
assert((std::equal(std::begin(arr), std::end(arr), s.begin(), s.end()))); assert(s.data() == arr.data());
} }
{ {
const std::array<long, 5> arr = {4, 5, 6, 7, 8}; const std::array<long, 5> arr = {4, 5, 6, 7, 8};
std::span s{arr}; std::span s{arr};
using S = decltype(s); ASSERT_SAME_TYPE(decltype(s), std::span<const long, 5>);
ASSERT_SAME_TYPE(S, std::span<const long, 5>); assert(s.size() == arr.size());
assert((std::equal(std::begin(arr), std::end(arr), s.begin(), s.end()))); assert(s.data() == arr.data());
} }
{ {
std::string str{"ABCDE"}; std::string str{"ABCDE"};
std::span s{str}; std::span s{str};
using S = decltype(s); ASSERT_SAME_TYPE(decltype(s), std::span<char>);
ASSERT_SAME_TYPE(S, std::span<char>); assert(s.size() == str.size());
assert((size_t)s.size() == str.size()); assert(s.data() == str.data());
assert((std::equal(s.begin(), s.end(), std::begin(s), std::end(s))));
} }
{ {
const std::string str{"QWERTYUIOP"}; const std::string str{"QWERTYUIOP"};
std::span s{str}; std::span s{str};
using S = decltype(s); ASSERT_SAME_TYPE(decltype(s), std::span<const char>);
ASSERT_SAME_TYPE(S, std::span<const char>); assert(s.size() == str.size());
assert((size_t)s.size() == str.size()); assert(s.data() == str.data());
assert((std::equal(s.begin(), s.end(), std::begin(s), std::end(s))));
} }
return 0; return 0;