summaryrefslogtreecommitdiffstats
path: root/storage/tokudb/PerconaFT/util/tests/threadpool-testrunf.cc
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 18:07:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 18:07:14 +0000
commita175314c3e5827eb193872241446f2f8f5c9d33c (patch)
treecd3d60ca99ae00829c52a6ca79150a5b6e62528b /storage/tokudb/PerconaFT/util/tests/threadpool-testrunf.cc
parentInitial commit. (diff)
downloadmariadb-10.5-upstream/1%10.5.12.tar.xz
mariadb-10.5-upstream/1%10.5.12.zip
Adding upstream version 1:10.5.12.upstream/1%10.5.12upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'storage/tokudb/PerconaFT/util/tests/threadpool-testrunf.cc')
-rw-r--r--storage/tokudb/PerconaFT/util/tests/threadpool-testrunf.cc114
1 files changed, 114 insertions, 0 deletions
diff --git a/storage/tokudb/PerconaFT/util/tests/threadpool-testrunf.cc b/storage/tokudb/PerconaFT/util/tests/threadpool-testrunf.cc
new file mode 100644
index 00000000..4db38c73
--- /dev/null
+++ b/storage/tokudb/PerconaFT/util/tests/threadpool-testrunf.cc
@@ -0,0 +1,114 @@
+/* -*- mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- */
+// vim: ft=cpp:expandtab:ts=8:sw=4:softtabstop=4:
+#ident "$Id$"
+/*======
+This file is part of PerconaFT.
+
+
+Copyright (c) 2006, 2015, Percona and/or its affiliates. All rights reserved.
+
+ PerconaFT is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License, version 2,
+ as published by the Free Software Foundation.
+
+ PerconaFT 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.
+
+ You should have received a copy of the GNU General Public License
+ along with PerconaFT. If not, see <http://www.gnu.org/licenses/>.
+
+----------------------------------------
+
+ PerconaFT is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Affero General Public License, version 3,
+ as published by the Free Software Foundation.
+
+ PerconaFT 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 Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with PerconaFT. If not, see <http://www.gnu.org/licenses/>.
+======= */
+
+#ident "Copyright (c) 2006, 2015, Percona and/or its affiliates. All rights reserved."
+
+#include <util/threadpool.h>
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <assert.h>
+#include <string.h>
+#include <unistd.h>
+
+int verbose = 0;
+
+static int usage(int poolsize) {
+ fprintf(stderr, "[-q] [-v] [--verbose] (%d)\n", verbose);
+ fprintf(stderr, "[--poolsize %d]\n", poolsize);
+ return 1;
+}
+
+static void *f(void *arg) {
+ return arg;
+}
+
+static void dotest(int poolsize, int nloops) {
+ int r;
+ struct toku_thread_pool *pool = NULL;
+ r = toku_thread_pool_create(&pool, poolsize);
+ assert(r == 0 && pool != NULL);
+
+ int i;
+ for (i = 0; i < nloops; i++) {
+ int n = 1;
+ r = toku_thread_pool_run(pool, 1, &n, f, NULL);
+ assert(r == 0);
+ }
+
+ if (verbose)
+ toku_thread_pool_print(pool, stderr);
+ toku_thread_pool_destroy(&pool);
+}
+
+int main(int argc, char *argv[]) {
+ // defaults
+ int poolsize = 1;
+ int nloops = 100000;
+
+ // options
+ int i;
+ for (i = 1; i < argc; i++) {
+ char *arg = argv[i];
+ if (arg[0] != '-')
+ break;
+ if (strcmp(arg, "--poolsize") == 0 && i+1 < argc) {
+ poolsize = atoi(argv[++i]);
+ continue;
+ }
+ if (strcmp(arg, "-v") == 0 || strcmp(arg, "--verbose") == 0) {
+ verbose = verbose+1;
+ continue;
+ }
+ if (strcmp(arg, "-q") == 0) {
+ verbose = verbose > 0 ? verbose-1 : 0;
+ continue;
+ }
+
+ return usage(poolsize);
+ }
+ int starti = i;
+
+ if (starti == argc) {
+ dotest(poolsize, nloops);
+ } else {
+ for (i = starti; i < argc; i++) {
+ nloops = atoi(argv[i]);
+ dotest(poolsize, nloops);
+ }
+ }
+ return 0;
+}