aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/libutil/upstream.c13
-rw-r--r--test/rspamd_upstream_test.c32
2 files changed, 40 insertions, 5 deletions
diff --git a/src/libutil/upstream.c b/src/libutil/upstream.c
index 010b2d0ff..7bec3729a 100644
--- a/src/libutil/upstream.c
+++ b/src/libutil/upstream.c
@@ -260,7 +260,6 @@ rspamd_upstream_fail (struct upstream *up)
rspamd_mutex_lock (up->lock);
if (g_atomic_int_compare_and_exchange (&up->errors, 0, 1)) {
gettimeofday (&up->tv, NULL);
- up->errors ++;
}
else {
g_atomic_int_inc (&up->errors);
@@ -270,9 +269,15 @@ rspamd_upstream_fail (struct upstream *up)
msec_last = tv_to_msec (&up->tv) / 1000.;
msec_cur = tv_to_msec (&tv) / 1000.;
- if (msec_cur > msec_last) {
- error_rate = ((gdouble)up->errors) / (msec_cur - msec_last);
- max_error_rate = (gdouble)default_max_errors / (gdouble)default_error_time;
+ if (msec_cur >= msec_last) {
+ if (msec_cur > msec_last) {
+ error_rate = ((gdouble)up->errors) / (msec_cur - msec_last);
+ max_error_rate = (gdouble)default_max_errors / default_error_time;
+ }
+ else {
+ error_rate = 1;
+ max_error_rate = 0;
+ }
if (error_rate > max_error_rate) {
/* Remove upstream from the active list */
diff --git a/test/rspamd_upstream_test.c b/test/rspamd_upstream_test.c
index 16ce27160..80d963963 100644
--- a/test/rspamd_upstream_test.c
+++ b/test/rspamd_upstream_test.c
@@ -51,6 +51,14 @@ rspamd_upstream_test_method (struct upstream_list *ls,
}
}
+static void
+rspamd_upstream_timeout_handler (int fd, short what, void *arg)
+{
+ struct rspamd_dns_resolver *resolver = (struct rspamd_dns_resolver *)arg;
+
+ rdns_resolver_release (resolver->r);
+}
+
void
rspamd_upstream_test_func (void)
{
@@ -62,19 +70,26 @@ rspamd_upstream_test_func (void)
gint i, success = 0;
const gint assumptions = 100500;
gdouble p;
+ struct event ev;
+ struct timeval tv;
cfg = (struct rspamd_config *)g_malloc (sizeof (struct rspamd_config));
bzero (cfg, sizeof (struct rspamd_config));
cfg->cfg_pool = rspamd_mempool_new (rspamd_mempool_suggest_size ());
cfg->dns_retransmits = 2;
cfg->dns_timeout = 0.5;
+ cfg->upstream_max_errors = 1;
+ cfg->upstream_revive_time = 0.5;
+ cfg->upstream_error_time = 2;
resolver = dns_resolver_init (NULL, ev_base, cfg);
rspamd_upstreams_library_init (resolver->r, ev_base);
+ rspamd_upstreams_library_config (cfg);
ls = rspamd_upstreams_create ();
g_assert (rspamd_upstreams_parse_line (ls, test_upstream_list, 443, NULL));
+ g_assert (rspamd_upstreams_count (ls) == 3);
/* Test master-slave rotation */
rspamd_upstream_test_method (ls, RSPAMD_UPSTREAM_MASTER_SLAVE, "kernel.org");
@@ -111,6 +126,21 @@ rspamd_upstream_test_func (void)
* miss should be close to the relation N / (N + M), where N is the size of
* the previous upstreams list.
*/
- msg_info ("p value for hash consistency: %.6f", p);
+ msg_debug ("p value for hash consistency: %.6f", p);
g_assert (p > 0.9);
+
+ /* Upstream fail test */
+ evtimer_set (&ev, rspamd_upstream_timeout_handler, resolver);
+ event_base_set (ev_base, &ev);
+
+ up = rspamd_upstream_get (ls, RSPAMD_UPSTREAM_MASTER_SLAVE);
+ rspamd_upstream_fail (up);
+ g_assert (rspamd_upstreams_alive (ls) == 2);
+
+ tv.tv_sec = 2;
+ tv.tv_usec = 0;
+ event_add (&ev, &tv);
+
+ event_base_loop (ev_base, 0);
+ g_assert (rspamd_upstreams_alive (ls) == 3);
}