| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
- // Exceptions. See /LICENSE for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- #include "toolchain/base/value_store.h"
- #include <gmock/gmock.h>
- #include <gtest/gtest.h>
- #include "toolchain/base/value_ids.h"
- namespace Carbon::Testing {
- namespace {
- using ::testing::Eq;
- using ::testing::Not;
- TEST(ValueStore, Real) {
- Real real1{.mantissa = llvm::APInt(64, 1),
- .exponent = llvm::APInt(64, 11),
- .is_decimal = true};
- Real real2{.mantissa = llvm::APInt(64, 2),
- .exponent = llvm::APInt(64, 22),
- .is_decimal = false};
- ValueStore<RealId> reals;
- RealId id1 = reals.Add(real1);
- RealId id2 = reals.Add(real2);
- ASSERT_TRUE(id1.has_value());
- ASSERT_TRUE(id2.has_value());
- EXPECT_THAT(id1, Not(Eq(id2)));
- const auto& real1_copy = reals.Get(id1);
- EXPECT_THAT(real1.mantissa, Eq(real1_copy.mantissa));
- EXPECT_THAT(real1.exponent, Eq(real1_copy.exponent));
- EXPECT_THAT(real1.is_decimal, Eq(real1_copy.is_decimal));
- const auto& real2_copy = reals.Get(id2);
- EXPECT_THAT(real2.mantissa, Eq(real2_copy.mantissa));
- EXPECT_THAT(real2.exponent, Eq(real2_copy.exponent));
- EXPECT_THAT(real2.is_decimal, Eq(real2_copy.is_decimal));
- }
- TEST(ValueStore, Float) {
- llvm::APFloat float1(1.0);
- llvm::APFloat float2(2.0);
- CanonicalValueStore<FloatId> floats;
- FloatId id1 = floats.Add(float1);
- FloatId id2 = floats.Add(float2);
- ASSERT_TRUE(id1.has_value());
- ASSERT_TRUE(id2.has_value());
- EXPECT_THAT(id1, Not(Eq(id2)));
- EXPECT_THAT(floats.Get(id1).compare(float1), Eq(llvm::APFloatBase::cmpEqual));
- EXPECT_THAT(floats.Get(id2).compare(float2), Eq(llvm::APFloatBase::cmpEqual));
- }
- TEST(ValueStore, Identifiers) {
- std::string a = "a";
- std::string b = "b";
- CanonicalValueStore<IdentifierId> identifiers;
- // Make sure reserve works, we use it with identifiers.
- identifiers.Reserve(100);
- auto a_id = identifiers.Add(a);
- auto b_id = identifiers.Add(b);
- ASSERT_TRUE(a_id.has_value());
- ASSERT_TRUE(b_id.has_value());
- EXPECT_THAT(a_id, Not(Eq(b_id)));
- EXPECT_THAT(identifiers.Get(a_id), Eq(a));
- EXPECT_THAT(identifiers.Get(b_id), Eq(b));
- EXPECT_THAT(identifiers.Lookup(a), Eq(a_id));
- EXPECT_THAT(identifiers.Lookup("c"), Eq(IdentifierId::None));
- }
- TEST(ValueStore, StringLiterals) {
- std::string a = "a";
- std::string b = "b";
- CanonicalValueStore<StringLiteralValueId> string_literals;
- auto a_id = string_literals.Add(a);
- auto b_id = string_literals.Add(b);
- ASSERT_TRUE(a_id.has_value());
- ASSERT_TRUE(b_id.has_value());
- EXPECT_THAT(a_id, Not(Eq(b_id)));
- EXPECT_THAT(string_literals.Get(a_id), Eq(a));
- EXPECT_THAT(string_literals.Get(b_id), Eq(b));
- EXPECT_THAT(string_literals.Lookup(a), Eq(a_id));
- EXPECT_THAT(string_literals.Lookup("c"), Eq(StringLiteralValueId::None));
- }
- } // namespace
- } // namespace Carbon::Testing
|