X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fserver.h;h=b1ca30aa713f04e2d26eacd3fb955910dfeec541;hb=7287f37372f5e4198f7f16f5f6d6dcf9a8d5c1fb;hp=1b6841d55d38d57541679d0af66305f9060df58a;hpb=90c96090380d18b6bb7a553d6b9c7e1ce93e248c;p=m6w6%2Flibmemcached diff --git a/libtest/server.h b/libtest/server.h index 1b6841d5..b1ca30aa 100644 --- a/libtest/server.h +++ b/libtest/server.h @@ -47,7 +47,6 @@ private: 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; @@ -55,13 +54,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 @@ -163,8 +162,6 @@ public: 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; void add_option(const std::string&); @@ -188,26 +185,17 @@ public: // Reset a server if another process has killed the server void reset() { - _pid= -1; _pid_file.clear(); _log_file.clear(); } bool args(Application&); - pid_t pid(); + pid_t pid() const; - pid_t pid() const - { - return _pid; - } + bool has_pid() const; - 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 { @@ -224,9 +212,11 @@ public: return _running; } + bool check(); + std::string log_and_pid(); - bool kill(pid_t pid_arg); + bool kill(); bool start(); bool command(libtest::Application& app); @@ -235,6 +225,7 @@ public: protected: bool set_pid_file(); Options _options; + Application _app; private: bool is_helgrind() const;