mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-10 21:23:58 +01:00
Merge branch 'ticket29806_034_squashed' into ticket29806_035_squashed_merged
Copy and paste the vote=0 code from the old src/or/dirserv.c to the new src/feature/dirauth/bwauth.c.
This commit is contained in:
commit
3adb689fbc
7
changes/ticket29806
Normal file
7
changes/ticket29806
Normal file
@ -0,0 +1,7 @@
|
||||
o Minor features (bandwidth authority):
|
||||
- Make bandwidth authorities to ignore relays that are reported in the
|
||||
bandwidth file with the key-value "vote=0".
|
||||
This change allows to report the relays that were not measured due
|
||||
some failure and diagnose the reasons without the bandwidth being included in the
|
||||
bandwidth authorities vote.
|
||||
Closes ticket 29806.
|
@ -366,7 +366,13 @@ measured_bw_line_parse(measured_bw_line_t *out, const char *orig_line,
|
||||
}
|
||||
|
||||
do {
|
||||
if (strcmpstart(cp, "bw=") == 0) {
|
||||
// If the line contains vote=0, ignore it.
|
||||
if (strcmpstart(cp, "vote=0") == 0) {
|
||||
log_debug(LD_DIRSERV, "Ignoring bandwidth file line that contains "
|
||||
"vote=0: %s",escaped(orig_line));
|
||||
tor_free(line);
|
||||
return -1;
|
||||
} else if (strcmpstart(cp, "bw=") == 0) {
|
||||
int parse_ok = 0;
|
||||
char *endptr;
|
||||
if (got_bw) {
|
||||
|
@ -1562,6 +1562,19 @@ test_dir_measured_bw_kb(void *arg)
|
||||
/* check whether node_id can be at the end and something in the
|
||||
* in the middle of bw and node_id */
|
||||
"bw=1024 foo=bar node_id=$557365204145532d32353620696e73746561642e\n",
|
||||
|
||||
/* Test that a line with vote=1 will pass. */
|
||||
"node_id=$557365204145532d32353620696e73746561642e bw=1024 vote=1\n",
|
||||
/* Test that a line with unmeasured=1 will pass. */
|
||||
"node_id=$557365204145532d32353620696e73746561642e bw=1024 unmeasured=1\n",
|
||||
/* Test that a line with vote=1 and unmeasured=1 will pass. */
|
||||
"node_id=$557365204145532d32353620696e73746561642e bw=1024 vote=1"
|
||||
"unmeasured=1\n",
|
||||
/* Test that a line with unmeasured=0 will pass. */
|
||||
"node_id=$557365204145532d32353620696e73746561642e bw=1024 unmeasured=0\n",
|
||||
/* Test that a line with vote=1 and unmeasured=0 will pass. */
|
||||
"node_id=$557365204145532d32353620696e73746561642e bw=1024 vote=1"
|
||||
"unmeasured=0\n",
|
||||
"end"
|
||||
};
|
||||
const char *lines_fail[] = {
|
||||
@ -1595,6 +1608,12 @@ test_dir_measured_bw_kb(void *arg)
|
||||
"node_id=$55736520414552d32353620696e73746561642e bw=1024\n",
|
||||
"node_id=557365204145532d32353620696e73746561642e bw=1024\n",
|
||||
"node_id= $557365204145532d32353620696e73746561642e bw=0.23\n",
|
||||
|
||||
/* Test that a line with vote=0 will fail too, so that it is ignored. */
|
||||
"node_id=$557365204145532d32353620696e73746561642e bw=1024 vote=0\n",
|
||||
/* Test that a line with vote=0 will fail even if unmeasured=0. */
|
||||
"node_id=$557365204145532d32353620696e73746561642e bw=1024 vote=0 "
|
||||
"unmeasured=0\n",
|
||||
"end"
|
||||
};
|
||||
|
||||
@ -1979,6 +1998,44 @@ test_dir_dirserv_read_measured_bandwidths(void *arg)
|
||||
smartlist_free(bw_file_headers);
|
||||
tor_free(bw_file_headers_str);
|
||||
|
||||
/* Test v1.x.x bandwidth line with vote=0.
|
||||
* It will be ignored it and logged it at debug level. */
|
||||
const char *relay_lines_ignore =
|
||||
"node_id=$68A483E05A2ABDCA6DA5A3EF8DB5177638A27F80 bw=1024 vote=0\n"
|
||||
"node_id=$68A483E05A2ABDCA6DA5A3EF8DB5177638A27F80 bw=1024 vote=0"
|
||||
"unmeasured=1\n"
|
||||
"node_id=$68A483E05A2ABDCA6DA5A3EF8DB5177638A27F80 bw=1024 vote=0"
|
||||
"unmeasured=0\n";
|
||||
|
||||
/* Create the bandwidth file */
|
||||
tor_asprintf(&content, "%ld\n%s", (long)timestamp, relay_lines_ignore);
|
||||
write_str_to_file(fname, content, 0);
|
||||
tor_free(content);
|
||||
|
||||
/* Read the bandwidth file */
|
||||
setup_full_capture_of_logs(LOG_DEBUG);
|
||||
tt_int_op(0, OP_EQ, dirserv_read_measured_bandwidths(fname, NULL));
|
||||
expect_log_msg_containing("Ignoring bandwidth file line");
|
||||
teardown_capture_of_logs();
|
||||
|
||||
/* Test v1.x.x bandwidth line with "vote=1" or "unmeasured=1" or
|
||||
* "unmeasured=0".
|
||||
* They will not be ignored. */
|
||||
/* Create the bandwidth file */
|
||||
const char *relay_lines_vote =
|
||||
"node_id=$68A483E05A2ABDCA6DA5A3EF8DB5177638A27F80 bw=1024 vote=1\n"
|
||||
"node_id=$68A483E05A2ABDCA6DA5A3EF8DB5177638A27F80 bw=1024 unmeasured=0\n"
|
||||
"node_id=$68A483E05A2ABDCA6DA5A3EF8DB5177638A27F80 bw=1024 unmeasured=1\n";
|
||||
tor_asprintf(&content, "%ld\n%s", (long)timestamp, relay_lines_vote);
|
||||
write_str_to_file(fname, content, 0);
|
||||
tor_free(content);
|
||||
|
||||
/* Read the bandwidth file */
|
||||
setup_full_capture_of_logs(LOG_DEBUG);
|
||||
tt_int_op(0, OP_EQ, dirserv_read_measured_bandwidths(fname, NULL));
|
||||
expect_log_msg_not_containing("Ignoring bandwidth file line");
|
||||
teardown_capture_of_logs();
|
||||
|
||||
done:
|
||||
tor_free(fname);
|
||||
tor_free(header_lines_v100);
|
||||
|
Loading…
Reference in New Issue
Block a user