expiring_set_ut.cpp 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. #include <library/cpp/yt/containers/expiring_set.h>
  2. #include <library/cpp/testing/gtest/gtest.h>
  3. namespace NYT {
  4. namespace {
  5. ////////////////////////////////////////////////////////////////////////////////
  6. TInstant operator""_ts(unsigned long long seconds)
  7. {
  8. return TInstant::Zero() + TDuration::Seconds(seconds);
  9. }
  10. ////////////////////////////////////////////////////////////////////////////////
  11. TEST(TExpiringSetTest, Empty)
  12. {
  13. TExpiringSet<int> set;
  14. EXPECT_EQ(set.GetSize(), 0);
  15. }
  16. TEST(TExpiringSetTest, ExpireSingle)
  17. {
  18. TExpiringSet<int> set;
  19. set.SetTtl(TDuration::Seconds(2));
  20. set.Insert(0_ts, 1);
  21. EXPECT_EQ(set.GetSize(), 1);
  22. set.Expire(1_ts);
  23. EXPECT_EQ(set.GetSize(), 1);
  24. set.Expire(2_ts);
  25. EXPECT_EQ(set.GetSize(), 0);
  26. }
  27. TEST(TExpiringSetTest, ExpireBatch)
  28. {
  29. TExpiringSet<int> set;
  30. set.SetTtl(TDuration::Seconds(2));
  31. set.InsertMany(0_ts, std::vector<int>{1, 2, 3});
  32. EXPECT_EQ(set.GetSize(), 3);
  33. set.Expire(1_ts);
  34. EXPECT_EQ(set.GetSize(), 3);
  35. set.Expire(2_ts);
  36. EXPECT_EQ(set.GetSize(), 0);
  37. }
  38. TEST(TExpiringSetTest, Reinsert)
  39. {
  40. TExpiringSet<int> set;
  41. set.SetTtl(TDuration::Seconds(2));
  42. set.Insert(0_ts, 1);
  43. EXPECT_EQ(set.GetSize(), 1);
  44. set.Insert(1_ts, 1);
  45. EXPECT_EQ(set.GetSize(), 1);
  46. set.Expire(2_ts);
  47. EXPECT_EQ(set.GetSize(), 1);
  48. set.Expire(3_ts);
  49. EXPECT_EQ(set.GetSize(), 0);
  50. }
  51. TEST(TExpiringSetTest, Contains)
  52. {
  53. TExpiringSet<int> set;
  54. set.SetTtl(TDuration::Seconds(1));
  55. EXPECT_FALSE(set.Contains(1));
  56. set.Insert(0_ts, 1);
  57. EXPECT_TRUE(set.Contains(1));
  58. set.Expire(1_ts);
  59. EXPECT_FALSE(set.Contains(1));
  60. }
  61. TEST(TExpiringSetTest, Clear)
  62. {
  63. TExpiringSet<int> set;
  64. set.SetTtl(TDuration::Seconds(1));
  65. set.Insert(0_ts, 1);
  66. EXPECT_EQ(set.GetSize(), 1);
  67. EXPECT_TRUE(set.Contains(1));
  68. set.Clear();
  69. EXPECT_EQ(set.GetSize(), 0);
  70. EXPECT_FALSE(set.Contains(1));
  71. }
  72. TEST(TExpiringSetTest, RemoveBeforeExpire)
  73. {
  74. TExpiringSet<int> set;
  75. set.SetTtl(TDuration::Seconds(1));
  76. set.Insert(0_ts, 1);
  77. EXPECT_EQ(set.GetSize(), 1);
  78. EXPECT_TRUE(set.Contains(1));
  79. set.Remove(1);
  80. EXPECT_EQ(set.GetSize(), 0);
  81. EXPECT_FALSE(set.Contains(1));
  82. }
  83. TEST(TExpiringSetTest, RemoveAfterExpire)
  84. {
  85. TExpiringSet<int> set;
  86. set.SetTtl(TDuration::Seconds(1));
  87. set.Insert(0_ts, 1);
  88. set.Expire(2_ts);
  89. EXPECT_EQ(set.GetSize(), 0);
  90. EXPECT_FALSE(set.Contains(1));
  91. set.Remove(1);
  92. EXPECT_EQ(set.GetSize(), 0);
  93. EXPECT_FALSE(set.Contains(1));
  94. }
  95. ////////////////////////////////////////////////////////////////////////////////
  96. } // namespace
  97. } // namespace NYT