xaizek / vifm (License: GPLv2+) (since 2018-12-07)
Vifm is a file manager with curses interface, which provides Vi[m]-like environment for managing objects within file systems, extended with some useful ideas from mutt.
<root> / tests / utils / matchers.c (8d886da436129fa16da28c073a5a589db026e1f1) (5,769B) (mode 100644) [raw]
#include <stic.h>

#include <stddef.h> /* NULL */
#include <stdlib.h> /* free() */

#include "../../src/utils/matchers.h"
#include "../../src/utils/string_array.h"

TEST(freeing_null_matchers_does_nothing)
{
	matchers_free(NULL);
}

TEST(empty_patterns_are_disallowed)
{
	assert_false(matchers_is_expr("//"));
	assert_false(matchers_is_expr("////iI"));
	assert_false(matchers_is_expr("{}"));
	assert_false(matchers_is_expr("{{}}"));
	assert_false(matchers_is_expr("<>"));
}

TEST(wrong_expr_produces_error)
{
	char *error = NULL;
	assert_null(matchers_alloc("/*/{?}", 0, 1, "", &error));
	assert_non_null(error);
	free(error);
}

TEST(none_matchers_match)
{
	char *error = NULL;
	matchers_t *const ms = matchers_alloc("{[a]}{?}", 0, 1, "", &error);
	assert_string_equal(NULL, error);
	assert_false(matchers_match(ms, "xx"));
	matchers_free(ms);
}

TEST(only_first_matches)
{
	char *error = NULL;
	matchers_t *const ms = matchers_alloc("{ab}{?}", 0, 1, "", &error);
	assert_string_equal(NULL, error);
	assert_false(matchers_match(ms, "ab"));
	matchers_free(ms);
}

TEST(only_second_matches)
{
	char *error = NULL;
	matchers_t *const ms = matchers_alloc("{ab}{?}", 0, 1, "", &error);
	assert_string_equal(NULL, error);
	assert_false(matchers_match(ms, "a"));
	matchers_free(ms);
}

TEST(both_matchers_match)
{
	char *error = NULL;
	matchers_t *const ms = matchers_alloc("{[a]}{?}", 0, 1, "", &error);
	assert_string_equal(NULL, error);
	assert_true(matchers_match(ms, "a"));
	matchers_free(ms);
}

TEST(get_expr_returns_original_expr)
{
	char *error = NULL;
	matchers_t *const ms = matchers_alloc("{[a]}{?}", 0, 1, "", &error);
	assert_string_equal(NULL, error);
	assert_string_equal("{[a]}{?}", matchers_get_expr(ms));
	matchers_free(ms);
}

TEST(empty_input)
{
	char **list;
	int count;

	list = break_into_matchers("", &count, 0);
	assert_int_equal(1, count);
	if(count == 1)
	{
		assert_string_equal("", list[0]);
	}

	free_string_array(list, count);
}

TEST(extra_emark_breaks_everything)
{
	char **list;
	int count;

	list = break_into_matchers("{ng1,ng2}!!{ng3}{{pg1,pg2}}", &count, 0);
	assert_int_equal(1, count);
	if(count == 1)
	{
		assert_string_equal("{ng1,ng2}!!{ng3}{{pg1,pg2}}", list[0]);
	}

	free_string_array(list, count);
}

TEST(globs_are_parsed_well)
{
	char **list;
	int count;

	list = break_into_matchers("{ng1,{ng2}!{ng3}{{pg1,pg2}}!{{pg3}}", &count, 0);
	assert_int_equal(4, count);
	if(count == 4)
	{
		assert_string_equal("{ng1,{ng2}", list[0]);
		assert_string_equal("!{ng3}", list[1]);
		assert_string_equal("{{pg1,pg2}}", list[2]);
		assert_string_equal("!{{pg3}}", list[3]);
	}

	free_string_array(list, count);
}

TEST(regexps_are_parsed_well)
{
	char **list;
	int count;

	list = break_into_matchers("!/nr1//nr2///pr1////pr2//", &count, 0);
	assert_int_equal(4, count);
	if(count == 4)
	{
		assert_string_equal("!/nr1/", list[0]);
		assert_string_equal("/nr2/", list[1]);
		assert_string_equal("//pr1//", list[2]);
		assert_string_equal("//pr2//", list[3]);
	}

	free_string_array(list, count);
}

TEST(regexps_escaping_works)
{
	char **list;
	int count;

	list = break_into_matchers("!/n\\/r1//nr2///p\\/\\/r1////p/r/\\//2//", &count,
			0);
	assert_int_equal(4, count);
	if(count == 4)
	{
		assert_string_equal("!/n\\/r1/", list[0]);
		assert_string_equal("/nr2/", list[1]);
		assert_string_equal("//p\\/\\/r1//", list[2]);
		assert_string_equal("//p/r/\\//2//", list[3]);
	}

	free_string_array(list, count);
}

TEST(regexs_with_correct_flags)
{
	char **list;
	int count;

	list = break_into_matchers("!/nr1/iIiiiII//asdf//iI", &count, 0);
	assert_int_equal(2, count);
	if(count == 2)
	{
		assert_string_equal("!/nr1/iIiiiII", list[0]);
		assert_string_equal("//asdf//iI", list[1]);
	}

	free_string_array(list, count);
}

TEST(regexs_with_incorrect_flags)
{
	char **list;
	int count;

	list = break_into_matchers("//a//!/nr1/a", &count, 0);
	assert_int_equal(1, count);
	if(count == 1)
	{
		assert_string_equal("//a//!/nr1/a", list[0]);
	}

	free_string_array(list, count);
}

TEST(mime_patterns)
{
	char **list;
	int count;

	list = break_into_matchers("<a><<<<>!<b>", &count, 0);
	assert_int_equal(3, count);
	if(count == 3)
	{
		assert_string_equal("<a>", list[0]);
		assert_string_equal("<<<<>", list[1]);
		assert_string_equal("!<b>", list[2]);
	}

	free_string_array(list, count);
}

TEST(matchers_are_cloned)
{
	char *error = NULL;
	matchers_t *ms, *clone;

	assert_non_null(ms = matchers_alloc("{*.ext}/.*/", 0, 1, "", &error));
	assert_null(error);

	assert_non_null(clone = matchers_clone(ms));

	assert_true(matchers_match(ms, "a.ext"));
	assert_false(matchers_match(ms, "a.so"));
	matchers_free(ms);

	assert_true(matchers_match(clone, "a.ext"));
	assert_false(matchers_match(clone, "a.so"));
	matchers_free(clone);
}

TEST(inclusion_check_works)
{
	char *error = NULL;
	matchers_t *ms1, *ms2;

	assert_non_null(
			ms1 = matchers_alloc("<*.cpp,*.c><*.cpp,*.d>", 0, 1, "", &error));
	assert_null(error);
	assert_non_null(ms2 = matchers_alloc("<*.c><*.cpp>", 0, 1, "", &error));
	assert_null(error);

	assert_true(matchers_includes(ms1, ms1));
	assert_true(matchers_includes(ms1, ms2));
	assert_false(matchers_includes(ms2, ms1));

	matchers_free(ms1);
	matchers_free(ms2);
}

TEST(breaking_list_of_lists)
{
	int nmatchers;
	char **const matchers =
		matchers_list("<mime>{*.,ext},/re,gex/,{a,,b,c,,d},{{x,,y}}", &nmatchers);
	if(nmatchers == 4)
	{
		assert_string_equal("<mime>{*.,ext}", matchers[0]);
		assert_string_equal("/re,gex/", matchers[1]);
		assert_string_equal("{a,,b,c,,d}", matchers[2]);
		assert_string_equal("{{x,,y}}", matchers[3]);
	}
	free_string_array(matchers, nmatchers);
}

/* vim: set tabstop=2 softtabstop=2 shiftwidth=2 noexpandtab cinoptions-=(0 : */
/* vim: set cinoptions+=t0 filetype=c : */
Hints

Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"

Clone this repository using HTTP(S):
git clone https://code.reversed.top/user/xaizek/vifm

Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@code.reversed.top/user/xaizek/vifm

You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a pull request:
... clone the repository ...
... make some changes and some commits ...
git push origin master