#pragma once
+#include <libtest/cmdline.h>
+
#include <cassert>
#include <cstdio>
#include <cstring>
struct Server {
private:
+ typedef std::vector< std::pair<std::string, std::string> > Options;
+
+private:
+ uint64_t _magic;
bool _is_socket;
std::string _socket;
std::string _sasl;
std::string _log_file;
std::string _base_command; // executable command which include libtool, valgrind, gdb, etc
std::string _running; // Current string being used for system()
- pid_t _pid;
protected:
in_port_t _port;
std::string _extra_args;
public:
- Server(const std::string& hostname, const in_port_t port_arg, const bool is_socket_arg= false);
+ Server(const std::string& hostname, const in_port_t port_arg,
+ const std::string& executable, const bool _is_libtool,
+ const bool is_socket_arg= false);
virtual ~Server();
virtual const char *name()= 0;
- virtual const char *executable()= 0;
- virtual const char *port_option()= 0;
- virtual const char *pid_file_option()= 0;
- virtual const char *daemon_file_option()= 0;
- virtual const char *log_file_option()= 0;
virtual bool is_libtool()= 0;
- virtual bool broken_socket_cleanup()
+ virtual bool has_socket_file_option() const
+ {
+ return false;
+ }
+
+ virtual void socket_file_option(Application& app, const std::string& socket_arg)
+ {
+ if (socket_arg.empty() == false)
+ {
+ std::string buffer("--socket=");
+ buffer+= socket_arg;
+ app.add_option(buffer);
+ }
+ }
+
+ virtual bool has_log_file_option() const
+ {
+ return false;
+ }
+
+ virtual void log_file_option(Application& app, const std::string& arg)
+ {
+ if (arg.empty() == false)
+ {
+ std::string buffer("--log-file=");
+ buffer+= arg;
+ app.add_option(buffer);
+ }
+ }
+
+ virtual void pid_file_option(Application& app, const std::string& arg)
+ {
+ if (arg.empty() == false)
+ {
+ std::string buffer("--pid-file=");
+ buffer+= arg;
+ app.add_option(buffer);
+ }
+ }
+
+ virtual bool has_port_option() const
{
return false;
}
- virtual const char *socket_file_option() const
+ virtual void port_option(Application& app, in_port_t arg)
+ {
+ if (arg > 0)
+ {
+ char buffer[1024];
+ snprintf(buffer, sizeof(buffer), "--port=%d", int(arg));
+ app.add_option(buffer);
+ }
+ }
+
+ virtual bool broken_socket_cleanup()
{
- return NULL;
+ return false;
}
virtual bool broken_pid_file()
virtual bool ping()= 0;
- virtual pid_t get_pid(bool error_is_ok= false)= 0;
+ virtual bool build(size_t argc, const char *argv[])= 0;
- virtual bool build(int argc, const char *argv[])= 0;
+ void add_option(const std::string&);
+ void add_option(const std::string&, const std::string&);
in_port_t port() const
{
return (_port != 0);
}
+ virtual bool has_syslog() const
+ {
+ return false;
+ }
+
// Reset a server if another process has killed the server
void reset()
{
- _pid= -1;
_pid_file.clear();
_log_file.clear();
}
- void set_extra_args(const std::string &arg);
+ bool args(Application&);
- bool args(std::string& options);
+ pid_t pid() const;
- pid_t pid();
+ bool has_pid() const;
- pid_t pid() const
- {
- return _pid;
- }
-
- bool has_pid() const
- {
- return (_pid > 1);
- }
-
- bool wait_for_pidfile() const;
+ virtual bool wait_for_pidfile() const;
bool check_pid(pid_t pid_arg) const
{
return _running;
}
+ bool check();
+
std::string log_and_pid();
- bool kill(pid_t pid_arg);
+ bool kill();
bool start();
- bool command(std::string& command_arg);
+ bool command(libtest::Application& app);
+
+ bool validate();
protected:
- void nap();
bool set_pid_file();
+ Options _options;
+ Application _app;
private:
bool is_helgrind() const;
bool is_debug() const;
bool set_log_file();
bool set_socket_file();
- void rebuild_base_command();
void reset_pid();
};