mirror of https://github.com/djcb/mu.git
utils/add: improve unit test coverage
This commit is contained in:
parent
b0dca49dc0
commit
abb0fb4fd5
|
@ -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_);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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*/
|
||||||
|
|
Loading…
Reference in New Issue