/* vim:expandtab:shiftwidth=2:tabstop=2:smarttab: * * Gearmand client and server library. * * Copyright (C) 2011-2012 Data Differential, http://datadifferential.com/ * Copyright (C) 2008 Brian Aker, Eric Day * 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. * */ #include "gear_config.h" #include using namespace libtest; #include #include #include #include #include #include #include "tests/basic.h" #include "tests/context.h" #include "libgearman/client.hpp" #include "libgearman/worker.hpp" using namespace org::gearmand; #include "tests/workers/v2/called.h" #ifndef __INTEL_COMPILER #pragma GCC diagnostic ignored "-Wold-style-cast" #endif static test_return_t gearmand_basic_option_test(void *) { const char *args[]= { "--check-args", "--queue-type=libtokyocabinet", "--libtokyocabinet-file=var/tmp/gearman_basic.tcb", "--libtokyocabinet-optimize", 0 }; unlink("var/tmp/gearman.tcb"); ASSERT_EQ(EXIT_SUCCESS, exec_cmdline(gearmand_binary(), args, true)); return TEST_SUCCESS; } static test_return_t collection_init(void *object) { const char *argv[]= { "--libtokyocabinet-file=var/tmp/gearman.tcb", "--queue-type=libtokyocabinet", 0 }; unlink("var/tmp/gearman.tcb"); Context *test= (Context *)object; assert(test); ASSERT_TRUE(test->initialize(argv)); return TEST_SUCCESS; } static test_return_t lp_1054377_TEST(void *object) { Context *test= (Context *)object; ASSERT_TRUE(test); server_startup_st &servers= test->_servers; unlink("var/tmp/gearman.tcb"); const char *argv[]= { "--libtokyocabinet-file=var/tmp/gearman.tcb", "--queue-type=libtokyocabinet", 0 }; const int32_t inserted_jobs= 8; { in_port_t first_port= libtest::get_free_port(); ASSERT_TRUE(server_startup(servers, "gearmand", first_port, argv)); { libgearman::Worker worker(first_port); ASSERT_EQ(gearman_worker_register(&worker, __func__, 0), GEARMAN_SUCCESS); } { libgearman::Client client(first_port); ASSERT_EQ(gearman_client_echo(&client, test_literal_param("This is my echo test")), GEARMAN_SUCCESS); gearman_job_handle_t job_handle; for (int32_t x= 0; x < inserted_jobs; ++x) { ASSERT_EQ(gearman_client_do_background(&client, __func__, // func NULL, // unique test_literal_param("foo"), job_handle), GEARMAN_SUCCESS); } } servers.clear(); } { in_port_t first_port= libtest::get_free_port(); ASSERT_TRUE(server_startup(servers, "gearmand", first_port, argv)); { libgearman::Worker worker(first_port); Called called; gearman_function_t counter_function= gearman_function_create(called_worker); ASSERT_EQ(gearman_worker_define_function(&worker, test_literal_param(__func__), counter_function, 3000, &called), GEARMAN_SUCCESS); const int32_t max_timeout= 4; int32_t max_timeout_value= max_timeout; int32_t job_count= 0; gearman_return_t ret; do { ret= gearman_worker_work(&worker); if (gearman_success(ret)) { job_count++; max_timeout_value= max_timeout; if (job_count == inserted_jobs) { break; } } else if (ret == GEARMAN_TIMEOUT) { if ((--max_timeout_value) < 0) { break; } } } while (ret == GEARMAN_TIMEOUT or ret == GEARMAN_SUCCESS); ASSERT_EQ(called.count(), inserted_jobs); } } unlink("var/tmp/gearman.tcb"); return TEST_SUCCESS; } static test_return_t collection_cleanup(void *object) { Context *test= (Context *)object; test->reset(); unlink("var/tmp/gearman.tcb"); return TEST_SUCCESS; } static void *world_create(server_startup_st& servers, test_return_t&) { SKIP_IF(HAVE_UUID_UUID_H != 1); SKIP_IF(HAVE_TOKYOCABINET != 1); unlink("var/tmp/gearman.tcb"); return new Context(servers); } static bool world_destroy(void *object) { Context *test= (Context *)object; unlink("var/tmp/gearman.tcb"); delete test; return TEST_SUCCESS; } test_st gearmand_basic_option_tests[] ={ {"--libtokyocabinet-file=var/tmp/gearman_basic.tcb --libtokyocabinet-optimize", 0, gearmand_basic_option_test }, {0, 0, 0} }; test_st tests[] ={ {"gearman_client_echo()", 0, client_echo_test }, {"gearman_client_echo() fail", 0, client_echo_fail_test }, {"gearman_worker_echo()", 0, worker_echo_test }, {"clean", 0, queue_clean }, {"add", 0, queue_add }, {"worker", 0, queue_worker }, {0, 0, 0} }; test_st queue_restart_TESTS[] ={ {"lp:1054377", 0, lp_1054377_TEST }, {0, 0, 0} }; collection_st collection[] ={ {"gearmand options", 0, 0, gearmand_basic_option_tests}, {"tokyocabinet queue", collection_init, collection_cleanup, tests}, {"queue restart", 0, 0, queue_restart_TESTS}, {0, 0, 0, 0} }; void get_world(libtest::Framework *world) { world->collections(collection); world->create(world_create); world->destroy(world_destroy); }