/* Copyright (c) 2012, Vsevolod Stakhov * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL AUTHOR BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include "config.h" #include "tests.h" #include "rrd.h" #include "rspamd.h" #include "ottery.h" const int rows_cnt = 20; const int pdp_per_cdp = 60; void rspamd_rrd_test_func () { gchar tmpfile[PATH_MAX]; struct rrd_rra_def rra[4]; struct rrd_ds_def ds[2]; GArray ar; GError *err = NULL; struct rspamd_rrd_file *rrd; gdouble ticks; gint i; gdouble t[2], cnt = 0.0; rspamd_snprintf (tmpfile, sizeof (tmpfile), "/tmp/rspamd_rrd.rrd"); unlink (tmpfile); /* Create sample rrd */ ticks = rspamd_get_calendar_ticks (); g_assert ((rrd = rspamd_rrd_create (tmpfile, 2, 4, 1, ticks, &err)) != NULL); /* Add RRA */ rrd_make_default_rra ("AVERAGE", pdp_per_cdp, rows_cnt, &rra[0]); rrd_make_default_rra ("AVERAGE", pdp_per_cdp / 2, rows_cnt, &rra[1]); rrd_make_default_rra ("AVERAGE", pdp_per_cdp / 4, rows_cnt, &rra[2]); rrd_make_default_rra ("AVERAGE", pdp_per_cdp / 10, rows_cnt, &rra[3]); ar.data = rra; ar.len = sizeof (rra); g_assert (rspamd_rrd_add_rra (rrd, &ar, &err)); /* Add DS */ rrd_make_default_ds ("test", "COUNTER", 1, &ds[0]); rrd_make_default_ds ("test1", "COUNTER", 1, &ds[1]); ar.data = ds; ar.len = sizeof (ds); g_assert (rspamd_rrd_add_ds (rrd, &ar, &err)); /* Finalize */ g_assert (rspamd_rrd_finalize (rrd, &err)); /* Close */ rspamd_rrd_close (rrd); /* Reopen */ g_assert ((rrd = rspamd_rrd_open (tmpfile, &err)) != NULL); /* Add some points */ for (i = 0; i < pdp_per_cdp * rows_cnt / 2; i ++) { t[0] = i; t[1] = cnt ++; ar.data = t; ar.len = sizeof (t); ticks += 1.0; g_assert (rspamd_rrd_add_record (rrd, &ar, ticks, &err)); } /* Add some more points */ for (i = 0; i < pdp_per_cdp * rows_cnt / 4; i ++) { t[0] = i + rspamd_time_jitter (1.0, 0.0); t[1] = cnt ++; ar.data = t; ar.len = sizeof (t); ticks += 1.0; g_assert (rspamd_rrd_add_record (rrd, &ar, ticks, &err)); } /* Add undefined interval */ ticks += 200; /* Add some more points */ for (i = 0; i < pdp_per_cdp * rows_cnt / 8; i ++) { t[0] = i; t[1] = cnt ++; ar.data = t; ar.len = sizeof (t); ticks += 1.0; g_assert (rspamd_rrd_add_record (rrd, &ar, ticks, &err)); } /* Finish */ rspamd_rrd_close (rrd); /* unlink (tmpfile); */ }