* test-mu-cmd: don't create too many databases -- big speedup
This commit is contained in:
@ -37,6 +37,8 @@
|
|||||||
|
|
||||||
/* tests for the command line interface, uses testdir2 */
|
/* tests for the command line interface, uses testdir2 */
|
||||||
|
|
||||||
|
static gchar *DBPATH; /* global */
|
||||||
|
|
||||||
static gchar*
|
static gchar*
|
||||||
fill_database (void)
|
fill_database (void)
|
||||||
{
|
{
|
||||||
@ -82,13 +84,10 @@ newlines_in_output (const char* str)
|
|||||||
static void
|
static void
|
||||||
search (const char* query, unsigned expected)
|
search (const char* query, unsigned expected)
|
||||||
{
|
{
|
||||||
gchar *muhome, *cmdline, *output, *erroutput;
|
gchar *cmdline, *output, *erroutput;
|
||||||
|
|
||||||
muhome = fill_database ();
|
|
||||||
g_assert (muhome);
|
|
||||||
|
|
||||||
cmdline = g_strdup_printf ("%s find --muhome=%s %s",
|
cmdline = g_strdup_printf ("%s find --muhome=%s %s",
|
||||||
MU_PROGRAM, muhome, query);
|
MU_PROGRAM, DBPATH, query);
|
||||||
|
|
||||||
if (g_test_verbose())
|
if (g_test_verbose())
|
||||||
g_printerr ("%s\n", cmdline);
|
g_printerr ("%s\n", cmdline);
|
||||||
@ -110,7 +109,6 @@ search (const char* query, unsigned expected)
|
|||||||
g_free (output);
|
g_free (output);
|
||||||
g_free (erroutput);
|
g_free (erroutput);
|
||||||
g_free (cmdline);
|
g_free (cmdline);
|
||||||
g_free (muhome);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* index testdir2, and make sure it adds two documents */
|
/* index testdir2, and make sure it adds two documents */
|
||||||
@ -118,12 +116,9 @@ static void
|
|||||||
test_mu_index (void)
|
test_mu_index (void)
|
||||||
{
|
{
|
||||||
MuStore *store;
|
MuStore *store;
|
||||||
gchar *muhome, *xpath;
|
gchar *xpath;
|
||||||
|
|
||||||
muhome = fill_database ();
|
xpath = g_strdup_printf ("%s%c%s", DBPATH, G_DIR_SEPARATOR, "xapian");
|
||||||
g_assert (muhome != NULL);
|
|
||||||
|
|
||||||
xpath = g_strdup_printf ("%s%c%s", muhome, G_DIR_SEPARATOR, "xapian");
|
|
||||||
|
|
||||||
store = mu_store_new_read_only (xpath, NULL);
|
store = mu_store_new_read_only (xpath, NULL);
|
||||||
g_assert (store);
|
g_assert (store);
|
||||||
@ -131,7 +126,6 @@ test_mu_index (void)
|
|||||||
g_assert_cmpuint (mu_store_count (store, NULL), ==, 12);
|
g_assert_cmpuint (mu_store_count (store, NULL), ==, 12);
|
||||||
mu_store_unref (store);
|
mu_store_unref (store);
|
||||||
|
|
||||||
g_free (muhome);
|
|
||||||
g_free (xpath);
|
g_free (xpath);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -222,10 +216,7 @@ test_mu_find_03 (void)
|
|||||||
static void /* error cases */
|
static void /* error cases */
|
||||||
test_mu_find_04 (void)
|
test_mu_find_04 (void)
|
||||||
{
|
{
|
||||||
gchar *muhome, *cmdline, *erroutput;
|
gchar *cmdline, *erroutput;
|
||||||
|
|
||||||
muhome = fill_database ();
|
|
||||||
g_assert (muhome);
|
|
||||||
|
|
||||||
cmdline = g_strdup_printf ("%s --muhome=%cfoo%cbar%cnonexistent "
|
cmdline = g_strdup_printf ("%s --muhome=%cfoo%cbar%cnonexistent "
|
||||||
"find f:socrates",
|
"find f:socrates",
|
||||||
@ -242,23 +233,19 @@ test_mu_find_04 (void)
|
|||||||
|
|
||||||
g_free (erroutput);
|
g_free (erroutput);
|
||||||
g_free (cmdline);
|
g_free (cmdline);
|
||||||
g_free (muhome);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
test_mu_find_links (void)
|
test_mu_find_links (void)
|
||||||
{
|
{
|
||||||
gchar *muhome, *cmdline, *output, *erroutput, *tmpdir;
|
gchar *cmdline, *output, *erroutput, *tmpdir;
|
||||||
|
|
||||||
|
|
||||||
muhome = fill_database ();
|
|
||||||
g_assert (muhome);
|
|
||||||
tmpdir = test_mu_common_get_random_tmpdir();
|
tmpdir = test_mu_common_get_random_tmpdir();
|
||||||
|
|
||||||
cmdline = g_strdup_printf (
|
cmdline = g_strdup_printf (
|
||||||
"%s find --muhome=%s --format=links --linksdir=%s "
|
"%s find --muhome=%s --format=links --linksdir=%s "
|
||||||
"mime:message/rfc822", MU_PROGRAM, muhome, tmpdir);
|
"mime:message/rfc822", MU_PROGRAM, DBPATH, tmpdir);
|
||||||
|
|
||||||
if (g_test_verbose())
|
if (g_test_verbose())
|
||||||
g_printerr ("%s\n", cmdline);
|
g_printerr ("%s\n", cmdline);
|
||||||
@ -295,7 +282,7 @@ test_mu_find_links (void)
|
|||||||
g_free (cmdline);
|
g_free (cmdline);
|
||||||
cmdline = g_strdup_printf (
|
cmdline = g_strdup_printf (
|
||||||
"%s find --muhome=%s --format=links --linksdir=%s --clearlinks "
|
"%s find --muhome=%s --format=links --linksdir=%s --clearlinks "
|
||||||
"mime:message/rfc822", MU_PROGRAM, muhome, tmpdir);
|
"mime:message/rfc822", MU_PROGRAM, DBPATH, tmpdir);
|
||||||
g_assert (g_spawn_command_line_sync (cmdline,
|
g_assert (g_spawn_command_line_sync (cmdline,
|
||||||
&output, &erroutput,
|
&output, &erroutput,
|
||||||
NULL, NULL));
|
NULL, NULL));
|
||||||
@ -307,7 +294,6 @@ test_mu_find_links (void)
|
|||||||
g_free (erroutput);
|
g_free (erroutput);
|
||||||
|
|
||||||
g_free (cmdline);
|
g_free (cmdline);
|
||||||
g_free (muhome);
|
|
||||||
g_free (tmpdir);
|
g_free (tmpdir);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -803,7 +789,10 @@ main (int argc, char *argv[])
|
|||||||
G_LOG_LEVEL_MASK | G_LOG_LEVEL_WARNING|
|
G_LOG_LEVEL_MASK | G_LOG_LEVEL_WARNING|
|
||||||
G_LOG_FLAG_FATAL| G_LOG_FLAG_RECURSION,
|
G_LOG_FLAG_FATAL| G_LOG_FLAG_RECURSION,
|
||||||
(GLogFunc)black_hole, NULL);
|
(GLogFunc)black_hole, NULL);
|
||||||
|
|
||||||
|
DBPATH = fill_database ();
|
||||||
rv = g_test_run ();
|
rv = g_test_run ();
|
||||||
|
g_free (DBPATH);
|
||||||
|
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user