/* * Copyright (C) 2008 Martin Willi * Hochschule fuer Technik Rapperswil * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or (at your * option) any later version. See . * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. */ #include #include #include #include #define ALLOCS 1000 #define THREADS 20 static void* testing(void *thread) { int i; host_t *addr[ALLOCS]; identification_t *id[ALLOCS]; /* prepare identities */ for (i = 0; i < ALLOCS; i++) { char buf[256]; snprintf(buf, sizeof(buf), "%d-%d@strongswan.org", (uintptr_t)thread, i); id[i] = identification_create_from_string(buf); } /* allocate addresses */ for (i = 0; i < ALLOCS; i++) { addr[i] = hydra->attributes->acquire_address(hydra->attributes, "test", id[i], NULL); if (!addr[i]) { return (void*)FALSE; } } /* release addresses */ for (i = 0; i < ALLOCS; i++) { hydra->attributes->release_address(hydra->attributes, "test", addr[i], id[i]); } /* cleanup */ for (i = 0; i < ALLOCS; i++) { addr[i]->destroy(addr[i]); id[i]->destroy(id[i]); } return (void*)TRUE; } /******************************************************************************* * SQL pool performance test ******************************************************************************/ bool test_pool() { thread_t *threads[THREADS]; uintptr_t i; for (i = 0; i < THREADS; i++) { if (!(threads[i] = thread_create((thread_main_t)testing, (void*)i))) { return FALSE; } } for (i = 0; i < THREADS; i++) { bool *res = threads[i]->join(threads[i]); if (!res) { return FALSE; } } return TRUE; }