summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVicent Martí <vicent@github.com>2013-02-22 12:26:01 -0800
committerVicent Martí <vicent@github.com>2013-02-22 12:26:01 -0800
commit68fec637a24fa60497e458155432c76327b60653 (patch)
tree44f5a4089db9752b1062931c681e7e3848e6e11f
parent7beeb3f4206b37981e3c42d25a0a638055c068ed (diff)
parent37d9168608e9d9a5451011e83623a829eb896dd5 (diff)
downloadlibgit2-68fec637a24fa60497e458155432c76327b60653.tar.gz
Merge pull request #1356 from arrbee/fix-directory-as-ignore-file
Do not fail if .gitignore is directory
-rw-r--r--src/attr.c10
-rw-r--r--tests-clar/attr/ignore.c38
2 files changed, 35 insertions, 13 deletions
diff --git a/src/attr.c b/src/attr.c
index a1d9932e9..9c88771e3 100644
--- a/src/attr.c
+++ b/src/attr.c
@@ -278,8 +278,14 @@ static int load_attr_file(
return GIT_ENOTFOUND;
error = git_futils_readbuffer(&content, filename);
- if (error < 0)
- return error;
+ if (error < 0) {
+ /* convert error into ENOTFOUND so failed permissions / invalid
+ * file type don't actually stop the operation in progress.
+ */
+ return GIT_ENOTFOUND;
+
+ /* TODO: once warnings are available, issue a warning callback */
+ }
*data = git_buf_detach(&content);
diff --git a/tests-clar/attr/ignore.c b/tests-clar/attr/ignore.c
index 943eafe69..aa81e9249 100644
--- a/tests-clar/attr/ignore.c
+++ b/tests-clar/attr/ignore.c
@@ -1,32 +1,48 @@
#include "clar_libgit2.h"
+#include "posix.h"
+#include "path.h"
static git_repository *g_repo = NULL;
void test_attr_ignore__initialize(void)
{
- g_repo = cl_git_sandbox_init("attr");
+ g_repo = cl_git_sandbox_init("attr");
}
void test_attr_ignore__cleanup(void)
{
- cl_git_sandbox_cleanup();
- g_repo = NULL;
+ cl_git_sandbox_cleanup();
+ g_repo = NULL;
}
void assert_is_ignored(bool expected, const char *filepath)
{
- int is_ignored;
+ int is_ignored;
- cl_git_pass(git_ignore_path_is_ignored(&is_ignored, g_repo, filepath));
- cl_assert_equal_i(expected, is_ignored == 1);
+ cl_git_pass(git_ignore_path_is_ignored(&is_ignored, g_repo, filepath));
+ cl_assert_equal_i(expected, is_ignored == 1);
}
void test_attr_ignore__honor_temporary_rules(void)
{
- cl_git_rewritefile("attr/.gitignore", "/NewFolder\n/NewFolder/NewFolder");
+ cl_git_rewritefile("attr/.gitignore", "/NewFolder\n/NewFolder/NewFolder");
- assert_is_ignored(false, "File.txt");
- assert_is_ignored(true, "NewFolder");
- assert_is_ignored(true, "NewFolder/NewFolder");
- assert_is_ignored(true, "NewFolder/NewFolder/File.txt");
+ assert_is_ignored(false, "File.txt");
+ assert_is_ignored(true, "NewFolder");
+ assert_is_ignored(true, "NewFolder/NewFolder");
+ assert_is_ignored(true, "NewFolder/NewFolder/File.txt");
+}
+
+void test_attr_ignore__skip_gitignore_directory(void)
+{
+ cl_git_rewritefile("attr/.git/info/exclude", "/NewFolder\n/NewFolder/NewFolder");
+ p_unlink("attr/.gitignore");
+ cl_assert(!git_path_exists("attr/.gitignore"));
+ p_mkdir("attr/.gitignore", 0777);
+ cl_git_mkfile("attr/.gitignore/garbage.txt", "new_file\n");
+
+ assert_is_ignored(false, "File.txt");
+ assert_is_ignored(true, "NewFolder");
+ assert_is_ignored(true, "NewFolder/NewFolder");
+ assert_is_ignored(true, "NewFolder/NewFolder/File.txt");
}