[tor-commits] [tor/master] Added tests for bandwidth functions
nickm at torproject.org
nickm at torproject.org
Fri Jul 31 15:59:11 UTC 2020
commit a93c3d7a8d98f04f8e651543e4031bb18008aa74
Author: MrSquanchee <usuraj35 at gmail.com>
Date: Sat Apr 4 17:49:50 2020 +0530
Added tests for bandwidth functions
Added tests for
1. commit_max
2. advance_obs
3. add_obs
4. rep_hist_fill_bandwidth_history
5. rep_hist_get_bandwidth_lines
(Lightly edited by nickm to use new names from bwhist refactoring.)
Signed-off-by: Suraj Upadhyay <usuraj35 at gmail.com>
---
src/feature/stats/bwhist.c | 11 ++++-------
src/feature/stats/bwhist.h | 7 +++++++
src/test/test_stats.c | 21 ++++++++++++---------
3 files changed, 23 insertions(+), 16 deletions(-)
diff --git a/src/feature/stats/bwhist.c b/src/feature/stats/bwhist.c
index 48e33948da..7cbc5f60a6 100644
--- a/src/feature/stats/bwhist.c
+++ b/src/feature/stats/bwhist.c
@@ -74,7 +74,7 @@ advance_obs(bw_array_t *b)
/** Add <b>n</b> bytes to the number of bytes in <b>b</b> for second
* <b>when</b>. */
-static inline void
+STATIC void
add_obs(bw_array_t *b, time_t when, uint64_t n)
{
if (when < b->cur_obs_time)
@@ -95,7 +95,7 @@ add_obs(bw_array_t *b, time_t when, uint64_t n)
}
/** Allocate, initialize, and return a new bw_array. */
-static bw_array_t *
+STATIC bw_array_t *
bw_array_new(void)
{
bw_array_t *b;
@@ -107,11 +107,8 @@ bw_array_new(void)
return b;
}
-#define bw_array_free(val) \
- FREE_AND_NULL(bw_array_t, bw_array_free_, (val))
-
/** Free storage held by bandwidth array <b>b</b>. */
-static void
+STATIC void
bw_array_free_(bw_array_t *b)
{
if (!b) {
@@ -250,7 +247,7 @@ bwhist_bandwidth_assess,(void))
*
* It returns the number of bytes written.
*/
-static size_t
+STATIC size_t
bwhist_fill_bandwidth_history(char *buf, size_t len, const bw_array_t *b)
{
char *cp = buf;
diff --git a/src/feature/stats/bwhist.h b/src/feature/stats/bwhist.h
index d556f5a026..f88b951447 100644
--- a/src/feature/stats/bwhist.h
+++ b/src/feature/stats/bwhist.h
@@ -31,6 +31,13 @@ typedef struct bw_array_t bw_array_t;
STATIC uint64_t find_largest_max(bw_array_t *b);
STATIC void commit_max(bw_array_t *b);
STATIC void advance_obs(bw_array_t *b);
+STATIC bw_array_t *bw_array_new(void);
+STATIC void add_obs(bw_array_t *b, time_t when, uint64_t n);
+#define bw_array_free(val) \
+ FREE_AND_NULL(bw_array_t, bw_array_free_, (val))
+STATIC void bw_array_free_(bw_array_t *b);
+STATIC size_t bwhist_fill_bandwidth_history(char *buf, size_t len,
+ const bw_array_t *b);
#endif /* defined(REPHIST_PRIVATE) */
#ifdef TOR_UNIT_TESTS
diff --git a/src/test/test_stats.c b/src/test/test_stats.c
index 01981f602b..16dd2ca37c 100644
--- a/src/test/test_stats.c
+++ b/src/test/test_stats.c
@@ -31,6 +31,7 @@
#define MAINLOOP_PRIVATE
#define STATEFILE_PRIVATE
#define CONFIG_PRIVATE
+#define BWHIST_PRIVATE
#include "core/or/or.h"
#include "lib/err/backtrace.h"
@@ -43,6 +44,8 @@
#include "feature/stats/connstats.h"
#include "feature/stats/rephist.h"
#include "app/config/statefile.h"
+#include "feature/stats/bwhist.h"
+#include "feature/stats/bw_array_st.h"
/** Run unit tests for some stats code. */
static void
@@ -382,7 +385,7 @@ mock_get_options(void)
#define test_fill_bw(b, buf, rv, str, checkrv) STMT_BEGIN \
buf = tor_malloc_zero(MAX_HIST_VALUE_LEN); \
- rv = rep_hist_fill_bandwidth_history(buf, MAX_HIST_VALUE_LEN, b); \
+ rv = bwhist_fill_bandwidth_history(buf, MAX_HIST_VALUE_LEN, b); \
tt_str_op(buf, OP_EQ, str); \
tt_int_op(rv, OP_EQ, checkrv); \
tor_free(buf); \
@@ -399,7 +402,7 @@ test_fill_bandwidth_history(void *arg)
/* Day 1. */
set_test_case(b, 0, 0, 0, 0, 0, 0, 0);
buf = tor_malloc_zero(MAX_HIST_VALUE_LEN);
- rv = rep_hist_fill_bandwidth_history(buf, MAX_HIST_VALUE_LEN, b);
+ rv = bwhist_fill_bandwidth_history(buf, MAX_HIST_VALUE_LEN, b);
tt_int_op(rv, OP_EQ, 0);
tor_free(buf);
/* Day 2. */
@@ -434,14 +437,14 @@ test_fill_bandwidth_history(void *arg)
}
#define set_test_bw_lines(r, w, dr, dw, when) STMT_BEGIN \
- rep_hist_note_bytes_read(r, when); \
- rep_hist_note_bytes_written(w, when); \
- rep_hist_note_dir_bytes_read(dr, when); \
- rep_hist_note_dir_bytes_written(dw, when); \
+ bwhist_note_bytes_read(r, when, false); \
+ bwhist_note_bytes_written(w, when, false); \
+ bwhist_note_dir_bytes_read(dr, when); \
+ bwhist_note_dir_bytes_written(dw, when); \
STMT_END;
#define test_get_bw_lines(str, checkstr) STMT_BEGIN \
- str = rep_hist_get_bandwidth_lines(); \
+ str = bwhist_get_bandwidth_lines(); \
tt_str_op(str, OP_EQ, checkstr); \
tor_free(str); \
STMT_END;
@@ -455,7 +458,7 @@ test_get_bandwidth_lines(void *arg)
int len = (67+MAX_HIST_VALUE_LEN)*4;
checkstr = tor_malloc_zero(len);
time_t now = time(NULL);
- bw_arrays_init();
+ bwhist_init();
/* Day 1. */
now += 86400;
@@ -486,7 +489,7 @@ test_get_bandwidth_lines(void *arg)
test_get_bw_lines(str, checkstr);
done:
tor_free(checkstr);
- bw_arrays_free_all();
+ bwhist_free_all();
}
#define ENT(name) \
More information about the tor-commits
mailing list