run.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. #include <ccan/time/time.h>
  2. #include <ccan/time/time.c>
  3. #include <ccan/tap/tap.h>
  4. int main(void)
  5. {
  6. struct timeabs t1, t2;
  7. struct timerel t3, t4, zero = { { 0, 0 } };
  8. plan_tests(66);
  9. /* Test time_now */
  10. t1 = time_now();
  11. t2 = time_now();
  12. /* Test time_between. */
  13. t3 = time_between(t2, t1);
  14. ok1(t3.ts.tv_sec > 0 || t3.ts.tv_nsec >= 0);
  15. t3 = time_between(t2, t2);
  16. ok1(t3.ts.tv_sec == 0 && t3.ts.tv_nsec == 0);
  17. t3 = time_between(t1, t1);
  18. ok1(t3.ts.tv_sec == 0 && t3.ts.tv_nsec == 0);
  19. /* Test timeabs_eq / timerel_eq */
  20. ok1(timeabs_eq(t1, t1));
  21. ok1(timeabs_eq(t2, t2));
  22. t3.ts.tv_sec = 0;
  23. t3.ts.tv_nsec = 1;
  24. ok1(!timerel_eq(t3, zero));
  25. ok1(!timerel_eq(t3, zero));
  26. /* Make sure t2 > t1. */
  27. t2 = timeabs_add(t2, t3);
  28. /* Test time_after and time_before. */
  29. ok1(!timeabs_eq(t1, t2));
  30. ok1(!time_after(t1, t2));
  31. ok1(time_before(t1, t2));
  32. ok1(time_after(t2, t1));
  33. ok1(!time_before(t2, t1));
  34. t3.ts.tv_sec = 0;
  35. t3.ts.tv_nsec = 999999999;
  36. t2 = timeabs_add(t2, t3);
  37. ok1(!timeabs_eq(t1, t2));
  38. ok1(!time_after(t1, t2));
  39. ok1(time_before(t1, t2));
  40. ok1(time_after(t2, t1));
  41. ok1(!time_before(t2, t1));
  42. /* Test time_less and time_greater. */
  43. ok1(time_less(zero, t3));
  44. ok1(!time_greater(zero, t3));
  45. ok1(!time_less(t3, zero));
  46. ok1(time_greater(t3, zero));
  47. /* Test time_sub */
  48. t3 = time_sub(t3, t3);
  49. ok1(timerel_eq(t3, zero));
  50. /* Test time_between */
  51. t3 = time_between(t2, t2);
  52. ok1(timerel_eq(t3, zero));
  53. t3.ts.tv_sec = 0;
  54. t3.ts.tv_nsec = 999999999;
  55. t1 = timeabs_add(t2, t3);
  56. t3 = time_between(t1, t2);
  57. ok1(t3.ts.tv_sec == 0 && t3.ts.tv_nsec == 999999999);
  58. /* time_from_sec / time_to_sec */
  59. t3 = time_from_sec(500);
  60. ok1(t3.ts.tv_sec == 500);
  61. ok1(t3.ts.tv_nsec == 0);
  62. ok1(time_to_sec(t3) == 500);
  63. /* time_from_msec / time_to_msec */
  64. t3 = time_from_msec(500);
  65. ok1(t3.ts.tv_sec == 0);
  66. ok1(t3.ts.tv_nsec == 500000000);
  67. ok1(time_to_msec(t3) == 500);
  68. t3 = time_from_msec(1000);
  69. ok1(t3.ts.tv_sec == 1);
  70. ok1(t3.ts.tv_nsec == 0);
  71. ok1(time_to_msec(t3) == 1000);
  72. t3 = time_from_msec(1500);
  73. ok1(t3.ts.tv_sec == 1);
  74. ok1(t3.ts.tv_nsec == 500000000);
  75. ok1(time_to_msec(t3) == 1500);
  76. /* time_from_usec */
  77. t3 = time_from_usec(500000);
  78. ok1(t3.ts.tv_sec == 0);
  79. ok1(t3.ts.tv_nsec == 500000000);
  80. ok1(time_to_usec(t3) == 500000);
  81. t3 = time_from_usec(1000000);
  82. ok1(t3.ts.tv_sec == 1);
  83. ok1(t3.ts.tv_nsec == 0);
  84. ok1(time_to_usec(t3) == 1000000);
  85. t3 = time_from_usec(1500000);
  86. ok1(t3.ts.tv_sec == 1);
  87. ok1(t3.ts.tv_nsec == 500000000);
  88. ok1(time_to_usec(t3) == 1500000);
  89. /* time_from_nsec */
  90. t3 = time_from_nsec(500000000);
  91. ok1(t3.ts.tv_sec == 0);
  92. ok1(t3.ts.tv_nsec == 500000000);
  93. ok1(time_to_nsec(t3) == 500000000);
  94. t3 = time_from_nsec(1000000000);
  95. ok1(t3.ts.tv_sec == 1);
  96. ok1(t3.ts.tv_nsec == 0);
  97. ok1(time_to_nsec(t3) == 1000000000);
  98. t3 = time_from_nsec(1500000000);
  99. ok1(t3.ts.tv_sec == 1);
  100. ok1(t3.ts.tv_nsec == 500000000);
  101. ok1(time_to_nsec(t3) == 1500000000);
  102. /* Test wrapunder */
  103. t1 = timeabs_sub(timeabs_sub(t2, time_from_msec(500)), time_from_msec(500));
  104. ok1(t1.ts.tv_sec == t2.ts.tv_sec - 1);
  105. ok1(t1.ts.tv_nsec == t2.ts.tv_nsec);
  106. /* time_divide and time_multiply */
  107. t4.ts.tv_nsec = 100;
  108. t4.ts.tv_sec = 100;
  109. t3 = time_divide(t4, 2);
  110. ok1(t3.ts.tv_sec == 50);
  111. ok1(t3.ts.tv_nsec == 50);
  112. t3 = time_divide(t4, 100);
  113. ok1(t3.ts.tv_sec == 1);
  114. ok1(t3.ts.tv_nsec == 1);
  115. t3 = time_multiply(t3, 100);
  116. ok1(timerel_eq(t3, t4));
  117. t3 = time_divide(t4, 200);
  118. ok1(t3.ts.tv_sec == 0);
  119. ok1(t3.ts.tv_nsec == 500000000);
  120. /* Divide by huge number. */
  121. t4.ts.tv_sec = (1U << 31) - 1;
  122. t4.ts.tv_nsec = 999999999;
  123. t3 = time_divide(t4, 1 << 30);
  124. /* Allow us to round either way. */
  125. ok1((t3.ts.tv_sec == 2 && t3.ts.tv_nsec == 0)
  126. || (t3.ts.tv_sec == 1 && t3.ts.tv_nsec == 999999999));
  127. /* Multiply by huge number. */
  128. t4.ts.tv_sec = 0;
  129. t4.ts.tv_nsec = 1;
  130. t3 = time_multiply(t4, 1UL << 31);
  131. ok1(t3.ts.tv_sec == 2);
  132. ok1(t3.ts.tv_nsec == 147483648);
  133. return exit_status();
  134. }