00001 00004 /* Copyright (C) 2008,2009 Olly Betts 00005 * 00006 * This program is free software; you can redistribute it and/or 00007 * modify it under the terms of the GNU General Public License as 00008 * published by the Free Software Foundation; either version 2 of the 00009 * License, or (at your option) any later version. 00010 * 00011 * This program is distributed in the hope that it will be useful, 00012 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 * GNU General Public License for more details. 00015 * 00016 * You should have received a copy of the GNU General Public License 00017 * along with this program; if not, write to the Free Software 00018 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 00019 * USA 00020 */ 00021 00022 #include <config.h> 00023 00024 #include "api_scalability.h" 00025 00026 #include "apitest.h" 00027 #include "cputimer.h" 00028 #include "scalability.h" 00029 #include "testsuite.h" 00030 #include "testutils.h" 00031 00032 #include <xapian.h> 00033 00034 using namespace std; 00035 00036 static double 00037 bigoaddvalue1_helper(unsigned num_values) 00038 { 00039 Xapian::WritableDatabase db = get_writable_database(); 00040 00041 Xapian::Document doc; 00042 for (unsigned i = 0; i < num_values; ++i) { 00043 doc.add_value(i, "moo"); 00044 } 00045 00046 CPUTimer timer; 00047 00048 db.add_document(doc); 00049 db.flush(); 00050 00051 return timer.get_time(); 00052 } 00053 00054 DEFINE_TESTCASE(bigoaddvalue1, writable) { 00055 // O(n*n) is bad, but O(n*log(n)) is acceptable. 00056 test_scalability(bigoaddvalue1_helper, 5000, O_N_LOG_N); 00057 return true; 00058 }