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 / sessions.c (50acd32f82fe00502b8e8fbda68c584959bcd38a) (10KiB) (mode 100644) [raw]
#include <stic.h>

#include <stdio.h> /* rename() */

#include <test-utils.h>

#include "../../src/cfg/config.h"
#include "../../src/cfg/info.h"
#include "../../src/utils/hist.h"
#include "../../src/flist_hist.h"
#include "../../src/status.h"

SETUP_ONCE()
{
	make_abs_path(cfg.config_dir, sizeof(cfg.config_dir), SANDBOX_PATH, "", NULL);
}

TEARDOWN_ONCE()
{
	cfg.config_dir[0] = '\0';
}

TEARDOWN()
{
	(void)sessions_stop();
	histories_init(0);
	cfg.session_options = 0;
	cfg.vifm_info = 0;
}

TEST(not_in_a_session_initially)
{
	assert_string_equal("", sessions_current());
}

TEST(can_create_new_session)
{
	assert_success(sessions_create("session"));
	assert_string_equal("session", sessions_current());
}

TEST(cannot_create_same_session_second_time)
{
	assert_success(sessions_create("session"));
	assert_string_equal("session", sessions_current());

	assert_failure(sessions_create("session"));
	assert_string_equal("session", sessions_current());
}

TEST(cannot_create_existing_session)
{
	create_dir(SANDBOX_PATH "/sessions");
	create_file(SANDBOX_PATH "/sessions/session.json");

	assert_failure(sessions_create("session"));

	remove_file(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
}

TEST(cannot_stop_session_when_there_is_none)
{
	assert_string_equal("", sessions_current());
	assert_failure(sessions_stop());
	assert_string_equal("", sessions_current());
}

TEST(can_stop_session)
{
	assert_success(sessions_create("session"));
	assert_string_equal("session", sessions_current());

	assert_success(sessions_stop());
	assert_string_equal("", sessions_current());
}

TEST(session_is_store_as_part_of_state)
{
	create_dir(SANDBOX_PATH "/sessions");

	cfg.session_options = VINFO_CHISTORY;
	assert_success(sessions_create("session"));
	state_store();

	remove_file(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
	remove_file(SANDBOX_PATH "/vifminfo.json");
}

TEST(session_is_not_stored_for_empty_session_options)
{
	assert_success(sessions_create("session"));
	state_store();

	no_remove_dir(SANDBOX_PATH "/sessions");
	remove_file(SANDBOX_PATH "/vifminfo.json");
}

TEST(session_directory_is_created_on_storing)
{
	cfg.session_options = VINFO_CHISTORY;
	assert_success(sessions_create("session"));
	state_store();

	remove_file(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
	remove_file(SANDBOX_PATH "/vifminfo.json");
}

TEST(session_can_be_loaded)
{
	histories_init(10);
	cfg.session_options = VINFO_CHISTORY;
	assert_success(sessions_create("session"));

	hist_add(&curr_stats.cmd_hist, "command0", 0);
	hist_add(&curr_stats.cmd_hist, "command2", 2);

	state_store();

	histories_init(10);
	assert_success(sessions_load("session"));

	assert_int_equal(2, curr_stats.cmd_hist.size);

	assert_string_equal("command2", curr_stats.cmd_hist.items[0].text);
	assert_int_equal(2, curr_stats.cmd_hist.items[0].timestamp);
	assert_string_equal("command0", curr_stats.cmd_hist.items[1].text);
	assert_int_equal(0, curr_stats.cmd_hist.items[1].timestamp);

	remove_file(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
	remove_file(SANDBOX_PATH "/vifminfo.json");

	histories_init(0);
}

TEST(loading_nonexisting_session_just_loads_vifminfo)
{
	histories_init(10);
	cfg.vifm_info = VINFO_CHISTORY;

	hist_add(&curr_stats.cmd_hist, "command0", 0);
	hist_add(&curr_stats.cmd_hist, "command2", 2);

	state_store();

	histories_init(10);
	assert_failure(sessions_load("session"));

	assert_int_equal(2, curr_stats.cmd_hist.size);

	assert_string_equal("command2", curr_stats.cmd_hist.items[0].text);
	assert_int_equal(2, curr_stats.cmd_hist.items[0].timestamp);
	assert_string_equal("command0", curr_stats.cmd_hist.items[1].text);
	assert_int_equal(0, curr_stats.cmd_hist.items[1].timestamp);

	remove_file(SANDBOX_PATH "/vifminfo.json");

	histories_init(0);
}

TEST(session_is_merged_on_storing)
{
	histories_init(10);
	cfg.session_options = VINFO_CHISTORY;
	assert_success(sessions_create("session"));

	hist_add(&curr_stats.cmd_hist, "command0", 0);
	hist_add(&curr_stats.cmd_hist, "command2", 2);

	state_store();

	histories_init(10);
	hist_add(&curr_stats.cmd_hist, "command1", 1);
	hist_add(&curr_stats.cmd_hist, "command3", 3);

	/* Second time, touched session file, merging is necessary. */
	reset_timestamp(SANDBOX_PATH "/sessions/session.json");
	state_store();

	histories_init(10);
	assert_success(sessions_load("session"));

	assert_int_equal(4, curr_stats.cmd_hist.size);

	assert_string_equal("command3", curr_stats.cmd_hist.items[0].text);
	assert_int_equal(3, curr_stats.cmd_hist.items[0].timestamp);
	assert_string_equal("command2", curr_stats.cmd_hist.items[1].text);
	assert_int_equal(2, curr_stats.cmd_hist.items[1].timestamp);
	assert_string_equal("command1", curr_stats.cmd_hist.items[2].text);
	assert_int_equal(1, curr_stats.cmd_hist.items[2].timestamp);
	assert_string_equal("command0", curr_stats.cmd_hist.items[3].text);
	assert_int_equal(0, curr_stats.cmd_hist.items[3].timestamp);

	remove_file(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
	remove_file(SANDBOX_PATH "/vifminfo.json");
}

TEST(session_is_merged_after_switching)
{
	histories_init(10);
	cfg.session_options = VINFO_CHISTORY;
	assert_success(sessions_create("session-a"));

	hist_add(&curr_stats.cmd_hist, "command0", 0);
	hist_add(&curr_stats.cmd_hist, "command2", 2);

	state_store();
	assert_success(sessions_create("session-b"));

	assert_success(rename(SANDBOX_PATH "/sessions/session-a.json",
			SANDBOX_PATH "/sessions/session-b.json"));

	histories_init(10);
	hist_add(&curr_stats.cmd_hist, "command1", 1);
	hist_add(&curr_stats.cmd_hist, "command3", 3);

	state_store();

	histories_init(10);
	assert_success(sessions_load("session-b"));

	assert_int_equal(4, curr_stats.cmd_hist.size);

	remove_file(SANDBOX_PATH "/sessions/session-b.json");
	remove_dir(SANDBOX_PATH "/sessions");
	remove_file(SANDBOX_PATH "/vifminfo.json");
}

TEST(session_histories_have_priority_over_vifminfo)
{
	cfg.vifm_info = VINFO_CHISTORY;
	cfg.session_options = VINFO_CHISTORY;

	histories_init(10);
	assert_success(sessions_create("session-a"));
	hist_add(&curr_stats.cmd_hist, "command0", 0);
	hist_add(&curr_stats.cmd_hist, "command2", 2);

	state_store();

	histories_init(10);
	assert_success(sessions_create("session-b"));
	hist_add(&curr_stats.cmd_hist, "command1", 1);
	hist_add(&curr_stats.cmd_hist, "command3", 3);

	state_store();

	histories_init(10);
	assert_success(sessions_load("session-a"));

	assert_int_equal(4, curr_stats.cmd_hist.size);

	assert_string_equal("command2", curr_stats.cmd_hist.items[0].text);
	assert_int_equal(2, curr_stats.cmd_hist.items[0].timestamp);
	assert_string_equal("command0", curr_stats.cmd_hist.items[1].text);
	assert_int_equal(0, curr_stats.cmd_hist.items[1].timestamp);
	assert_string_equal("command3", curr_stats.cmd_hist.items[2].text);
	assert_int_equal(3, curr_stats.cmd_hist.items[2].timestamp);
	assert_string_equal("command1", curr_stats.cmd_hist.items[3].text);
	assert_int_equal(1, curr_stats.cmd_hist.items[3].timestamp);

	remove_file(SANDBOX_PATH "/sessions/session-a.json");
	remove_file(SANDBOX_PATH "/sessions/session-b.json");
	remove_dir(SANDBOX_PATH "/sessions");
	remove_file(SANDBOX_PATH "/vifminfo.json");
}

TEST(session_dhistory_has_priority_over_vifminfo)
{
	cfg.vifm_info = VINFO_DHISTORY;
	cfg.session_options = VINFO_DHISTORY;

	histories_init(10);
	assert_success(sessions_create("session-a"));
	flist_hist_setup(&lwin, "/dir1", "file1", 1, 1);
	flist_hist_setup(&lwin, "/dir2", "file2", 2, 2);

	state_store();

	histories_init(10);
	assert_success(sessions_create("session-b"));
	flist_hist_setup(&lwin, "/dir3", "file3", 3, 3);
	flist_hist_setup(&lwin, "/dir4", "file4", 4, 4);

	state_store();

	histories_init(10);
	assert_success(sessions_load("session-a"));

	assert_int_equal(3, lwin.history_pos);
	assert_int_equal(4, lwin.history_num);

	assert_string_equal("/dir3", lwin.history[0].dir);
	assert_string_equal("file3", lwin.history[0].file);
	assert_int_equal(3, lwin.history[0].timestamp);
	assert_int_equal(3, lwin.history[0].rel_pos);
	assert_string_equal("/dir4", lwin.history[1].dir);
	assert_string_equal("file4", lwin.history[1].file);
	assert_int_equal(4, lwin.history[1].timestamp);
	assert_int_equal(4, lwin.history[1].rel_pos);
	assert_string_equal("/dir1", lwin.history[2].dir);
	assert_string_equal("file1", lwin.history[2].file);
	assert_int_equal(1, lwin.history[2].timestamp);
	assert_int_equal(1, lwin.history[2].rel_pos);
	assert_string_equal("/dir2", lwin.history[3].dir);
	assert_string_equal("file2", lwin.history[3].file);
	assert_int_equal(2, lwin.history[3].timestamp);
	assert_int_equal(2, lwin.history[3].rel_pos);

	remove_file(SANDBOX_PATH "/sessions/session-a.json");
	remove_file(SANDBOX_PATH "/sessions/session-b.json");
	remove_dir(SANDBOX_PATH "/sessions");
	remove_file(SANDBOX_PATH "/vifminfo.json");
}

TEST(can_check_for_existing_session)
{
	create_dir(SANDBOX_PATH "/sessions");
	create_file(SANDBOX_PATH "/sessions/session.json");

	assert_true(sessions_exists("session"));

	remove_file(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
}

TEST(can_check_for_nonexisting_session)
{
	create_dir(SANDBOX_PATH "/sessions");

	assert_false(sessions_exists("session"));

	remove_dir(SANDBOX_PATH "/sessions");
}

TEST(directories_are_not_sessions)
{
	create_dir(SANDBOX_PATH "/sessions");
	create_dir(SANDBOX_PATH "/sessions/session.json");

	assert_false(sessions_exists("session"));

	remove_dir(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
}

TEST(can_remove_a_session)
{
	create_dir(SANDBOX_PATH "/sessions");
	create_file(SANDBOX_PATH "/sessions/session.json");

	assert_success(sessions_remove("session"));

	no_remove_file(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
}

TEST(can_remove_nonexistent_session)
{
	assert_failure(sessions_remove("session"));
}

TEST(directories_are_not_considered_on_removal)
{
	create_dir(SANDBOX_PATH "/sessions");
	create_dir(SANDBOX_PATH "/sessions/session.json");

	assert_failure(sessions_remove("session"));

	remove_dir(SANDBOX_PATH "/sessions/session.json");
	remove_dir(SANDBOX_PATH "/sessions");
}

TEST(failure_to_load_a_session_resets_current_one)
{
	assert_success(sessions_create("session"));
	assert_failure(sessions_load("no-such-session"));
	assert_false(sessions_active());
}

/* 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