[tor-commits] [tor/master] Use new mock functions in buffer/time_tracking test

nickm at torproject.org nickm at torproject.org
Thu Jul 21 11:05:00 UTC 2016


commit 50463524a931ea2a3cc5f2b850bf0d43bd4595c5
Author: Nick Mathewson <nickm at torproject.org>
Date:   Thu Jul 21 11:23:35 2016 +0200

    Use new mock functions in buffer/time_tracking test
---
 src/test/test_buffers.c | 18 ++++++++----------
 1 file changed, 8 insertions(+), 10 deletions(-)

diff --git a/src/test/test_buffers.c b/src/test/test_buffers.c
index 95584d5..20a1e34 100644
--- a/src/test/test_buffers.c
+++ b/src/test/test_buffers.c
@@ -511,26 +511,26 @@ static void
 test_buffer_time_tracking(void *arg)
 {
   buf_t *buf=NULL, *buf2=NULL;
-  struct timeval tv0;
   const time_t START = 1389288246;
-  const uint32_t START_MSEC = (uint32_t) ((uint64_t)START * 1000);
+  const uint64_t START_NSEC = ((uint64_t)START) * 1000000000;
   int i;
   char tmp[4096];
   (void)arg;
 
   crypto_rand(tmp, sizeof(tmp));
 
-  tv0.tv_sec = START;
-  tv0.tv_usec = 0;
+  monotime_enable_test_mocking();
 
   buf = buf_new_with_capacity(3000); /* rounds up to next power of 2. */
   tt_assert(buf);
 
+  monotime_coarse_set_mock_time_nsec(START_NSEC);
+  const uint32_t START_MSEC = (uint32_t)monotime_coarse_absolute_msec();
+
   /* Empty buffer means the timestamp is 0. */
   tt_int_op(0, OP_EQ, buf_get_oldest_chunk_timestamp(buf, START_MSEC));
   tt_int_op(0, OP_EQ, buf_get_oldest_chunk_timestamp(buf, START_MSEC+1000));
 
-  tor_gettimeofday_cache_set(&tv0);
   write_to_buf("ABCDEFG", 7, buf);
   tt_int_op(1000, OP_EQ, buf_get_oldest_chunk_timestamp(buf, START_MSEC+1000));
 
@@ -540,8 +540,7 @@ test_buffer_time_tracking(void *arg)
             buf_get_oldest_chunk_timestamp(buf2, START_MSEC+1234));
 
   /* Now add more bytes; enough to overflow the first chunk. */
-  tv0.tv_usec += 123 * 1000;
-  tor_gettimeofday_cache_set(&tv0);
+  monotime_coarse_set_mock_time_nsec(START_NSEC + 123 * (uint64_t)1000000);
   for (i = 0; i < 600; ++i)
     write_to_buf("ABCDEFG", 7, buf);
   tt_int_op(4207, OP_EQ, buf_datalen(buf));
@@ -562,9 +561,7 @@ test_buffer_time_tracking(void *arg)
 
   /* This time we'll be grabbing a chunk from the freelist, and making sure
      its time gets updated */
-  tv0.tv_sec += 5;
-  tv0.tv_usec = 617*1000;
-  tor_gettimeofday_cache_set(&tv0);
+  monotime_coarse_set_mock_time_nsec(START_NSEC + 5617 * (uint64_t)1000000);
   for (i = 0; i < 600; ++i)
     write_to_buf("ABCDEFG", 7, buf);
   tt_int_op(4307, OP_EQ, buf_datalen(buf));
@@ -578,6 +575,7 @@ test_buffer_time_tracking(void *arg)
  done:
   buf_free(buf);
   buf_free(buf2);
+  monotime_disable_test_mocking();
 }
 
 static void





More information about the tor-commits mailing list