/* vim:expandtab:shiftwidth=2:tabstop=2:smarttab: * * Gearmand client and server library. * * Copyright (C) 2011 Data Differential, http://datadifferential.com/ * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. * * * The names of its contributors may not be used to endorse or * promote products derived from this software without specific prior * written permission. * * THIs soFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */ #pragma once #include #include class Context { private: gearman_worker_st *_worker; in_port_t _port; std::string _worker_function_name; public: server_startup_st &_servers; bool run_worker; std::vector _extra_files; Context(server_startup_st &server_arg): _worker(NULL), _port(get_free_port()), _worker_function_name("queue_test"), _servers(server_arg), run_worker(false) { } ~Context() { extra_clear(); _servers.clear(); } const char *worker_function_name() const { return _worker_function_name.c_str(); } gearman_worker_st* worker() { if (_worker) { return _worker; } _worker= gearman_worker_create(NULL); ASSERT_TRUE(_worker); ASSERT_TRUE(gearman_success(gearman_worker_add_server(_worker, NULL, _port))); return _worker; } in_port_t port() const { return _port; } bool initialize(const char *argv[]) { ASSERT_TRUE(server_startup(_servers, "gearmand", _port, argv)); return true; } void extra_file(const std::string& extra_file_) { _extra_files.push_back(extra_file_); } void extra_clear() { for (std::vector::iterator iter= _extra_files.begin(); iter != _extra_files.end(); ++iter) { unlink((*iter).c_str()); } _extra_files.clear(); } void reset() { _servers.clear(); gearman_worker_free(_worker); _worker= NULL; extra_clear(); _port= get_free_port(); } };