lib: add unit tests for message priority / flags
We already had _compile-time_ tests; but for coverage it's useful to make those available as runtime-tests, too.
This commit is contained in:
@ -53,6 +53,17 @@ validate_message_info_flags()
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* tests... also build as runtime-tests, so we can get coverage info
|
||||
*/
|
||||
#ifdef BUILD_TESTS
|
||||
#define static_assert g_assert_true
|
||||
#endif /*BUILD_TESTS*/
|
||||
|
||||
[[maybe_unused]] static void
|
||||
test_basic()
|
||||
{
|
||||
static_assert(AllMessageFlagInfos.size() ==
|
||||
__builtin_ctz(static_cast<unsigned>(MessageFlags::_final_)));
|
||||
static_assert(validate_message_info_flags());
|
||||
@ -60,12 +71,15 @@ static_assert(validate_message_info_flags());
|
||||
static_assert(!!message_flag_info(MessageFlags::Encrypted));
|
||||
static_assert(!message_flag_info(MessageFlags::None));
|
||||
static_assert(!message_flag_info(static_cast<MessageFlags>(0)));
|
||||
static_assert(!message_flag_info(static_cast<MessageFlags>(1<<AllMessageFlagInfos.size())),
|
||||
"should be invalid");
|
||||
static_assert(!message_flag_info(static_cast<MessageFlags>(1<<AllMessageFlagInfos.size())));
|
||||
}
|
||||
|
||||
/*
|
||||
* message_flag_info
|
||||
*/
|
||||
[[maybe_unused]] static void
|
||||
test_message_flag_info()
|
||||
{
|
||||
static_assert(message_flag_info('D')->flag == MessageFlags::Draft);
|
||||
static_assert(message_flag_info('l')->flag == MessageFlags::MailingList);
|
||||
static_assert(!message_flag_info('q'));
|
||||
@ -77,10 +91,14 @@ static_assert(!message_flag_info("fnorb"));
|
||||
|
||||
static_assert(message_flag_info('D')->shortcut_lower() == 'd');
|
||||
static_assert(message_flag_info('u')->shortcut_lower() == 'u');
|
||||
}
|
||||
|
||||
/*
|
||||
* message_flags_from_expr
|
||||
*/
|
||||
[[maybe_unused]] static void
|
||||
test_message_flags_from_expr()
|
||||
{
|
||||
static_assert(message_flags_from_absolute_expr("SRP").value() ==
|
||||
(MessageFlags::Seen | MessageFlags::Replied | MessageFlags::Passed));
|
||||
static_assert(message_flags_from_absolute_expr("Faul").value() ==
|
||||
@ -96,10 +114,15 @@ static_assert(message_flags_from_absolute_expr("DFPNxulabcdef", true/*ignore inv
|
||||
MessageFlags::New | MessageFlags::Encrypted |
|
||||
MessageFlags::Unread | MessageFlags::MailingList |
|
||||
MessageFlags::HasAttachment));
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* message_flags_from_delta_expr
|
||||
*/
|
||||
[[maybe_unused]] static void
|
||||
test_message_flags_from_delta_expr()
|
||||
{
|
||||
static_assert(message_flags_from_delta_expr(
|
||||
"+S-u-N", MessageFlags::New|MessageFlags::Unread).value() ==
|
||||
MessageFlags::Seen);
|
||||
@ -112,11 +135,36 @@ static_assert(message_flags_from_delta_expr("+R+P-B", MessageFlags::Seen, true)
|
||||
(MessageFlags::Replied|MessageFlags::Passed|MessageFlags::Seen));
|
||||
static_assert(message_flags_from_delta_expr("+F+T-S", MessageFlags::None, true).value() ==
|
||||
(MessageFlags::Flagged|MessageFlags::Trashed));
|
||||
}
|
||||
|
||||
/*
|
||||
* message_flags_filter
|
||||
*/
|
||||
[[maybe_unused]] static void
|
||||
test_message_flags_filter()
|
||||
{
|
||||
static_assert(message_flags_filter(message_flags_from_absolute_expr(
|
||||
"DFPNxulabcdef", true/*ignore invalid*/).value(),
|
||||
MessageFlagCategory::Mailfile) ==
|
||||
(MessageFlags::Draft|MessageFlags::Flagged|MessageFlags::Passed));
|
||||
}
|
||||
|
||||
|
||||
#ifdef BUILD_TESTS
|
||||
int
|
||||
main(int argc, char* argv[])
|
||||
{
|
||||
g_test_init(&argc, &argv, NULL);
|
||||
|
||||
g_test_add_func("/message/flags/basic", test_basic);
|
||||
g_test_add_func("/message/flags/flag-info", test_message_flag_info);
|
||||
g_test_add_func("/message/flags/flags-from-absolute-expr",
|
||||
test_message_flags_from_expr);
|
||||
g_test_add_func("/message/flags/flags-from-delta-expr",
|
||||
test_message_flags_from_delta_expr);
|
||||
g_test_add_func("/message/flags/flags-filter",
|
||||
test_message_flags_filter);
|
||||
|
||||
return g_test_run();
|
||||
}
|
||||
#endif /*BUILD_TESTS*/
|
||||
|
||||
@ -30,19 +30,53 @@ Mu::to_string(MessagePriority prio)
|
||||
return std::string{message_priority_name(prio)};
|
||||
}
|
||||
|
||||
/*
|
||||
* tests... also build as runtime-tests, so we can get coverage info
|
||||
*/
|
||||
#ifdef BUILD_TESTS
|
||||
#include <glib.h>
|
||||
#define static_assert g_assert_true
|
||||
#endif /*BUILD_TESTS*/
|
||||
|
||||
[[maybe_unused]] static void
|
||||
test_priority_to_char()
|
||||
{
|
||||
static_assert(to_char(MessagePriority::Low) == 'l');
|
||||
static_assert(to_char(MessagePriority::Normal) == 'n');
|
||||
static_assert(to_char(MessagePriority::High) == 'h');
|
||||
}
|
||||
|
||||
[[maybe_unused]] static void
|
||||
test_priority_from_char()
|
||||
{
|
||||
static_assert(message_priority_from_char('l') == MessagePriority::Low);
|
||||
static_assert(message_priority_from_char('n') == MessagePriority::Normal);
|
||||
static_assert(message_priority_from_char('h') == MessagePriority::High);
|
||||
static_assert(message_priority_from_char('x') == MessagePriority::Normal);
|
||||
}
|
||||
|
||||
[[maybe_unused]] static void
|
||||
test_priority_name()
|
||||
{
|
||||
static_assert(message_priority_name(MessagePriority::Low) == "low");
|
||||
static_assert(message_priority_name(MessagePriority::Normal) == "normal");
|
||||
static_assert(message_priority_name(MessagePriority::High) == "high");
|
||||
}
|
||||
|
||||
|
||||
#ifdef BUILD_TESTS
|
||||
int
|
||||
main(int argc, char* argv[])
|
||||
{
|
||||
g_test_init(&argc, &argv, NULL);
|
||||
|
||||
g_test_add_func("/message/priority/to-char", test_priority_to_char);
|
||||
g_test_add_func("/message/priority/from-char", test_priority_from_char);
|
||||
g_test_add_func("/message/priority/name", test_priority_name);
|
||||
|
||||
return g_test_run();
|
||||
}
|
||||
#endif /*BUILD_TESTS*/
|
||||
|
||||
|
||||
#endif /* MU_MESSAGE_PRIORITY_CC__ */
|
||||
|
||||
@ -70,6 +70,23 @@ test('test-message-contact',
|
||||
dependencies: [glib_dep, gmime_dep, lib_mu_dep,
|
||||
lib_test_mu_common_dep]))
|
||||
|
||||
|
||||
test('test-message-flags',
|
||||
executable('test-message-flags',
|
||||
'../mu-message-flags.cc',
|
||||
install: false,
|
||||
cpp_args: ['-DBUILD_TESTS'],
|
||||
dependencies: [glib_dep, gmime_dep, lib_mu_dep,
|
||||
lib_test_mu_common_dep]))
|
||||
test('test-message-priority',
|
||||
executable('test-message-priority',
|
||||
'../mu-message-priority.cc',
|
||||
install: false,
|
||||
cpp_args: ['-DBUILD_TESTS'],
|
||||
dependencies: [glib_dep, gmime_dep, lib_mu_dep,
|
||||
lib_test_mu_common_dep]))
|
||||
|
||||
|
||||
test('test-parser',
|
||||
executable('test-parser',
|
||||
'test-parser.cc',
|
||||
|
||||
Reference in New Issue
Block a user