time_util_test.cc 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. //
  2. // Copyright 2021 the gRPC authors.
  3. //
  4. // Licensed under the Apache License, Version 2.0 (the "License");
  5. // you may not use this file except in compliance with the License.
  6. // You may obtain a copy of the License at
  7. //
  8. // http://www.apache.org/licenses/LICENSE-2.0
  9. //
  10. // Unless required by applicable law or agreed to in writing, software
  11. // distributed under the License is distributed on an "AS IS" BASIS,
  12. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. // See the License for the specific language governing permissions and
  14. // limitations under the License.
  15. //
  16. #include "src/core/lib/gprpp/time_util.h"
  17. #include <stdio.h>
  18. #include <string.h>
  19. #include <gtest/gtest.h>
  20. #include "absl/time/time.h"
  21. #include <grpc/support/time.h>
  22. TEST(TimeUtilTest, ToGprTimeSpecFromAbslDurationWithRegularValues) {
  23. std::vector<int> times = {-10, -1, 0, 1, 10};
  24. for (int t : times) {
  25. EXPECT_EQ(0, gpr_time_cmp(gpr_time_from_nanos(t, GPR_TIMESPAN),
  26. grpc_core::ToGprTimeSpec(absl::Nanoseconds(t))));
  27. EXPECT_EQ(0, gpr_time_cmp(gpr_time_from_micros(t, GPR_TIMESPAN),
  28. grpc_core::ToGprTimeSpec(absl::Microseconds(t))));
  29. EXPECT_EQ(0, gpr_time_cmp(gpr_time_from_millis(t, GPR_TIMESPAN),
  30. grpc_core::ToGprTimeSpec(absl::Milliseconds(t))));
  31. EXPECT_EQ(0, gpr_time_cmp(gpr_time_from_seconds(t, GPR_TIMESPAN),
  32. grpc_core::ToGprTimeSpec(absl::Seconds(t))));
  33. EXPECT_EQ(0, gpr_time_cmp(gpr_time_from_minutes(t, GPR_TIMESPAN),
  34. grpc_core::ToGprTimeSpec(absl::Minutes(t))));
  35. EXPECT_EQ(0, gpr_time_cmp(gpr_time_from_hours(t, GPR_TIMESPAN),
  36. grpc_core::ToGprTimeSpec(absl::Hours(t))));
  37. }
  38. }
  39. TEST(TimeUtilTest, ToGprTimeSpecFromAbslDurationWithInfinites) {
  40. EXPECT_EQ(0,
  41. gpr_time_cmp(gpr_inf_past(GPR_TIMESPAN),
  42. grpc_core::ToGprTimeSpec(-absl::InfiniteDuration())));
  43. EXPECT_EQ(0, gpr_time_cmp(gpr_time_0(GPR_TIMESPAN),
  44. grpc_core::ToGprTimeSpec(absl::ZeroDuration())));
  45. }
  46. TEST(TimeUtilTest, ToGprTimeSpecFromAbslTimeWithRegularValues) {
  47. std::vector<int> times = {0, 10, 100000000};
  48. for (int t : times) {
  49. EXPECT_EQ(0,
  50. gpr_time_cmp(gpr_time_from_nanos(t, GPR_CLOCK_REALTIME),
  51. grpc_core::ToGprTimeSpec(absl::FromUnixNanos(t))));
  52. EXPECT_EQ(0,
  53. gpr_time_cmp(gpr_time_from_micros(t, GPR_CLOCK_REALTIME),
  54. grpc_core::ToGprTimeSpec(absl::FromUnixMicros(t))));
  55. EXPECT_EQ(0,
  56. gpr_time_cmp(gpr_time_from_millis(t, GPR_CLOCK_REALTIME),
  57. grpc_core::ToGprTimeSpec(absl::FromUnixMillis(t))));
  58. EXPECT_EQ(0,
  59. gpr_time_cmp(gpr_time_from_seconds(t, GPR_CLOCK_REALTIME),
  60. grpc_core::ToGprTimeSpec(absl::FromUnixSeconds(t))));
  61. }
  62. }
  63. TEST(TimeUtilTest, ToGprTimeSpecFromAbslTimeWithInfinites) {
  64. EXPECT_EQ(0, gpr_time_cmp(gpr_inf_future(GPR_CLOCK_REALTIME),
  65. grpc_core::ToGprTimeSpec(absl::InfiniteFuture())));
  66. EXPECT_EQ(0, gpr_time_cmp(gpr_inf_past(GPR_CLOCK_REALTIME),
  67. grpc_core::ToGprTimeSpec(absl::InfinitePast())));
  68. }
  69. TEST(TimeUtilTest, ToAbslDurationWithRegularValues) {
  70. std::vector<int> times = {-10, -1, 0, 1, 10};
  71. for (int t : times) {
  72. EXPECT_EQ(absl::Nanoseconds(t),
  73. grpc_core::ToAbslDuration(gpr_time_from_nanos(t, GPR_TIMESPAN)));
  74. EXPECT_EQ(absl::Microseconds(t),
  75. grpc_core::ToAbslDuration(gpr_time_from_micros(t, GPR_TIMESPAN)));
  76. EXPECT_EQ(absl::Milliseconds(t),
  77. grpc_core::ToAbslDuration(gpr_time_from_millis(t, GPR_TIMESPAN)));
  78. EXPECT_EQ(absl::Seconds(t), grpc_core::ToAbslDuration(
  79. gpr_time_from_seconds(t, GPR_TIMESPAN)));
  80. EXPECT_EQ(absl::Minutes(t), grpc_core::ToAbslDuration(
  81. gpr_time_from_minutes(t, GPR_TIMESPAN)));
  82. EXPECT_EQ(absl::Hours(t),
  83. grpc_core::ToAbslDuration(gpr_time_from_hours(t, GPR_TIMESPAN)));
  84. }
  85. }
  86. TEST(TimeUtilTest, ToAbslDurationWithInfinites) {
  87. EXPECT_EQ(absl::InfiniteDuration(),
  88. grpc_core::ToAbslDuration(gpr_inf_future(GPR_TIMESPAN)));
  89. EXPECT_EQ(-absl::InfiniteDuration(),
  90. grpc_core::ToAbslDuration(gpr_inf_past(GPR_TIMESPAN)));
  91. }
  92. TEST(TimeUtilTest, ToAbslTimeWithRegularValues) {
  93. std::vector<int> times = {0, 10, 100000000};
  94. for (int t : times) {
  95. EXPECT_EQ(absl::FromUnixNanos(t), grpc_core::ToAbslTime(gpr_time_from_nanos(
  96. t, GPR_CLOCK_REALTIME)));
  97. EXPECT_EQ(
  98. absl::FromUnixMicros(t),
  99. grpc_core::ToAbslTime(gpr_time_from_micros(t, GPR_CLOCK_REALTIME)));
  100. EXPECT_EQ(
  101. absl::FromUnixMillis(t),
  102. grpc_core::ToAbslTime(gpr_time_from_millis(t, GPR_CLOCK_REALTIME)));
  103. EXPECT_EQ(
  104. absl::FromUnixSeconds(t),
  105. grpc_core::ToAbslTime(gpr_time_from_seconds(t, GPR_CLOCK_REALTIME)));
  106. }
  107. }
  108. TEST(TimeUtilTest, ToAbslTimeWithInfinites) {
  109. EXPECT_EQ(absl::InfiniteFuture(),
  110. grpc_core::ToAbslTime(gpr_inf_future(GPR_CLOCK_REALTIME)));
  111. EXPECT_EQ(absl::InfinitePast(),
  112. grpc_core::ToAbslTime(gpr_inf_past(GPR_CLOCK_REALTIME)));
  113. EXPECT_EQ(absl::UnixEpoch(),
  114. grpc_core::ToAbslTime(gpr_time_0(GPR_CLOCK_REALTIME)));
  115. }
  116. int main(int argc, char** argv) {
  117. ::testing::InitGoogleTest(&argc, argv);
  118. int ret = RUN_ALL_TESTS();
  119. return ret;
  120. }