diff options
author | Vicent Martà <vicent@github.com> | 2012-11-18 17:19:20 -0800 |
---|---|---|
committer | Vicent Martà <vicent@github.com> | 2012-11-18 17:19:20 -0800 |
commit | 560cc1e1ed0fb29679c32434490446bb6fd5dc17 (patch) | |
tree | 66b2cef0220d13f6543f1b0e3a2d56e42e759f43 /tests-clar | |
parent | 629c08293051e9828f2ca3517d2659728647c2cd (diff) | |
parent | 1876360f813da8e6aba763baded5dcb004d9999c (diff) | |
download | libgit2-560cc1e1ed0fb29679c32434490446bb6fd5dc17.tar.gz |
Merge pull request #1084 from libgit2/filename-validation
Filename validation
Diffstat (limited to 'tests-clar')
-rw-r--r-- | tests-clar/index/tests.c | 27 | ||||
-rw-r--r-- | tests-clar/object/tree/write.c | 6 |
2 files changed, 33 insertions, 0 deletions
diff --git a/tests-clar/index/tests.c b/tests-clar/index/tests.c index d3f6f2582..3b71b704d 100644 --- a/tests-clar/index/tests.c +++ b/tests-clar/index/tests.c @@ -261,3 +261,30 @@ void test_index_tests__add_from_workdir_to_a_bare_repository_returns_EBAREPO(voi git_index_free(index); git_repository_free(bare_repo); } + +/* Test that writing an invalid filename fails */ +void test_index_tests__write_invalid_filename(void) +{ + git_repository *repo; + git_index *index; + git_oid expected; + + p_mkdir("read_tree", 0700); + + cl_git_pass(git_repository_init(&repo, "./read_tree", 0)); + cl_git_pass(git_repository_index(&index, repo)); + + cl_assert(git_index_entrycount(index) == 0); + + cl_git_mkfile("./read_tree/.git/hello", NULL); + + cl_git_pass(git_index_add_from_workdir(index, ".git/hello")); + + /* write-tree */ + cl_git_fail(git_index_write_tree(&expected, index)); + + git_index_free(index); + git_repository_free(repo); + + cl_fixture_cleanup("read_tree"); +} diff --git a/tests-clar/object/tree/write.c b/tests-clar/object/tree/write.c index 657bed289..cc5438b05 100644 --- a/tests-clar/object/tree/write.c +++ b/tests-clar/object/tree/write.c @@ -39,6 +39,12 @@ void test_object_tree_write__from_memory(void) &bid, GIT_FILEMODE_BLOB)); cl_git_fail(git_treebuilder_insert(NULL, builder, "/", &bid, GIT_FILEMODE_BLOB)); + cl_git_fail(git_treebuilder_insert(NULL, builder, ".git", + &bid, GIT_FILEMODE_BLOB)); + cl_git_fail(git_treebuilder_insert(NULL, builder, "..", + &bid, GIT_FILEMODE_BLOB)); + cl_git_fail(git_treebuilder_insert(NULL, builder, ".", + &bid, GIT_FILEMODE_BLOB)); cl_git_fail(git_treebuilder_insert(NULL, builder, "folder/new.txt", &bid, GIT_FILEMODE_BLOB)); |