utils/add: improve unit test coverage

This commit is contained in:
Dirk-Jan C. Binnema 2023-09-24 15:49:58 +03:00
parent b0dca49dc0
commit abb0fb4fd5
4 changed files with 36 additions and 19 deletions

View File

@ -36,11 +36,13 @@
using namespace Mu; using namespace Mu;
/* LCOV_EXCL_START*/
bool bool
Mu::mu_test_mu_hacker() Mu::mu_test_mu_hacker()
{ {
return !!g_getenv("MU_HACKER"); return !!g_getenv("MU_HACKER");
} }
/* LCOV_EXCL_STOP*/
const char* const char*
@ -65,8 +67,10 @@ Mu::set_en_us_utf8_locale()
setlocale(LC_ALL, "en_US.UTF-8"); setlocale(LC_ALL, "en_US.UTF-8");
if (strcmp(nl_langinfo(CODESET), "UTF-8") != 0) { if (strcmp(nl_langinfo(CODESET), "UTF-8") != 0) {
/* LCOV_EXCL_START*/
mu_println("Note: Unit tests require the en_US.utf8 locale. " mu_println("Note: Unit tests require the en_US.utf8 locale. "
"Ignoring test cases."); "Ignoring test cases.");
/* LCOV_EXCL_STOP*/
return false; return false;
} }
@ -130,13 +134,10 @@ Mu::TempDir::~TempDir()
return; return;
} }
/* ugly */ if (auto&& res{run_command0({RM_PROGRAM, "-fr", path_})}; !res) {
GError *err{}; /* LCOV_EXCL_START*/
const auto cmd{mu_format("/bin/rm -rf '{}'", path_)}; mu_warning("error removing {}: {}", path_, format_as(res.error()));
if (!g_spawn_command_line_sync(cmd.c_str(), NULL, /* LCOV_EXCL_STOP*/
NULL, NULL, &err)) {
mu_warning("error: {}", err ? err->message : "?");
g_clear_error(&err);
} else } else
mu_debug("removed '{}'", path_); mu_debug("removed '{}'", path_);
} }

View File

@ -158,10 +158,13 @@ Mu::runtime_path(Mu::RuntimePath path, const std::string& muhome)
return mu_config; return mu_config;
case Mu::RuntimePath::Scripts: case Mu::RuntimePath::Scripts:
return join_paths(mu_config, "scripts"); return join_paths(mu_config, "scripts");
/*LCOV_EXCL_START*/
default: default:
throw std::logic_error("unknown path"); throw std::logic_error("unknown path");
/*LCOV_EXCL_STOP*/
} }
} }
/* LCOV_EXCL_START*/ /* LCOV_EXCL_START*/
static gpointer static gpointer
cancel_wait(gpointer data) cancel_wait(gpointer data)
@ -212,6 +215,7 @@ Mu::g_cancellable_new_with_timeout(guint timeout)
} }
/* LCOV_EXCL_STOP*/ /* LCOV_EXCL_STOP*/
/* LCOV_EXCL_START*/
Result<std::string> Result<std::string>
Mu::read_from_stdin() Mu::read_from_stdin()
{ {
@ -234,13 +238,14 @@ Mu::read_from_stdin()
G_MEMORY_OUTPUT_STREAM(outmem))), G_MEMORY_OUTPUT_STREAM(outmem))),
g_memory_output_stream_get_size(G_MEMORY_OUTPUT_STREAM(outmem))}); g_memory_output_stream_get_size(G_MEMORY_OUTPUT_STREAM(outmem))});
} }
/* LCOV_EXCL_STOP*/
/* /*
* Set the child to a group leader to avoid being killed when the * Set the child to a group leader to avoid being killed when the
* parent group is killed. * parent group is killed.
*/ */
/*LCOV_EXCL_START*/
static void static void
maybe_setsid (G_GNUC_UNUSED gpointer user_data) maybe_setsid (G_GNUC_UNUSED gpointer user_data)
{ {
@ -248,6 +253,7 @@ maybe_setsid (G_GNUC_UNUSED gpointer user_data)
setsid(); setsid();
#endif /*HAVE_SETSID*/ #endif /*HAVE_SETSID*/
} }
/*LCOV_EXCL_STOP*/
Result<Mu::CommandOutput> Result<Mu::CommandOutput>
Mu::run_command(std::initializer_list<std::string> args, bool try_setsid) Mu::run_command(std::initializer_list<std::string> args, bool try_setsid)
@ -451,7 +457,20 @@ test_join_paths()
assert_equal(join_paths("/a/b///c/d//", "e"), "/a/b/c/d/e"); assert_equal(join_paths("/a/b///c/d//", "e"), "/a/b/c/d/e");
} }
static void
test_runtime_paths()
{
TempDir tdir;
assert_equal(runtime_path(RuntimePath::Cache, tdir.path()), tdir.path());
assert_equal(runtime_path(RuntimePath::XapianDb, tdir.path()),
join_paths(tdir.path(), "xapian"));
assert_equal(runtime_path(RuntimePath::Bookmarks, tdir.path()),
join_paths(tdir.path(), "bookmarks"));
assert_equal(runtime_path(RuntimePath::Config, tdir.path()), tdir.path());
assert_equal(runtime_path(RuntimePath::Scripts, tdir.path()),
join_paths(tdir.path(), "scripts"));
}
int int
main(int argc, char* argv[]) main(int argc, char* argv[])
@ -473,6 +492,8 @@ main(int argc, char* argv[])
test_program_in_path); test_program_in_path);
g_test_add_func("/utils/join-paths", g_test_add_func("/utils/join-paths",
test_join_paths); test_join_paths);
g_test_add_func("/utils/runtime-paths",
test_runtime_paths);
return g_test_run(); return g_test_run();
} }

View File

@ -47,7 +47,6 @@
namespace Mu { namespace Mu {
/* /*
* Separator characters used in various places; importantly, * Separator characters used in various places; importantly,
* they are not used in UTF-8 * they are not used in UTF-8
@ -55,7 +54,6 @@ namespace Mu {
constexpr const auto SepaChar1 = '\xfe'; constexpr const auto SepaChar1 = '\xfe';
constexpr const auto SepaChar2 = '\xff'; constexpr const auto SepaChar2 = '\xff';
/* /*
* Logging/printing/formatting functions connect libfmt with the Glib logging * Logging/printing/formatting functions connect libfmt with the Glib logging
* system. We wrap so perhaps at some point (C++23?) we can use std:: instead. * system. We wrap so perhaps at some point (C++23?) we can use std:: instead.
@ -88,6 +86,7 @@ void mu_warning(fmt::format_string<T...> frm, T&&... args) noexcept {
g_log("mu", G_LOG_LEVEL_WARNING, "%s", g_log("mu", G_LOG_LEVEL_WARNING, "%s",
fmt::format(frm, std::forward<T>(args)...).c_str()); fmt::format(frm, std::forward<T>(args)...).c_str());
} }
/* LCOV_EXCL_START*/
template<typename...T> template<typename...T>
void mu_critical(fmt::format_string<T...> frm, T&&... args) noexcept { void mu_critical(fmt::format_string<T...> frm, T&&... args) noexcept {
g_log("mu", G_LOG_LEVEL_CRITICAL, "%s", g_log("mu", G_LOG_LEVEL_CRITICAL, "%s",
@ -98,6 +97,7 @@ void mu_error(fmt::format_string<T...> frm, T&&... args) noexcept {
g_log("mu", G_LOG_LEVEL_ERROR, "%s", g_log("mu", G_LOG_LEVEL_ERROR, "%s",
fmt::format(frm, std::forward<T>(args)...).c_str()); fmt::format(frm, std::forward<T>(args)...).c_str());
} }
/* LCOV_EXCL_STOP*/
/* /*
* Printing; add our wrapper functions, one day we might be able to use std:: * Printing; add our wrapper functions, one day we might be able to use std::
@ -355,8 +355,10 @@ struct StopWatch {
StopWatch(const std::string name) : start_{Clock::now()}, name_{name} {} StopWatch(const std::string name) : start_{Clock::now()}, name_{name} {}
~StopWatch() { ~StopWatch() {
const auto us{static_cast<double>(to_us(Clock::now() - start_))}; const auto us{static_cast<double>(to_us(Clock::now() - start_))};
/* LCOV_EXCL_START*/
if (us > 2000000) if (us > 2000000)
mu_debug("sw: {}: finished after {:.1f} s", name_, us / 1000000); mu_debug("sw: {}: finished after {:.1f} s", name_, us / 1000000);
/* LCOV_EXCL_STOP*/
else if (us > 2000) else if (us > 2000)
mu_debug("sw: {}: finished after {:.1f} ms", name_, us / 1000); mu_debug("sw: {}: finished after {:.1f} ms", name_, us / 1000);
else else

View File

@ -113,20 +113,13 @@ test_add_fail()
int int
main(int argc, char* argv[]) try { main(int argc, char* argv[])
{
mu_test_init(&argc, &argv); mu_test_init(&argc, &argv);
g_test_add_func("/cmd/add/ok", test_add_ok); g_test_add_func("/cmd/add/ok", test_add_ok);
g_test_add_func("/cmd/add/fail", test_add_fail); g_test_add_func("/cmd/add/fail", test_add_fail);
return g_test_run(); return g_test_run();
} catch (const Error& e) {
mu_printerrln("{}", e.what());
return 1;
} catch (...) {
mu_printerrln("caught exception");
return 1;
} }
#endif /*BUILD_TESTS*/ #endif /*BUILD_TESTS*/