X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fserver.h;h=c9700e95e620fe6a28ff2bc2aba1ee4149b5b043;hb=7ba11a92a63df071ee3f848c980c8459dc184ebc;hp=9c8f048bd393049f4739c9e83093b915d95aa704;hpb=ad5d3efae1a492151ab2b08d370d86d27931c3a9;p=awesomized%2Flibmemcached diff --git a/libtest/server.h b/libtest/server.h index 9c8f048b..c9700e95 100644 --- a/libtest/server.h +++ b/libtest/server.h @@ -39,6 +39,7 @@ private: typedef std::vector< std::pair > Options; private: + uint64_t _magic; bool _is_socket; std::string _socket; std::string _sasl; @@ -54,13 +55,13 @@ protected: 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 *daemon_file_option()= 0; virtual bool is_libtool()= 0; virtual bool has_socket_file_option() const @@ -78,7 +79,7 @@ public: } } - bool has_log_file_option() const + virtual bool has_log_file_option() const { return false; } @@ -97,7 +98,7 @@ public: { if (arg.empty() == false) { - std::string buffer("--socket="); + std::string buffer("--pid-file="); buffer+= arg; app.add_option(buffer); } @@ -164,7 +165,7 @@ public: virtual pid_t get_pid(bool error_is_ok= false)= 0; - virtual bool build(int argc, const char *argv[])= 0; + virtual bool build(size_t argc, const char *argv[])= 0; void add_option(const std::string&); void add_option(const std::string&, const std::string&); @@ -223,15 +224,20 @@ public: return _running; } + bool check(); + std::string log_and_pid(); bool kill(pid_t pid_arg); bool start(); bool command(libtest::Application& app); + bool validate(); + protected: bool set_pid_file(); Options _options; + Application _app; private: bool is_helgrind() const;