summaryrefslogtreecommitdiff
path: root/tests/diff/stats.c
diff options
context:
space:
mode:
authorVicent Marti <vicent@github.com>2014-04-16 19:09:35 +0200
committerVicent Marti <vicent@github.com>2014-04-16 19:09:35 +0200
commitc5cacc4ec2c13e93164b8e3013b0d18c8c6d820c (patch)
tree19ee82e4327f0d30a4e75bc5d7997430fbb2becf /tests/diff/stats.c
parent3b2d14a7b83e0db272c84046f90b53b7b773180e (diff)
parent39206ca256409edb7102edf0d30a6ced2e5f16e3 (diff)
downloadlibgit2-c5cacc4ec2c13e93164b8e3013b0d18c8c6d820c.tar.gz
Merge pull request #2261 from jacquesg/format-patch
Support for format-patch
Diffstat (limited to 'tests/diff/stats.c')
-rw-r--r--tests/diff/stats.c428
1 files changed, 428 insertions, 0 deletions
diff --git a/tests/diff/stats.c b/tests/diff/stats.c
new file mode 100644
index 000000000..131b7681d
--- /dev/null
+++ b/tests/diff/stats.c
@@ -0,0 +1,428 @@
+#include "clar.h"
+#include "clar_libgit2.h"
+
+#include "buffer.h"
+#include "commit.h"
+#include "diff.h"
+
+static git_repository *repo;
+
+void test_diff_stats__initialize(void)
+{
+ repo = cl_git_sandbox_init("diff_format_email");
+}
+
+void test_diff_stats__cleanup(void)
+{
+ cl_git_sandbox_cleanup();
+}
+
+void test_diff_stats__stat(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file1.txt | 8 +++++---\n" \
+ " 1 file changed, 5 insertions(+), 3 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "9264b96c6d104d0e07ae33d3007b6a48246c6f92");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 1);
+ cl_assert(git_diff_stats_insertions(stats) == 5);
+ cl_assert(git_diff_stats_deletions(stats) == 3);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__multiple_hunks(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file2.txt | 5 +++--\n" \
+ " file3.txt | 6 ++++--\n" \
+ " 2 files changed, 7 insertions(+), 4 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "cd471f0d8770371e1bc78bcbb38db4c7e4106bd2");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 2);
+ cl_assert(git_diff_stats_insertions(stats) == 7);
+ cl_assert(git_diff_stats_deletions(stats) == 4);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__numstat(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ "3 2 file2.txt\n"
+ "4 2 file3.txt\n";
+
+ git_oid_fromstr(&oid, "cd471f0d8770371e1bc78bcbb38db4c7e4106bd2");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_NUMBER));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__shortstat(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " 1 file changed, 5 insertions(+), 3 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "9264b96c6d104d0e07ae33d3007b6a48246c6f92");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 1);
+ cl_assert(git_diff_stats_insertions(stats) == 5);
+ cl_assert(git_diff_stats_deletions(stats) == 3);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_SHORT));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__rename(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file2.txt => file2.txt.renamed | 1 +\n"
+ " file3.txt => file3.txt.renamed | 4 +++-\n"
+ " 2 files changed, 4 insertions(+), 1 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "8947a46e2097638ca6040ad4877246f4186ec3bd");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+ cl_git_pass(git_diff_find_similar(diff, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 2);
+ cl_assert(git_diff_stats_insertions(stats) == 4);
+ cl_assert(git_diff_stats_deletions(stats) == 1);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__rename_nochanges(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file2.txt.renamed => file2.txt.renamed2 | 0\n"
+ " file3.txt.renamed => file3.txt.renamed2 | 0\n"
+ " 2 files changed, 0 insertions(+), 0 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "3991dce9e71a0641ca49a6a4eea6c9e7ff402ed4");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+ cl_git_pass(git_diff_find_similar(diff, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 2);
+ cl_assert(git_diff_stats_insertions(stats) == 0);
+ cl_assert(git_diff_stats_deletions(stats) == 0);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__rename_and_modifiy(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file2.txt.renamed2 | 2 +-\n"
+ " file3.txt.renamed2 => file3.txt.renamed | 0\n"
+ " 2 files changed, 1 insertions(+), 1 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "4ca10087e696d2ba78d07b146a118e9a7096ed4f");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+ cl_git_pass(git_diff_find_similar(diff, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 2);
+ cl_assert(git_diff_stats_insertions(stats) == 1);
+ cl_assert(git_diff_stats_deletions(stats) == 1);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__rename_no_find(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file2.txt | 5 -----\n"
+ " file2.txt.renamed | 6 ++++++\n"
+ " file3.txt | 5 -----\n"
+ " file3.txt.renamed | 7 +++++++\n"
+ " 4 files changed, 13 insertions(+), 10 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "8947a46e2097638ca6040ad4877246f4186ec3bd");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 4);
+ cl_assert(git_diff_stats_insertions(stats) == 13);
+ cl_assert(git_diff_stats_deletions(stats) == 10);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__rename_nochanges_no_find(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file2.txt.renamed | 6 ------\n"
+ " file2.txt.renamed2 | 6 ++++++\n"
+ " file3.txt.renamed | 7 -------\n"
+ " file3.txt.renamed2 | 7 +++++++\n"
+ " 4 files changed, 13 insertions(+), 13 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "3991dce9e71a0641ca49a6a4eea6c9e7ff402ed4");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 4);
+ cl_assert(git_diff_stats_insertions(stats) == 13);
+ cl_assert(git_diff_stats_deletions(stats) == 13);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__rename_and_modifiy_no_find(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file2.txt.renamed2 | 2 +-\n"
+ " file3.txt.renamed | 7 +++++++\n"
+ " file3.txt.renamed2 | 7 -------\n"
+ " 3 files changed, 8 insertions(+), 8 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "4ca10087e696d2ba78d07b146a118e9a7096ed4f");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 3);
+ cl_assert(git_diff_stats_insertions(stats) == 8);
+ cl_assert(git_diff_stats_deletions(stats) == 8);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__binary(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ /* TODO: Actually 0 bytes here should be 5!. Seems like we don't load the new content for binary files? */
+ const char *stat =
+ " binary.bin | Bin 3 -> 0 bytes\n"
+ " 1 file changed, 0 insertions(+), 0 deletions(-)\n";
+
+ git_oid_fromstr(&oid, "8d7523f6fcb2404257889abe0d96f093d9f524f9");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+ cl_assert(git_diff_stats_files_changed(stats) == 1);
+ cl_assert(git_diff_stats_insertions(stats) == 0);
+ cl_assert(git_diff_stats_deletions(stats) == 0);
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__binary_numstat(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ "- - binary.bin\n";
+
+ git_oid_fromstr(&oid, "8d7523f6fcb2404257889abe0d96f093d9f524f9");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_NUMBER));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}
+
+void test_diff_stats__mode_change(void)
+{
+ git_oid oid;
+ git_commit *commit = NULL;
+ git_diff *diff = NULL;
+ git_diff_stats *stats = NULL;
+ git_buf buf = GIT_BUF_INIT;
+
+ const char *stat =
+ " file1.txt.renamed | 0\n" \
+ " 1 file changed, 0 insertions(+), 0 deletions(-)\n" \
+ " mode change 100644 => 100755 file1.txt.renamed\n" \
+ "\n";
+
+ git_oid_fromstr(&oid, "7ade76dd34bba4733cf9878079f9fd4a456a9189");
+
+ cl_git_pass(git_commit_lookup(&commit, repo, &oid));
+ cl_git_pass(git_diff__commit(&diff, repo, commit, NULL));
+
+ cl_git_pass(git_diff_get_stats(&stats, diff));
+
+ cl_git_pass(git_diff_stats_to_buf(&buf, stats, GIT_DIFF_STATS_FULL | GIT_DIFF_STATS_INCLUDE_SUMMARY));
+ cl_assert(strcmp(git_buf_cstr(&buf), stat) == 0);
+
+ git_diff_stats_free(stats);
+ git_diff_free(diff);
+ git_commit_free(commit);
+ git_buf_free(&buf);
+}