Revert changes to t18 ...Ops, I broke the old test when porting it to Clay.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
diff --git a/tests/t18-status.c b/tests/t18-status.c
index 92ec78b..1995111 100644
--- a/tests/t18-status.c
+++ b/tests/t18-status.c
@@ -48,6 +48,20 @@ static int file_create(const char *filename, const char *content)
return GIT_SUCCESS;
}
+BEGIN_TEST(file0, "test retrieving OID from a file apart from the ODB")
+ git_oid expected_id, actual_id;
+ char filename[] = "new_file";
+
+ must_pass(file_create(filename, "new_file\n\0"));
+
+ must_pass(git_odb_hashfile(&actual_id, filename, GIT_OBJ_BLOB));
+
+ must_pass(git_oid_fromstr(&expected_id, test_blob_oid));
+ must_be_true(git_oid_cmp(&expected_id, &actual_id) == 0);
+
+ must_pass(p_unlink(filename));
+END_TEST
+
static const char *entry_paths0[] = {
"file_deleted",
"modified_file",
@@ -86,6 +100,15 @@ static const unsigned int entry_statuses0[] = {
#define ENTRY_COUNT0 14
+struct status_entry_counts {
+ int wrong_status_flags_count;
+ int wrong_sorted_path;
+ int entry_count;
+ const unsigned int* expected_statuses;
+ const char** expected_paths;
+ int expected_entry_count;
+};
+
static int status_cb(const char *path, unsigned int status_flags, void *payload)
{
struct status_entry_counts *counts = (struct status_entry_counts *)payload;
@@ -131,6 +154,18 @@ BEGIN_TEST(statuscb0, "test retrieving status for worktree of repository")
git_futils_rmdir_r(TEMP_REPO_FOLDER, 1);
END_TEST
+static int status_cb1(const char *path, unsigned int status_flags, void *payload)
+{
+ int *count = (int *)payload;;
+
+ GIT_UNUSED_ARG(path);
+ GIT_UNUSED_ARG(status_flags);
+
+ *count++;
+
+ return GIT_SUCCESS;
+}
+
BEGIN_TEST(statuscb1, "test retrieving status for a worktree of an empty repository")
git_repository *repo;
int count = 0;
@@ -410,4 +445,4 @@ BEGIN_SUITE(status)
ADD_TEST(singlestatus2);
ADD_TEST(singlestatus3);
ADD_TEST(singlestatus4);
-END_SUITE
+END_SUITE
\ No newline at end of file