|
Packit Service |
20376f |
#include "clar_libgit2.h"
|
|
Packit Service |
20376f |
#include "git2/sys/filter.h"
|
|
Packit Service |
20376f |
#include "buffer.h"
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
static git_repository *g_repo = NULL;
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
void test_filter_crlf__initialize(void)
|
|
Packit Service |
20376f |
{
|
|
Packit Service |
20376f |
g_repo = cl_git_sandbox_init("crlf");
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_mkfile("crlf/.gitattributes",
|
|
Packit Service |
20376f |
"*.txt text\n*.bin binary\n*.crlf text eol=crlf\n*.lf text eol=lf\n");
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_repo_set_bool(g_repo, "core.autocrlf", true);
|
|
Packit Service |
20376f |
}
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
void test_filter_crlf__cleanup(void)
|
|
Packit Service |
20376f |
{
|
|
Packit Service |
20376f |
cl_git_sandbox_cleanup();
|
|
Packit Service |
20376f |
}
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
void test_filter_crlf__to_worktree(void)
|
|
Packit Service |
20376f |
{
|
|
Packit Service |
20376f |
git_filter_list *fl;
|
|
Packit Service |
20376f |
git_filter *crlf;
|
|
Packit Service |
20376f |
git_buf in = { 0 }, out = { 0 };
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_new(
|
|
Packit Service |
20376f |
&fl, g_repo, GIT_FILTER_TO_WORKTREE, 0));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
crlf = git_filter_lookup(GIT_FILTER_CRLF);
|
|
Packit Service |
20376f |
cl_assert(crlf != NULL);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_push(fl, crlf, NULL));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
in.ptr = "Some text\nRight here\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_assert_equal_s("Some text\r\nRight here\r\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
git_filter_list_free(fl);
|
|
Packit Service |
20376f |
git_buf_free(&out;;
|
|
Packit Service |
20376f |
}
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
void test_filter_crlf__to_odb(void)
|
|
Packit Service |
20376f |
{
|
|
Packit Service |
20376f |
git_filter_list *fl;
|
|
Packit Service |
20376f |
git_filter *crlf;
|
|
Packit Service |
20376f |
git_buf in = { 0 }, out = { 0 };
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_new(
|
|
Packit Service |
20376f |
&fl, g_repo, GIT_FILTER_TO_ODB, 0));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
crlf = git_filter_lookup(GIT_FILTER_CRLF);
|
|
Packit Service |
20376f |
cl_assert(crlf != NULL);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_push(fl, crlf, NULL));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
in.ptr = "Some text\r\nRight here\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_assert_equal_s("Some text\nRight here\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
git_filter_list_free(fl);
|
|
Packit Service |
20376f |
git_buf_free(&out;;
|
|
Packit Service |
20376f |
}
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
void test_filter_crlf__with_safecrlf(void)
|
|
Packit Service |
20376f |
{
|
|
Packit Service |
20376f |
git_filter_list *fl;
|
|
Packit Service |
20376f |
git_filter *crlf;
|
|
Packit Service |
20376f |
git_buf in = {0}, out = GIT_BUF_INIT;
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_repo_set_bool(g_repo, "core.safecrlf", true);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_new(
|
|
Packit Service |
20376f |
&fl, g_repo, GIT_FILTER_TO_ODB, 0));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
crlf = git_filter_lookup(GIT_FILTER_CRLF);
|
|
Packit Service |
20376f |
cl_assert(crlf != NULL);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_push(fl, crlf, NULL));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Normalized \r\n succeeds with safecrlf */
|
|
Packit Service |
20376f |
in.ptr = "Normal\r\nCRLF\r\nline-endings.\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_s("Normal\nCRLF\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Mix of line endings fails with safecrlf */
|
|
Packit Service |
20376f |
in.ptr = "Mixed\nup\r\nLF\nand\r\nCRLF\nline-endings.\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_fail(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_i(giterr_last()->klass, GITERR_FILTER);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Normalized \n is reversible, so does not fail with safecrlf */
|
|
Packit Service |
20376f |
in.ptr = "Normal\nLF\nonly\nline-endings.\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_s(in.ptr, out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
git_filter_list_free(fl);
|
|
Packit Service |
20376f |
git_buf_free(&out;;
|
|
Packit Service |
20376f |
}
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
void test_filter_crlf__with_safecrlf_and_unsafe_allowed(void)
|
|
Packit Service |
20376f |
{
|
|
Packit Service |
20376f |
git_filter_list *fl;
|
|
Packit Service |
20376f |
git_filter *crlf;
|
|
Packit Service |
20376f |
git_buf in = {0}, out = GIT_BUF_INIT;
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_repo_set_bool(g_repo, "core.safecrlf", true);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_new(
|
|
Packit Service |
20376f |
&fl, g_repo, GIT_FILTER_TO_ODB, GIT_FILTER_ALLOW_UNSAFE));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
crlf = git_filter_lookup(GIT_FILTER_CRLF);
|
|
Packit Service |
20376f |
cl_assert(crlf != NULL);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_push(fl, crlf, NULL));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Normalized \r\n succeeds with safecrlf */
|
|
Packit Service |
20376f |
in.ptr = "Normal\r\nCRLF\r\nline-endings.\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_s("Normal\nCRLF\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Mix of line endings fails with safecrlf, but allowed to pass */
|
|
Packit Service |
20376f |
in.ptr = "Mixed\nup\r\nLF\nand\r\nCRLF\nline-endings.\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
/* TODO: check for warning */
|
|
Packit Service |
20376f |
cl_assert_equal_s("Mixed\nup\nLF\nand\nCRLF\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Normalized \n fails with safecrlf, but allowed to pass */
|
|
Packit Service |
20376f |
in.ptr = "Normal\nLF\nonly\nline-endings.\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
/* TODO: check for warning */
|
|
Packit Service |
20376f |
cl_assert_equal_s("Normal\nLF\nonly\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
git_filter_list_free(fl);
|
|
Packit Service |
20376f |
git_buf_free(&out;;
|
|
Packit Service |
20376f |
}
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
void test_filter_crlf__no_safecrlf(void)
|
|
Packit Service |
20376f |
{
|
|
Packit Service |
20376f |
git_filter_list *fl;
|
|
Packit Service |
20376f |
git_filter *crlf;
|
|
Packit Service |
20376f |
git_buf in = {0}, out = GIT_BUF_INIT;
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_new(
|
|
Packit Service |
20376f |
&fl, g_repo, GIT_FILTER_TO_ODB, 0));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
crlf = git_filter_lookup(GIT_FILTER_CRLF);
|
|
Packit Service |
20376f |
cl_assert(crlf != NULL);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_push(fl, crlf, NULL));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Normalized \r\n succeeds with safecrlf */
|
|
Packit Service |
20376f |
in.ptr = "Normal\r\nCRLF\r\nline-endings.\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_s("Normal\nCRLF\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Mix of line endings fails with safecrlf */
|
|
Packit Service |
20376f |
in.ptr = "Mixed\nup\r\nLF\nand\r\nCRLF\nline-endings.\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_s("Mixed\nup\nLF\nand\nCRLF\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Normalized \n fails with safecrlf */
|
|
Packit Service |
20376f |
in.ptr = "Normal\nLF\nonly\nline-endings.\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_s("Normal\nLF\nonly\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
git_filter_list_free(fl);
|
|
Packit Service |
20376f |
git_buf_free(&out;;
|
|
Packit Service |
20376f |
}
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
void test_filter_crlf__safecrlf_warn(void)
|
|
Packit Service |
20376f |
{
|
|
Packit Service |
20376f |
git_filter_list *fl;
|
|
Packit Service |
20376f |
git_filter *crlf;
|
|
Packit Service |
20376f |
git_buf in = {0}, out = GIT_BUF_INIT;
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_repo_set_string(g_repo, "core.safecrlf", "warn");
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_new(
|
|
Packit Service |
20376f |
&fl, g_repo, GIT_FILTER_TO_ODB, 0));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
crlf = git_filter_lookup(GIT_FILTER_CRLF);
|
|
Packit Service |
20376f |
cl_assert(crlf != NULL);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_push(fl, crlf, NULL));
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Normalized \r\n succeeds with safecrlf=warn */
|
|
Packit Service |
20376f |
in.ptr = "Normal\r\nCRLF\r\nline-endings.\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_s("Normal\nCRLF\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Mix of line endings succeeds with safecrlf=warn */
|
|
Packit Service |
20376f |
in.ptr = "Mixed\nup\r\nLF\nand\r\nCRLF\nline-endings.\r\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
/* TODO: check for warning */
|
|
Packit Service |
20376f |
cl_assert_equal_s("Mixed\nup\nLF\nand\nCRLF\nline-endings.\n", out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
/* Normalized \n is reversible, so does not fail with safecrlf=warn */
|
|
Packit Service |
20376f |
in.ptr = "Normal\nLF\nonly\nline-endings.\n";
|
|
Packit Service |
20376f |
in.size = strlen(in.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
cl_git_pass(git_filter_list_apply_to_data(&out, fl, &in);;
|
|
Packit Service |
20376f |
cl_assert_equal_s(in.ptr, out.ptr);
|
|
Packit Service |
20376f |
|
|
Packit Service |
20376f |
git_filter_list_free(fl);
|
|
Packit Service |
20376f |
git_buf_free(&out;;
|
|
Packit Service |
20376f |
}
|