aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMartin Willi <martin@strongswan.org>2008-11-04 12:59:53 +0000
committerMartin Willi <martin@strongswan.org>2008-11-04 12:59:53 +0000
commit480be6436a1f40ca1157e92b0d0a08442fca88c8 (patch)
treeeef27cf9462d45a7aecec3b1d8e5f3092edb96b6
parentec1bddc50c1773b3412f64b5f6affc81302b9614 (diff)
downloadstrongswan-480be6436a1f40ca1157e92b0d0a08442fca88c8.tar.bz2
strongswan-480be6436a1f40ca1157e92b0d0a08442fca88c8.tar.xz
added a delay option to delay initiations
-rw-r--r--src/charon/plugins/load_tester/load_tester_plugin.c50
1 files changed, 41 insertions, 9 deletions
diff --git a/src/charon/plugins/load_tester/load_tester_plugin.c b/src/charon/plugins/load_tester/load_tester_plugin.c
index 86a7e1d0e..9dbfcd609 100644
--- a/src/charon/plugins/load_tester/load_tester_plugin.c
+++ b/src/charon/plugins/load_tester/load_tester_plugin.c
@@ -20,6 +20,8 @@
#include "load_tester_creds.h"
#include "load_tester_ipsec.h"
+#include <unistd.h>
+
#include <daemon.h>
#include <processing/jobs/callback_job.h>
@@ -44,6 +46,21 @@ struct private_load_tester_plugin_t {
* load_tester credential set implementation
*/
load_tester_creds_t *creds;
+
+ /**
+ * number of iterations per thread
+ */
+ int iterations;
+
+ /**
+ * number of threads
+ */
+ int initiators;
+
+ /**
+ * delay between initiations, in ms
+ */
+ int delay;
};
/**
@@ -54,11 +71,13 @@ static job_requeue_t do_load_test(private_load_tester_plugin_t *this)
peer_cfg_t *peer_cfg;
child_cfg_t *child_cfg = NULL;;
enumerator_t *enumerator;
- int iterations, i;
-
- iterations = lib->settings->get_int(lib->settings,
- "charon.plugins.load_tester.iterations", 0);
+ int i, s = 0, ms = 0;
+ if (this->delay)
+ {
+ s = this->delay / 1000;
+ ms = this->delay % 1000;
+ }
peer_cfg = charon->backends->get_peer_cfg_by_name(charon->backends,
"load-test");
if (peer_cfg)
@@ -72,11 +91,20 @@ static job_requeue_t do_load_test(private_load_tester_plugin_t *this)
if (child_cfg)
{
- for (i = 0; i < iterations; i++)
+ for (i = 0; i < this->iterations; i++)
{
charon->controller->initiate(charon->controller,
peer_cfg->get_ref(peer_cfg), child_cfg->get_ref(child_cfg),
NULL, NULL);
+
+ if (s)
+ {
+ sleep(s);
+ }
+ if (ms)
+ {
+ usleep(ms * 1000);
+ }
}
child_cfg->destroy(child_cfg);
}
@@ -104,8 +132,8 @@ static void destroy(private_load_tester_plugin_t *this)
*/
plugin_t *plugin_create()
{
- int initiators;
private_load_tester_plugin_t *this = malloc_thing(private_load_tester_plugin_t);
+ int i;
this->public.plugin.destroy = (void(*)(plugin_t*))destroy;
@@ -120,9 +148,13 @@ plugin_t *plugin_create()
charon->kernel_interface->add_ipsec_interface(charon->kernel_interface,
(kernel_ipsec_constructor_t)load_tester_ipsec_create);
}
- initiators = lib->settings->get_int(lib->settings,
- "charon.plugins.load_tester.initiators", 1);
- while (initiators-- > 0)
+ this->delay = lib->settings->get_int(lib->settings,
+ "charon.plugins.load_tester.delay", 0);
+ this->iterations = lib->settings->get_int(lib->settings,
+ "charon.plugins.load_tester.iterations", 0);
+ this->initiators = lib->settings->get_int(lib->settings,
+ "charon.plugins.load_tester.initiators", 1);
+ for (i = 0; i < this->initiators; i++)
{
charon->processor->queue_job(charon->processor,
(job_t*)callback_job_create((callback_job_cb_t)do_load_test,