X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fframework.h;h=f4f64070cbb7dbe2afc66bf7f4258612a0df9135;hb=fe4757c512265eef4f8905b3392f19d33c436ddf;hp=1c9a1c1d5ff2e2dc1eabdb26fbcc8c0c129f51d2;hpb=bed5d0baa746d10fd3899be96a6ab8673daa7e03;p=m6w6%2Flibmemcached diff --git a/libtest/framework.h b/libtest/framework.h index 1c9a1c1d..f4f64070 100644 --- a/libtest/framework.h +++ b/libtest/framework.h @@ -1,40 +1,26 @@ /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab: * - * uTest, libtest + * libtest * * Copyright (C) 2011 Data Differential, http://datadifferential.com/ * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are - * met: + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. * - * * 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. + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ + #pragma once /** @@ -43,108 +29,57 @@ get_world() in order to fill this structure. */ -struct Framework { +class Framework { +public: collection_st *collections; /* These methods are called outside of any collection call. */ test_callback_create_fn *_create; - test_callback_fn *_destroy; + test_callback_destroy_fn *_destroy; +public: void* create(test_return_t& arg); - /* This is called a the beginning of any collection run. */ - test_callback_fn *collection_startup; + /** + If an error occurs during the test, this is called. + */ + test_callback_error_fn *_on_error; - test_return_t startup(void*); + void set_on_error(test_callback_error_fn *arg) + { + _on_error= arg; + } - /* This is called a the end of any collection run. */ - test_callback_fn *collection_shutdown; + test_return_t on_error(const enum test_return_t, void *); - test_return_t shutdown(void* arg) + void set_socket() { - if (collection_shutdown) - { - return collection_shutdown(arg); - } + _servers.set_socket(); + } - return TEST_SUCCESS; + void set_sasl(const std::string& username_arg, const std::string& password_arg) + { + _servers.set_sasl(username_arg, password_arg); } + libtest::server_startup_st& servers() + { + return _servers; + } + /** - These are run before/after the test. If implemented. Their execution is not controlled - by the test. + Runner represents the callers for the tests. If not implemented we will use + a set of default implementations. */ - struct Item { - /* This is called a the beginning of any run. */ - test_callback_fn *_startup; - - test_return_t startup(void*); - - /* - This called on a test if the test requires a flush call (the bool is - from test_st) - */ - test_callback_fn *_flush; - - /* - Run before and after the runnner is executed. - */ - test_callback_fn *pre_run; - test_callback_fn *post_run; - - Item() : - _startup(NULL), - _flush(NULL), - pre_run(NULL), - post_run(NULL) - { } - - test_return_t flush(void* arg, test_st* run); - - void set_pre(test_callback_fn *arg) - { - pre_run= arg; - } - - void set_post(test_callback_fn *arg) - { - pre_run= arg; - } - - test_return_t pre(void *arg) - { - if (pre_run) - { - return pre_run(arg); - } - - return TEST_SUCCESS; - } - - test_return_t post(void *arg) - { - if (post_run) - { - return post_run(arg); - } - - return TEST_SUCCESS; - } - - } item; + libtest::Runner *_runner; - /** - If an error occurs during the test, this is called. - */ - test_callback_error_fn *_on_error; + void set_runner(libtest::Runner *arg) + { + _runner= arg; + } - test_return_t on_error(const enum test_return_t, void *); + libtest::Runner *runner(); - /** - Runner represents the callers for the tests. If not implemented we will use - a set of default implementations. - */ - Runner *runner; Framework(); @@ -154,5 +89,8 @@ struct Framework { private: Framework& operator=(const Framework&); + libtest::server_startup_st _servers; + bool _socket; void *_creators_ptr; + unsigned long int _servers_to_run; };