mirror of https://github.com/djcb/mu.git
mu: add "unit" tests for 'mu add'
This commit is contained in:
parent
cc65b8b401
commit
a32b924692
|
@ -37,4 +37,16 @@ mu = executable(
|
||||||
cpp_args: ['-DMU_SCRIPTS_DIR="'+ join_paths(datadir, 'mu', 'scripts') + '"'],
|
cpp_args: ['-DMU_SCRIPTS_DIR="'+ join_paths(datadir, 'mu', 'scripts') + '"'],
|
||||||
install: true)
|
install: true)
|
||||||
|
|
||||||
|
#
|
||||||
|
# tests
|
||||||
|
#
|
||||||
|
|
||||||
|
test('test-cmd-add',
|
||||||
|
executable('test-cmd-add',
|
||||||
|
'mu-cmd-add.cc',
|
||||||
|
install: false,
|
||||||
|
cpp_args: ['-DBUILD_TESTS'],
|
||||||
|
dependencies: [glib_dep, lib_mu_dep]))
|
||||||
|
|
||||||
|
|
||||||
subdir('tests')
|
subdir('tests')
|
||||||
|
|
105
mu/mu-cmd-add.cc
105
mu/mu-cmd-add.cc
|
@ -35,3 +35,108 @@ Mu::mu_cmd_add(Mu::Store& store, const Options& opts)
|
||||||
|
|
||||||
return Ok();
|
return Ok();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef BUILD_TESTS
|
||||||
|
/*
|
||||||
|
* Tests.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "utils/mu-test-utils.hh"
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_add_ok()
|
||||||
|
{
|
||||||
|
auto testhome{unwrap(make_temp_dir())};
|
||||||
|
auto dbpath{runtime_path(RuntimePath::XapianDb, testhome)};
|
||||||
|
|
||||||
|
{
|
||||||
|
unwrap(Store::make_new(dbpath, MU_TESTMAILDIR));
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
auto res = run_mu_command(
|
||||||
|
mu_format("add --muhome={} {}",
|
||||||
|
testhome,
|
||||||
|
MU_TESTMAILDIR "/cur/1220863042.12663_1.mindcrime!2,S"));
|
||||||
|
assert_valid_result(res);
|
||||||
|
g_assert_cmpuint(*res,==,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
auto&& store = Store::make(dbpath);
|
||||||
|
assert_valid_result(store);
|
||||||
|
g_assert_cmpuint(store->size(),==,1);
|
||||||
|
}
|
||||||
|
|
||||||
|
{ // re-add the same
|
||||||
|
auto res = run_mu_command(
|
||||||
|
mu_format("add --muhome={} {}",
|
||||||
|
testhome,
|
||||||
|
MU_TESTMAILDIR "/cur/1220863042.12663_1.mindcrime!2,S"));
|
||||||
|
assert_valid_result(res);
|
||||||
|
g_assert_cmpuint(*res,==,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
auto&& store = Store::make(dbpath);
|
||||||
|
assert_valid_result(store);
|
||||||
|
g_assert_cmpuint(store->size(),==,1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
remove_directory(testhome);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_add_fail()
|
||||||
|
{
|
||||||
|
auto testhome{unwrap(make_temp_dir())};
|
||||||
|
auto dbpath{runtime_path(RuntimePath::XapianDb, testhome)};
|
||||||
|
|
||||||
|
{
|
||||||
|
unwrap(Store::make_new(dbpath, MU_TESTMAILDIR2));
|
||||||
|
}
|
||||||
|
|
||||||
|
{ // wrong maildir
|
||||||
|
auto res = run_mu_command(
|
||||||
|
mu_format("add --muhome={} {}",
|
||||||
|
testhome,
|
||||||
|
MU_TESTMAILDIR "/cur/1220863042.12663_1.mindcrime!2,S"));
|
||||||
|
assert_valid_result(res);
|
||||||
|
g_assert_cmpuint(*res,!=,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
{ // non-existent
|
||||||
|
auto res = run_mu_command(
|
||||||
|
mu_format("add --muhome={} {}",
|
||||||
|
testhome, "/foo/bar/non-existent"));
|
||||||
|
assert_valid_result(res);
|
||||||
|
g_assert_cmpuint(*res,!=,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
remove_directory(testhome);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
main(int argc, char* argv[]) try {
|
||||||
|
|
||||||
|
mu_test_init(&argc, &argv);
|
||||||
|
|
||||||
|
g_test_add_func("/cmd/add/ok", test_add_ok);
|
||||||
|
g_test_add_func("/cmd/add/fail", test_add_fail);
|
||||||
|
|
||||||
|
return g_test_run();
|
||||||
|
|
||||||
|
} catch (const Error& e) {
|
||||||
|
mu_printerrln("{}", e.what());
|
||||||
|
return 1;
|
||||||
|
} catch (...) {
|
||||||
|
mu_printerrln("caught exception");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
#endif /*BUILD_TESTS*/
|
||||||
|
|
Loading…
Reference in New Issue