]> git.ipfire.org Git - thirdparty/git.git/commitdiff
test-read-graph: include extra post-parse info
authorDerrick Stolee <derrickstolee@github.com>
Tue, 1 Mar 2022 19:48:28 +0000 (19:48 +0000)
committerJunio C Hamano <gitster@pobox.com>
Tue, 1 Mar 2022 20:09:55 +0000 (12:09 -0800)
It can be helpful to verify that the 'struct commit_graph' that results
from parsing a commit-graph is correctly structured. The existence of
different chunks is not enough to verify that all of the optional
features are correctly enabled.

Update 'test-tool read-graph' to output an "options:" line that includes
information for different parts of the struct commit_graph.

In particular, this change demonstrates that the read_generation_data
option is never being enabled, which will be fixed in a later change.

Signed-off-by: Derrick Stolee <derrickstolee@github.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
t/helper/test-read-graph.c
t/t4216-log-bloom.sh
t/t5318-commit-graph.sh
t/t5324-split-commit-graph.sh

index 75927b2c81d28de1b3f16de0ef4a9d55aad5e668..98b73bb8f25aabea7384cde0fb639cff16cf631e 100644 (file)
@@ -3,6 +3,7 @@
 #include "commit-graph.h"
 #include "repository.h"
 #include "object-store.h"
+#include "bloom.h"
 
 int cmd__read_graph(int argc, const char **argv)
 {
@@ -45,6 +46,18 @@ int cmd__read_graph(int argc, const char **argv)
                printf(" bloom_data");
        printf("\n");
 
+       printf("options:");
+       if (graph->bloom_filter_settings)
+               printf(" bloom(%"PRIu32",%"PRIu32",%"PRIu32")",
+                      graph->bloom_filter_settings->hash_version,
+                      graph->bloom_filter_settings->bits_per_entry,
+                      graph->bloom_filter_settings->num_hashes);
+       if (graph->read_generation_data)
+               printf(" read_generation_data");
+       if (graph->topo_levels)
+               printf(" topo_levels");
+       printf("\n");
+
        UNLEAK(graph);
 
        return 0;
index cc3cebf672242a622e86b388ada63c9e0c1a9c04..5ed6d2a21c1d71bfe392961db41089c2f38d40c4 100755 (executable)
@@ -48,6 +48,7 @@ graph_read_expect () {
        header: 43475048 1 $(test_oid oid_version) $NUM_CHUNKS 0
        num_commits: $1
        chunks: oid_fanout oid_lookup commit_metadata generation_data bloom_indexes bloom_data
+       options: bloom(1,10,7)
        EOF
        test-tool read-graph >actual &&
        test_cmp expect actual
index edb728f77c3583cecde2d87555a4547464db7b96..2b05026cf6d8d1fd378179e4aba23b42b4039b07 100755 (executable)
@@ -104,6 +104,7 @@ graph_read_expect() {
        header: 43475048 1 $(test_oid oid_version) $NUM_CHUNKS 0
        num_commits: $1
        chunks: oid_fanout oid_lookup commit_metadata$OPTIONAL
+       options:
        EOF
        test-tool read-graph >output &&
        test_cmp expect output
index 847b8097109cef7102c1e0709bf1c97a0457988c..778fa418de2bd9c17c4c5f609d96004341571137 100755 (executable)
@@ -34,6 +34,7 @@ graph_read_expect() {
        header: 43475048 1 $(test_oid oid_version) 4 $NUM_BASE
        num_commits: $1
        chunks: oid_fanout oid_lookup commit_metadata generation_data
+       options:
        EOF
        test-tool read-graph >output &&
        test_cmp expect output
@@ -508,6 +509,7 @@ test_expect_success 'setup repo for mixed generation commit-graph-chain' '
                header: 43475048 1 $(test_oid oid_version) 4 1
                num_commits: $NUM_SECOND_LAYER_COMMITS
                chunks: oid_fanout oid_lookup commit_metadata
+               options:
                EOF
                test_cmp expect output &&
                git commit-graph verify &&
@@ -540,6 +542,7 @@ test_expect_success 'do not write generation data chunk if not present on existi
                header: 43475048 1 $(test_oid oid_version) 4 2
                num_commits: $NUM_THIRD_LAYER_COMMITS
                chunks: oid_fanout oid_lookup commit_metadata
+               options:
                EOF
                test_cmp expect output &&
                git commit-graph verify
@@ -581,6 +584,7 @@ test_expect_success 'do not write generation data chunk if the topmost remaining
                header: 43475048 1 $(test_oid oid_version) 4 2
                num_commits: $(($NUM_THIRD_LAYER_COMMITS + $NUM_FOURTH_LAYER_COMMITS))
                chunks: oid_fanout oid_lookup commit_metadata
+               options:
                EOF
                test_cmp expect output &&
                git commit-graph verify
@@ -620,6 +624,7 @@ test_expect_success 'write generation data chunk if topmost remaining layer has
                header: 43475048 1 $(test_oid oid_version) 5 1
                num_commits: $(($NUM_SECOND_LAYER_COMMITS + $NUM_THIRD_LAYER_COMMITS + $NUM_FOURTH_LAYER_COMMITS + $NUM_FIFTH_LAYER_COMMITS))
                chunks: oid_fanout oid_lookup commit_metadata generation_data
+               options:
                EOF
                test_cmp expect output
        )