optional_test.cpp 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. // Copyright 2019 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // https://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #include "dap/optional.h"
  15. #include "gmock/gmock.h"
  16. #include "gtest/gtest.h"
  17. #include <string>
  18. TEST(Optional, EmptyConstruct) {
  19. dap::optional<std::string> opt;
  20. ASSERT_FALSE(opt);
  21. ASSERT_FALSE(opt.has_value());
  22. }
  23. TEST(Optional, ValueConstruct) {
  24. dap::optional<int> opt(10);
  25. ASSERT_TRUE(opt);
  26. ASSERT_TRUE(opt.has_value());
  27. ASSERT_EQ(opt.value(), 10);
  28. }
  29. TEST(Optional, CopyConstruct) {
  30. dap::optional<std::string> a("meow");
  31. dap::optional<std::string> b(a);
  32. ASSERT_EQ(a, b);
  33. ASSERT_EQ(a.value(), "meow");
  34. ASSERT_EQ(b.value(), "meow");
  35. }
  36. TEST(Optional, CopyCastConstruct) {
  37. dap::optional<int> a(10);
  38. dap::optional<uint16_t> b(a);
  39. ASSERT_EQ(a, b);
  40. ASSERT_EQ(b.value(), (uint16_t)10);
  41. }
  42. TEST(Optional, MoveConstruct) {
  43. dap::optional<std::string> a("meow");
  44. dap::optional<std::string> b(std::move(a));
  45. ASSERT_EQ(b.value(), "meow");
  46. }
  47. TEST(Optional, MoveCastConstruct) {
  48. dap::optional<int> a(10);
  49. dap::optional<uint16_t> b(std::move(a));
  50. ASSERT_EQ(b.value(), (uint16_t)10);
  51. }
  52. TEST(Optional, AssignValue) {
  53. dap::optional<std::string> a;
  54. std::string b = "meow";
  55. a = b;
  56. ASSERT_EQ(a.value(), "meow");
  57. ASSERT_EQ(b, "meow");
  58. }
  59. TEST(Optional, AssignOptional) {
  60. dap::optional<std::string> a;
  61. dap::optional<std::string> b("meow");
  62. a = b;
  63. ASSERT_EQ(a.value(), "meow");
  64. ASSERT_EQ(b.value(), "meow");
  65. }
  66. TEST(Optional, MoveAssignOptional) {
  67. dap::optional<std::string> a;
  68. dap::optional<std::string> b("meow");
  69. a = std::move(b);
  70. ASSERT_EQ(a.value(), "meow");
  71. }
  72. TEST(Optional, StarDeref) {
  73. dap::optional<std::string> a("meow");
  74. ASSERT_EQ(*a, "meow");
  75. }
  76. TEST(Optional, StarDerefConst) {
  77. const dap::optional<std::string> a("meow");
  78. ASSERT_EQ(*a, "meow");
  79. }
  80. TEST(Optional, ArrowDeref) {
  81. struct S {
  82. int i;
  83. };
  84. dap::optional<S> a(S{10});
  85. ASSERT_EQ(a->i, 10);
  86. }
  87. TEST(Optional, ArrowDerefConst) {
  88. struct S {
  89. int i;
  90. };
  91. const dap::optional<S> a(S{10});
  92. ASSERT_EQ(a->i, 10);
  93. }
  94. TEST(Optional, Value) {
  95. const dap::optional<std::string> a("meow");
  96. ASSERT_EQ(a.value(), "meow");
  97. }
  98. TEST(Optional, ValueDefault) {
  99. const dap::optional<std::string> a;
  100. const dap::optional<std::string> b("woof");
  101. ASSERT_EQ(a.value("meow"), "meow");
  102. ASSERT_EQ(b.value("meow"), "woof");
  103. }
  104. TEST(Optional, CompareLT) {
  105. ASSERT_FALSE(dap::optional<int>(5) < dap::optional<int>(3));
  106. ASSERT_FALSE(dap::optional<int>(5) < dap::optional<int>(5));
  107. ASSERT_TRUE(dap::optional<int>(5) < dap::optional<int>(10));
  108. ASSERT_TRUE(dap::optional<int>() < dap::optional<int>(10));
  109. ASSERT_FALSE(dap::optional<int>() < dap::optional<int>());
  110. }
  111. TEST(Optional, CompareLE) {
  112. ASSERT_FALSE(dap::optional<int>(5) <= dap::optional<int>(3));
  113. ASSERT_TRUE(dap::optional<int>(5) <= dap::optional<int>(5));
  114. ASSERT_TRUE(dap::optional<int>(5) <= dap::optional<int>(10));
  115. ASSERT_TRUE(dap::optional<int>() <= dap::optional<int>(10));
  116. ASSERT_TRUE(dap::optional<int>() <= dap::optional<int>());
  117. }
  118. TEST(Optional, CompareGT) {
  119. ASSERT_TRUE(dap::optional<int>(5) > dap::optional<int>(3));
  120. ASSERT_FALSE(dap::optional<int>(5) > dap::optional<int>(5));
  121. ASSERT_FALSE(dap::optional<int>(5) > dap::optional<int>(10));
  122. ASSERT_FALSE(dap::optional<int>() > dap::optional<int>(10));
  123. ASSERT_FALSE(dap::optional<int>() > dap::optional<int>());
  124. }
  125. TEST(Optional, CompareGE) {
  126. ASSERT_TRUE(dap::optional<int>(5) >= dap::optional<int>(3));
  127. ASSERT_TRUE(dap::optional<int>(5) >= dap::optional<int>(5));
  128. ASSERT_FALSE(dap::optional<int>(5) >= dap::optional<int>(10));
  129. ASSERT_FALSE(dap::optional<int>() >= dap::optional<int>(10));
  130. ASSERT_TRUE(dap::optional<int>() >= dap::optional<int>());
  131. }
  132. TEST(Optional, CompareEQ) {
  133. ASSERT_FALSE(dap::optional<int>(5) == dap::optional<int>(3));
  134. ASSERT_TRUE(dap::optional<int>(5) == dap::optional<int>(5));
  135. ASSERT_FALSE(dap::optional<int>(5) == dap::optional<int>(10));
  136. ASSERT_FALSE(dap::optional<int>() == dap::optional<int>(10));
  137. ASSERT_TRUE(dap::optional<int>() == dap::optional<int>());
  138. }
  139. TEST(Optional, CompareNEQ) {
  140. ASSERT_TRUE(dap::optional<int>(5) != dap::optional<int>(3));
  141. ASSERT_FALSE(dap::optional<int>(5) != dap::optional<int>(5));
  142. ASSERT_TRUE(dap::optional<int>(5) != dap::optional<int>(10));
  143. ASSERT_TRUE(dap::optional<int>() != dap::optional<int>(10));
  144. ASSERT_FALSE(dap::optional<int>() != dap::optional<int>());
  145. }