Adjust new comments to match existing
[xapian.git] / xapian-letor / tests / apitest.h
blob79b08d3106424e263948c07629246d63058753ae
1 /** @file
2 * @brief test functionality of the Xapian API
3 */
4 /* Copyright (C) 2007,2009,2011,2018 Olly Betts
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21 #ifndef XAPIAN_INCLUDED_APITEST_H
22 #define XAPIAN_INCLUDED_APITEST_H
24 #include <xapian.h>
26 #include "testsuite.h"
28 std::string get_dbtype();
30 Xapian::Database get_database(const std::string &db);
32 Xapian::Database get_database(const std::string &db1, const std::string &db2);
34 Xapian::Database get_database(const std::string &db,
35 void (*gen)(Xapian::WritableDatabase&,
36 const std::string &),
37 const std::string &arg = std::string());
39 std::string get_database_path(const std::string &db);
41 std::string get_database_path(const std::string &db,
42 void (*gen)(Xapian::WritableDatabase&,
43 const std::string &),
44 const std::string &arg = std::string());
46 Xapian::WritableDatabase get_writable_database(const std::string &db = std::string());
48 Xapian::WritableDatabase get_named_writable_database(const std::string &name, const std::string &source = std::string());
50 std::string get_named_writable_database_path(const std::string &name);
52 std::string get_compaction_output_path(const std::string& name);
54 Xapian::Database get_remote_database(const std::string& db,
55 unsigned timeout,
56 int* port_ptr = nullptr);
58 /** Kill the server associated with remote database @a db.
60 * Currently only supported for remotetcp and only for a database with a
61 * single shard.
63 void kill_remote(const Xapian::Database& db);
65 Xapian::Database get_writable_database_as_database();
67 Xapian::WritableDatabase get_writable_database_again();
69 // Skip the test for any backend not of the specified type.
71 // More precisely, this skips the test for any backend for which the
72 // get_dbtype() function does not return a string starting with backend_prefix.
73 // This allows backends like "multi_glass" to be covered by specifying "multi".
74 void skip_test_unless_backend(const std::string & backend_prefix);
76 // Skip the test for any backend of the specified type.
78 // More precisely, this skips the test for any backend for which the
79 // get_dbtype() function returns a string starting with backend_prefix. This
80 // allows backends like "multi_glass" to be covered by specifying "multi".
81 void skip_test_for_backend(const std::string & backend_prefix);
83 #define SKIP_TEST_UNLESS_BACKEND(B) skip_test_unless_backend(B)
84 #define SKIP_TEST_FOR_BACKEND(B) skip_test_for_backend(B)
86 void XFAIL_FOR_BACKEND(const std::string& backend_prefix,
87 const char* msg);
89 #endif // XAPIAN_INCLUDED_APITEST_H