91 lines
3.0 KiB
C++
91 lines
3.0 KiB
C++
|
|
// Copyright 2020 The Chromium Authors
|
||
|
|
// Use of this source code is governed by a BSD-style license that can be
|
||
|
|
// found in the LICENSE file.
|
||
|
|
|
||
|
|
#include "base/containers/fixed_flat_map.h"
|
||
|
|
|
||
|
|
#include <string>
|
||
|
|
|
||
|
|
#include "base/ranges/algorithm.h"
|
||
|
|
#include "base/strings/string_piece.h"
|
||
|
|
#include "base/test/gtest_util.h"
|
||
|
|
#include "testing/gmock/include/gmock/gmock.h"
|
||
|
|
#include "testing/gtest/include/gtest/gtest.h"
|
||
|
|
|
||
|
|
using ::testing::ElementsAre;
|
||
|
|
using ::testing::Pair;
|
||
|
|
|
||
|
|
namespace base {
|
||
|
|
|
||
|
|
namespace {
|
||
|
|
|
||
|
|
struct Unsortable {
|
||
|
|
int value;
|
||
|
|
};
|
||
|
|
|
||
|
|
bool operator==(const Unsortable& lhs, const Unsortable& rhs) {
|
||
|
|
return lhs.value == rhs.value;
|
||
|
|
}
|
||
|
|
|
||
|
|
bool operator<(const Unsortable& lhs, const Unsortable& rhs) = delete;
|
||
|
|
bool operator<=(const Unsortable& lhs, const Unsortable& rhs) = delete;
|
||
|
|
bool operator>(const Unsortable& lhs, const Unsortable& rhs) = delete;
|
||
|
|
bool operator>=(const Unsortable& lhs, const Unsortable& rhs) = delete;
|
||
|
|
|
||
|
|
} // namespace
|
||
|
|
|
||
|
|
TEST(FixedFlatMapTest, MakeFixedFlatMap_SortedInput) {
|
||
|
|
constexpr auto kSquares =
|
||
|
|
MakeFixedFlatMap<int, int>({{1, 1}, {2, 4}, {3, 9}, {4, 16}});
|
||
|
|
static_assert(ranges::is_sorted(kSquares), "Error: Map is not sorted.");
|
||
|
|
static_assert(ranges::adjacent_find(kSquares) == kSquares.end(),
|
||
|
|
"Error: Map contains repeated elements.");
|
||
|
|
EXPECT_THAT(kSquares,
|
||
|
|
ElementsAre(Pair(1, 1), Pair(2, 4), Pair(3, 9), Pair(4, 16)));
|
||
|
|
}
|
||
|
|
|
||
|
|
TEST(FixedFlatMapTest, MakeFixedFlatMap_UnsortedInput) {
|
||
|
|
constexpr auto kMap =
|
||
|
|
MakeFixedFlatMap<StringPiece, int>({{"foo", 1}, {"bar", 2}, {"baz", 3}});
|
||
|
|
static_assert(ranges::is_sorted(kMap), "Error: Map is not sorted.");
|
||
|
|
static_assert(ranges::adjacent_find(kMap) == kMap.end(),
|
||
|
|
"Error: Map contains repeated elements.");
|
||
|
|
EXPECT_THAT(kMap,
|
||
|
|
ElementsAre(Pair("bar", 2), Pair("baz", 3), Pair("foo", 1)));
|
||
|
|
}
|
||
|
|
|
||
|
|
// Tests that even though the keys are immutable, the values of a non-const map
|
||
|
|
// can still be changed.
|
||
|
|
TEST(FixedFlatMapTest, MutableValues) {
|
||
|
|
auto map = MakeFixedFlatMap<std::string, int>({{"bar", 1}, {"foo", 2}});
|
||
|
|
EXPECT_THAT(map, ElementsAre(Pair("bar", 1), Pair("foo", 2)));
|
||
|
|
map.at("bar") = 2;
|
||
|
|
EXPECT_THAT(map, ElementsAre(Pair("bar", 2), Pair("foo", 2)));
|
||
|
|
}
|
||
|
|
|
||
|
|
// Tests that even though the values are unsortable the built in sort still
|
||
|
|
// correctly orders the keys.
|
||
|
|
TEST(FixedFlatMapTest, UnsortableValues) {
|
||
|
|
using PairType = std::pair<int, Unsortable>;
|
||
|
|
|
||
|
|
constexpr auto kSquares = MakeFixedFlatMap<int, Unsortable>({
|
||
|
|
{4, {16}},
|
||
|
|
{3, {9}},
|
||
|
|
{2, {4}},
|
||
|
|
{1, {1}},
|
||
|
|
});
|
||
|
|
EXPECT_THAT(kSquares, ElementsAre(PairType(1, {1}), PairType(2, {4}),
|
||
|
|
PairType(3, {9}), PairType(4, {16})));
|
||
|
|
}
|
||
|
|
|
||
|
|
// Verifies that passing repeated keys to MakeFixedFlatMap results in a CHECK
|
||
|
|
// failure.
|
||
|
|
TEST(FixedFlatMapTest, RepeatedKeys) {
|
||
|
|
// Note: The extra pair of parens is needed to escape the nested commas in the
|
||
|
|
// type list.
|
||
|
|
EXPECT_CHECK_DEATH((MakeFixedFlatMap<StringPiece, int>(
|
||
|
|
{{"foo", 1}, {"bar", 2}, {"foo", 3}})));
|
||
|
|
}
|
||
|
|
|
||
|
|
} // namespace base
|