2 common commandline code to ctdb test tools
4 Copyright (C) Andrew Tridgell 2007
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 3 of the License, or (at your option) any later version.
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with this library; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 #include "lib/events/events.h"
23 #include "system/filesys.h"
25 #include "../include/ctdb.h"
26 #include "../include/ctdb_private.h"
28 /* Handle common command line options for ctdb test progs
33 const char *transport;
34 const char *myaddress;
48 struct poptOption popt_ctdb_cmdline[] = {
49 { "nlist", 0, POPT_ARG_STRING, &ctdb_cmdline.nlist, 0, "node list file", "filename" },
50 { "listen", 0, POPT_ARG_STRING, &ctdb_cmdline.myaddress, 0, "address to listen on", "address" },
51 { "transport", 0, POPT_ARG_STRING, &ctdb_cmdline.transport, 0, "protocol transport", NULL },
52 { "self-connect", 0, POPT_ARG_NONE, &ctdb_cmdline.self_connect, 0, "enable self connect", "boolean" },
53 { "debug", 'd', POPT_ARG_INT, &LogLevel, 0, "debug level"},
54 { "dbdir", 0, POPT_ARG_STRING, &ctdb_cmdline.db_dir, 0, "directory for the tdb files", NULL },
55 { "torture", 0, POPT_ARG_NONE, &ctdb_cmdline.torture, 0, "enable nastiness in library", NULL },
61 startup daemon side of ctdb according to command line options
63 struct ctdb_context *ctdb_cmdline_init(struct event_context *ev)
65 struct ctdb_context *ctdb;
68 if (ctdb_cmdline.nlist == NULL || ctdb_cmdline.myaddress == NULL) {
69 printf("You must provide a node list with --nlist and an address with --listen\n");
76 printf("Failed to init ctdb\n");
80 if (ctdb_cmdline.self_connect) {
81 ctdb_set_flags(ctdb, CTDB_FLAG_SELF_CONNECT);
83 if (ctdb_cmdline.torture) {
84 ctdb_set_flags(ctdb, CTDB_FLAG_TORTURE);
87 ret = ctdb_set_transport(ctdb, ctdb_cmdline.transport);
89 printf("ctdb_set_transport failed - %s\n", ctdb_errstr(ctdb));
93 /* tell ctdb what address to listen on */
94 ret = ctdb_set_address(ctdb, ctdb_cmdline.myaddress);
96 printf("ctdb_set_address failed - %s\n", ctdb_errstr(ctdb));
100 /* tell ctdb what nodes are available */
101 ret = ctdb_set_nlist(ctdb, ctdb_cmdline.nlist);
103 printf("ctdb_set_nlist failed - %s\n", ctdb_errstr(ctdb));
107 ret = ctdb_set_tdb_dir(ctdb, ctdb_cmdline.db_dir);
109 printf("ctdb_set_tdb_dir failed - %s\n", ctdb_errstr(ctdb));
118 startup a client only ctdb context
120 struct ctdb_context *ctdb_cmdline_client(struct event_context *ev, const char *ctdb_socket)
122 struct ctdb_context *ctdb;
125 /* initialise ctdb */
126 ctdb = ctdb_init(ev);
128 printf("Failed to init ctdb\n");
132 ctdb->daemon.name = talloc_strdup(ctdb, ctdb_socket);
134 ret = ctdb_socket_connect(ctdb);
136 DEBUG(0,(__location__ " Failed to connect to daemon\n"));