]> git.proxmox.com Git - libgit2.git/commitdiff
blob: fix fromchunks iteration counter
authorCarlos Martín Nieto <cmn@dwim.me>
Wed, 4 Nov 2015 18:36:50 +0000 (10:36 -0800)
committerCarlos Martín Nieto <cmn@dwim.me>
Tue, 22 Mar 2016 19:00:24 +0000 (20:00 +0100)
By returning when the count goes to zero rather than below it, setting
`howmany` to 7 in fact writes out the string 6 times.

Correct the termination condition to write out the string the amount of
times we specify.

tests/object/blob/fromchunks.c
tests/object/blob/fromstream.c

index b61cabfe19d6c0427d9df1a8cdf905df835ed429..5a7d8f72224384b8cdbfd5eed0143ece904bce27 100644 (file)
@@ -26,7 +26,7 @@ static int text_chunked_source_cb(char *content, size_t max_length, void *payloa
        count = (int *)payload;
        (*count)--;
 
-       if (*count == 0)
+       if (*count < 0)
                return 0;
 
        strcpy(content, textual_content);
@@ -37,7 +37,7 @@ void test_object_blob_fromchunks__can_create_a_blob_from_a_in_memory_chunk_provi
 {
        git_oid expected_oid, oid;
        git_object *blob;
-       int howmany = 7;
+       int howmany = 6;
 
        cl_git_pass(git_oid_fromstr(&expected_oid, "321cbdf08803c744082332332838df6bd160f8f9"));
 
@@ -58,7 +58,7 @@ void test_object_blob_fromchunks__doesnot_overwrite_an_already_existing_object(v
        git_buf path = GIT_BUF_INIT;
        git_buf content = GIT_BUF_INIT;
        git_oid expected_oid, oid;
-       int howmany = 7;
+       int howmany = 6;
 
        cl_git_pass(git_oid_fromstr(&expected_oid, "321cbdf08803c744082332332838df6bd160f8f9"));
 
@@ -101,7 +101,7 @@ static void write_attributes(git_repository *repo)
 static void assert_named_chunked_blob(const char *expected_sha, const char *fake_name)
 {
        git_oid expected_oid, oid;
-       int howmany = 7;
+       int howmany = 6;
 
        cl_git_pass(git_oid_fromstr(&expected_oid, expected_sha));
 
index 10f2d8b31b490a7ed06993a5bcb1db94bec0ebbf..fb6b0784cd814244f00af7bd2afb8e384326c45a 100644 (file)
@@ -50,7 +50,7 @@ void test_object_blob_fromstream__multiple_write(void)
        for (i = 0; i < howmany; i++)
                cl_git_pass(stream->write(stream, textual_content, strlen(textual_content)));
 
-       cl_git_pass(git_blob_create_fromstream_end(&id, stream));
+       cl_git_pass(git_blob_create_fromstream_commit(&id, stream));
        cl_assert_equal_oid(&expected_id, &id);
 
        cl_git_pass(git_object_lookup(&blob, repo, &expected_id, GIT_OBJ_BLOB));
@@ -88,7 +88,7 @@ static void assert_named_chunked_blob(const char *expected_sha, const char *fake
        for (i = 0; i < howmany; i++)
                cl_git_pass(stream->write(stream, textual_content, strlen(textual_content)));
 
-       cl_git_pass(git_blob_create_fromstream_end(&id, stream));
+       cl_git_pass(git_blob_create_fromstream_commit(&id, stream));
 
        cl_assert_equal_oid(&expected_id, &id);
 }