value_store_test.cpp 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
  2. // Exceptions. See /LICENSE for license information.
  3. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. #include "toolchain/base/value_store.h"
  5. #include <gmock/gmock.h>
  6. #include <gtest/gtest.h>
  7. #include "testing/base/test_raw_ostream.h"
  8. #include "toolchain/testing/yaml_test_helpers.h"
  9. namespace Carbon::Testing {
  10. namespace {
  11. using ::testing::ElementsAre;
  12. using ::testing::Eq;
  13. using ::testing::IsEmpty;
  14. using ::testing::Not;
  15. using ::testing::Pair;
  16. TEST(ValueStore, Int) {
  17. SharedValueStores value_stores;
  18. IntId id1 = value_stores.ints().Add(llvm::APInt(64, 1));
  19. IntId id2 = value_stores.ints().Add(llvm::APInt(64, 2));
  20. ASSERT_TRUE(id1.is_valid());
  21. ASSERT_TRUE(id2.is_valid());
  22. EXPECT_THAT(id1, Not(Eq(id2)));
  23. EXPECT_THAT(value_stores.ints().Get(id1), Eq(1));
  24. EXPECT_THAT(value_stores.ints().Get(id2), Eq(2));
  25. }
  26. TEST(ValueStore, Real) {
  27. Real real1{.mantissa = llvm::APInt(64, 1),
  28. .exponent = llvm::APInt(64, 11),
  29. .is_decimal = true};
  30. Real real2{.mantissa = llvm::APInt(64, 2),
  31. .exponent = llvm::APInt(64, 22),
  32. .is_decimal = false};
  33. SharedValueStores value_stores;
  34. RealId id1 = value_stores.reals().Add(real1);
  35. RealId id2 = value_stores.reals().Add(real2);
  36. ASSERT_TRUE(id1.is_valid());
  37. ASSERT_TRUE(id2.is_valid());
  38. EXPECT_THAT(id1, Not(Eq(id2)));
  39. const auto& real1_copy = value_stores.reals().Get(id1);
  40. EXPECT_THAT(real1.mantissa, Eq(real1_copy.mantissa));
  41. EXPECT_THAT(real1.exponent, Eq(real1_copy.exponent));
  42. EXPECT_THAT(real1.is_decimal, Eq(real1_copy.is_decimal));
  43. const auto& real2_copy = value_stores.reals().Get(id2);
  44. EXPECT_THAT(real2.mantissa, Eq(real2_copy.mantissa));
  45. EXPECT_THAT(real2.exponent, Eq(real2_copy.exponent));
  46. EXPECT_THAT(real2.is_decimal, Eq(real2_copy.is_decimal));
  47. }
  48. TEST(ValueStore, Float) {
  49. llvm::APFloat float1(1.0);
  50. llvm::APFloat float2(2.0);
  51. SharedValueStores value_stores;
  52. FloatId id1 = value_stores.floats().Add(float1);
  53. FloatId id2 = value_stores.floats().Add(float2);
  54. ASSERT_TRUE(id1.is_valid());
  55. ASSERT_TRUE(id2.is_valid());
  56. EXPECT_THAT(id1, Not(Eq(id2)));
  57. EXPECT_THAT(value_stores.floats().Get(id1).compare(float1),
  58. Eq(llvm::APFloatBase::cmpEqual));
  59. EXPECT_THAT(value_stores.floats().Get(id2).compare(float2),
  60. Eq(llvm::APFloatBase::cmpEqual));
  61. }
  62. TEST(ValueStore, String) {
  63. std::string a = "a";
  64. std::string b = "b";
  65. SharedValueStores value_stores;
  66. auto a_id = value_stores.identifiers().Add(a);
  67. auto b_id = value_stores.string_literal_values().Add(b);
  68. ASSERT_TRUE(a_id.is_valid());
  69. ASSERT_TRUE(b_id.is_valid());
  70. EXPECT_THAT(a_id.index, Not(Eq(b_id.index)));
  71. EXPECT_THAT(value_stores.identifiers().Get(a_id), Eq(a));
  72. EXPECT_THAT(value_stores.string_literal_values().Get(b_id), Eq(b));
  73. // Adding the same string again, even with a different Id type, should return
  74. // the same id.
  75. EXPECT_THAT(value_stores.string_literal_values().Add(a).index,
  76. Eq(a_id.index));
  77. EXPECT_THAT(value_stores.identifiers().Add(b).index, Eq(b_id.index));
  78. }
  79. auto MatchSharedValues(testing::Matcher<Yaml::MappingValue> ints,
  80. testing::Matcher<Yaml::MappingValue> reals,
  81. testing::Matcher<Yaml::MappingValue> strings) -> auto {
  82. return Yaml::IsYaml(Yaml::Sequence(ElementsAre(Yaml::Mapping(ElementsAre(Pair(
  83. "shared_values",
  84. Yaml::Mapping(ElementsAre(Pair("ints", Yaml::Mapping(ints)),
  85. Pair("reals", Yaml::Mapping(reals)),
  86. Pair("strings", Yaml::Mapping(strings))))))))));
  87. }
  88. TEST(ValueStore, PrintEmpty) {
  89. SharedValueStores value_stores;
  90. TestRawOstream out;
  91. value_stores.Print(out);
  92. EXPECT_THAT(Yaml::Value::FromText(out.TakeStr()),
  93. MatchSharedValues(IsEmpty(), IsEmpty(), IsEmpty()));
  94. }
  95. TEST(ValueStore, PrintVals) {
  96. SharedValueStores value_stores;
  97. llvm::APInt apint(64, 8, /*isSigned=*/true);
  98. value_stores.ints().Add(apint);
  99. value_stores.reals().Add(
  100. Real{.mantissa = apint, .exponent = apint, .is_decimal = true});
  101. value_stores.string_literal_values().Add("foo'\"baz");
  102. TestRawOstream out;
  103. value_stores.Print(out);
  104. EXPECT_THAT(
  105. Yaml::Value::FromText(out.TakeStr()),
  106. MatchSharedValues(ElementsAre(Pair("int0", Yaml::Scalar("8"))),
  107. ElementsAre(Pair("real0", Yaml::Scalar("8*10^8"))),
  108. ElementsAre(Pair("str0", Yaml::Scalar("foo'\"baz")))));
  109. }
  110. } // namespace
  111. } // namespace Carbon::Testing