From bb29cbb2fc42ce46bd8a53ad02d291aa833846fa Mon Sep 17 00:00:00 2001 From: Esben Mose Hansen Date: Fri, 6 Nov 2009 10:32:16 +0100 Subject: [PATCH] git_odb_open check for valid path to database --- src/errors.c | 1 + src/git/common.h | 3 +++ src/odb.c | 9 +++++++++ tests/t0204-opendb_errors.c | 38 ++++++++++++++++++++++++++++++++++++++ 4 files changed, 51 insertions(+), 0 deletions(-) create mode 100644 tests/t0204-opendb_errors.c diff --git a/src/errors.c b/src/errors.c index f348997..074c01c 100644 --- a/src/errors.c +++ b/src/errors.c @@ -36,6 +36,7 @@ static struct { { GIT_ENOTOID, "Not a git oid" }, { GIT_ENOTFOUND, "Object does not exist in the scope searched" }, { GIT_ENOMEM, "Not enough space" }, + { GIT_ENOTDIR, "Not a directory" } }; const char *git_strerror(int num) diff --git a/src/git/common.h b/src/git/common.h index c470e0e..96f2971 100644 --- a/src/git/common.h +++ b/src/git/common.h @@ -65,6 +65,9 @@ /** Consult the OS error information. */ #define GIT_EOSERR (GIT_ERROR - 4) +/** The path is not a directory */ +#define GIT_ENOTDIR (GIT_ERROR - 5) + GIT_BEGIN_DECL /** A revision traversal pool. */ diff --git a/src/odb.c b/src/odb.c index 6d646a4..a588c1b 100644 --- a/src/odb.c +++ b/src/odb.c @@ -1014,6 +1014,7 @@ int git_odb_exists(git_odb *db, const git_oid *id) int git_odb_open(git_odb **out, const char *objects_dir) { + struct stat objects_dir_stat; git_odb *db = git__calloc(1, sizeof(*db)); if (!db) return GIT_ERROR; @@ -1023,6 +1024,14 @@ int git_odb_open(git_odb **out, const char *objects_dir) free(db); return GIT_ERROR; } + if (stat(db->objects_dir, &objects_dir_stat)) { + free(db); + return GIT_EOSERR; + } + if (!S_ISDIR(objects_dir_stat.st_mode)) { + free(db); + return GIT_ENOTDIR; + } gitlck_init(&db->lock); diff --git a/tests/t0204-opendb_errors.c b/tests/t0204-opendb_errors.c new file mode 100644 index 0000000..e9b52c9 --- /dev/null +++ b/tests/t0204-opendb_errors.c @@ -0,0 +1,38 @@ +#include "test_lib.h" +#include "test_helpers.h" +#include +#include "fileops.h" + +static char *odb_dir = "test-objects"; + +static unsigned char one_bytes[] = { + 0x31, 0x78, 0x9c, 0xe3, 0x02, 0x00, 0x00, 0x0b, + 0x00, 0x0b, +}; + +static unsigned char one_data[] = { + 0x0a, +}; + +static object_data one = { + one_bytes, + sizeof(one_bytes), + "8b137891791fe96927ad78e64b0aad7bded08bdc", + "blob", + "test-objects/8b", + "test-objects/8b/137891791fe96927ad78e64b0aad7bded08bdc", + one_data, + sizeof(one_data), +}; + +BEGIN_TEST(opendb_errors) + git_odb *db; + int error = git_odb_open(&db, odb_dir); + must_be_true(error == GIT_EOSERR); + must_be_true(errno == ENOENT); + must_pass(write_object_files(odb_dir, &one)); + error = git_odb_open(&db, one.file); + must_be_true(error == GIT_ENOTDIR); + + must_pass(remove_object_files(odb_dir, &one)); +END_TEST -- 1.6.3.3