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 / misc / status.c (335025268e3cff8be049db571983a97b2aa20e81) (4,568B) (mode 100644) [raw]
#include <stic.h>

#include <limits.h> /* INT_MIN */
#include <stdlib.h> /* free() */
#include <string.h> /* strdup() */

#include "../../src/cfg/config.h"
#include "../../src/utils/str.h"
#include "../../src/utils/string_array.h"
#include "../../src/status.h"

SETUP()
{
	update_string(&cfg.shell, "");
	stats_init(&cfg);
}

TEARDOWN()
{
	update_string(&cfg.shell, NULL);
}

TEST(stats_silence_ui_operates_correctly)
{
	assert_false(stats_silenced_ui());
	stats_silence_ui(1);
	assert_true(stats_silenced_ui());
	stats_silence_ui(1);
	assert_true(stats_silenced_ui());
	stats_silence_ui(0);
	assert_true(stats_silenced_ui());
	stats_silence_ui(0);
	assert_false(stats_silenced_ui());
}

TEST(redraw_flag_resets_on_query)
{
	assert_int_equal(UT_NONE, stats_update_fetch());
	stats_redraw_later();
	assert_int_equal(UT_REDRAW, stats_update_fetch());
	assert_int_equal(UT_NONE, stats_update_fetch());
}

TEST(stats_update_term_state_operates_correctly)
{
	assert_int_equal(TS_NORMAL, curr_stats.term_state);
	stats_update_term_state(5, 5);
	assert_int_equal(TS_TOO_SMALL, curr_stats.term_state);
	stats_update_term_state(50, 50);
	assert_int_equal(TS_BACK_TO_NORMAL, curr_stats.term_state);
}

TEST(changing_splitter_position_schedules_redraw)
{
	assert_int_equal(UT_NONE, stats_update_fetch());
	stats_set_splitter_pos(10);
	assert_int_equal(UT_REDRAW, stats_update_fetch());
	stats_set_splitter_pos(10);
	assert_int_equal(UT_NONE, stats_update_fetch());
	stats_set_splitter_pos(-1);
	assert_int_equal(UT_REDRAW, stats_update_fetch());
}

TEST(negative_one_splitter_ratio)
{
	curr_stats.splitter_pos = -1;
	curr_stats.splitter_ratio = 0;

	stats_set_splitter_ratio(-1);

	assert_int_equal(-1, curr_stats.splitter_pos);
	assert_true(curr_stats.splitter_ratio == 0.5);
}

TEST(setting_splitter_ratio_to_half_updates_position_accordingly)
{
	cfg.lines = 20;
	cfg.columns = 20;

	assert_int_equal(UT_NONE, stats_update_fetch());

	stats_set_splitter_pos(5);
	assert_true(curr_stats.splitter_ratio == 0.25);
	assert_int_equal(UT_REDRAW, stats_update_fetch());

	stats_set_splitter_ratio(0.5);
	assert_int_equal(-1, curr_stats.splitter_pos);
	assert_int_equal(UT_REDRAW, stats_update_fetch());

	cfg.lines = INT_MIN;
	cfg.columns = INT_MIN;
}

TEST(setting_splitter_ratio_updates_position_and_schedules_redraw)
{
	cfg.lines = 20;
	cfg.columns = 20;

	assert_int_equal(UT_NONE, stats_update_fetch());
	stats_set_splitter_ratio(0.75);

	assert_int_equal(15, curr_stats.splitter_pos);
	assert_true(curr_stats.splitter_ratio == 0.75);
	assert_int_equal(UT_REDRAW, stats_update_fetch());

	stats_set_splitter_ratio(0.75);
	assert_int_equal(UT_NONE, stats_update_fetch());

	cfg.lines = INT_MIN;
	cfg.columns = INT_MIN;
}

TEST(selhist_missing_entry)
{
	char **paths = NULL;
	int path_count = 0;
	assert_failure(selhist_get("/no/such/path", &paths, &path_count));

	assert_null(paths);
	assert_int_equal(0, path_count);
}

TEST(selhist_present_entry)
{
	char path[] = "/selected/path";
	char *path_list[] = { path };
	selhist_put("/no/such/path", copy_string_array(path_list, 1), 1);

	char **paths = NULL;
	int path_count = 0;
	assert_success(selhist_get("/no/such/path", &paths, &path_count));

	assert_int_equal(1, path_count);
	assert_string_equal("/selected/path", paths[0]);
	free_string_array(paths, path_count);
}

TEST(selhist_updated_entry)
{
	char path_a[] = "/old/selected/path";
	char path_b[] = "/new/selected/path";
	char *path_list[1];

	path_list[0] = path_a;
	selhist_put("/no/such/path", copy_string_array(path_list, 1), 1);

	path_list[0] = path_b;
	selhist_put("/no/such/path", copy_string_array(path_list, 1), 1);

	char **paths;
	int path_count;
	assert_success(selhist_get("/no/such/path", &paths, &path_count));

	assert_int_equal(1, path_count);
	assert_string_equal("/new/selected/path", paths[0]);
	free_string_array(paths, path_count);
}

TEST(selhist_is_mru)
{
	int i;

	for(i = 0; i < 11; ++i)
	{
		char *str = format_str("/path/number/%d", i);
		char *path_list[] = { str };
		selhist_put(str, copy_string_array(path_list, 1), 1);
		free(str);
	}

	for(i = 1; i < 11; ++i)
	{
		char *str = format_str("/path/number/%d", i);

		char **paths;
		int path_count;
		selhist_get(str, &paths, &path_count);

		assert_int_equal(1, path_count);
		assert_string_equal(str, paths[0]);
		free_string_array(paths, path_count);

		free(str);
	}

	char **paths;
	int path_count;
	assert_failure(selhist_get("/path/number/0", &paths, &path_count));
}

/* vim: set tabstop=2 softtabstop=2 shiftwidth=2 noexpandtab cinoptions-=(0 : */
/* vim: set cinoptions+=t0 : */
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