git test suite
authorjoey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071>
Sun, 26 Nov 2006 20:10:09 +0000 (20:10 +0000)
committerjoey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071>
Sun, 26 Nov 2006 20:10:09 +0000 (20:10 +0000)
debian/changelog
t/git.t [new file with mode: 0755]

index 0429f152db4380b22753e62df95e7d003c7d4846..a6718aef336121ec80cb0dfd2377407b25caf640 100644 (file)
@@ -37,6 +37,7 @@ ikiwiki (1.34) UNRELEASED; urgency=low
   * Fix nested examples directory in deb.
   * Add a test suite for the mercurial backend, contributed by Emanuele Aina.
   * Add a test suite for the svn backend.
+  * Add a test suite for the git backend, from Recai 
   * Daemonize before sending RPC pings, since that can take a while
     and/or hang.
   * Daemonize before sending commit mails, as that can also take a long
@@ -48,8 +49,8 @@ ikiwiki (1.34) UNRELEASED; urgency=low
   * Add softwaresite example.
   * Mercurial backend improvements, including --get-ctime support. (Emanuele
     Aina)
-  * Git backend improvements, including bug fixes and better robustness.
-    (Recai Oktaş)
+  * Git backend improvements, including bug fixes and better robustness,
+    from Recai.
 
  -- Joey Hess <joeyh@debian.org>  Sun, 26 Nov 2006 15:01:14 -0500
 
diff --git a/t/git.t b/t/git.t
new file mode 100755 (executable)
index 0000000..a3e5b36
--- /dev/null
+++ b/t/git.t
@@ -0,0 +1,68 @@
+#!/usr/bin/perl
+use warnings;
+use strict;
+
+my $dir;
+my $gitrepo;
+BEGIN {
+       $dir="/tmp/ikiwiki-test-git.$$";
+       $gitrepo="$dir/repo";
+       my $git=`which git`;
+       chomp $git;
+       if (! -x $git || ! mkdir($dir) || ! mkdir($gitrepo)) {
+               eval q{
+                       use Test::More skip_all => "git not available or could not make test dirs"
+               }
+       }
+}
+use Test::More tests => 11;
+
+BEGIN { use_ok("IkiWiki"); }
+
+%config=IkiWiki::defaultconfig();
+$config{rcs} = "git";
+$config{srcdir} = "$dir/src";
+IkiWiki::checkconfig();
+
+system "cd $gitrepo && git init-db 2>/dev/null";
+system "cd $gitrepo && echo dummy >dummy; git add . 2>/dev/null";
+system "cd $gitrepo && git commit -m Initial 2>/dev/null";
+system "git clone -l -s $gitrepo $config{srcdir} 2>/dev/null";
+
+my @changes;
+@changes = IkiWiki::rcs_recentchanges(3);
+
+is($#changes, 0); # counts for dummy commit during repo creation
+is($changes[0]{message}[0]{"line"}, "Initial");
+is($changes[0]{pages}[0]{"page"}, undef); # no diff for first commit
+
+# Web commit
+my $test1 = readfile("t/test1.mdwn");
+writefile('test1.mdwn', $config{srcdir}, $test1);
+IkiWiki::rcs_add("test1.mdwn");
+IkiWiki::rcs_commit("test1.mdwn", "Added the first page", "moo");
+
+@changes = IkiWiki::rcs_recentchanges(3);
+
+is($#changes, 1);
+is($changes[0]{message}[0]{"line"}, "Added the first page");
+is($changes[0]{pages}[0]{"page"}, "test1.mdwn");
+       
+# Manual commit
+my $message = "Added the second page";
+
+my $test2 = readfile("t/test2.mdwn");
+writefile('test2.mdwn', $config{srcdir}, $test2);
+system "cd $config{srcdir}; git add test2.mdwn 2>/dev/null";
+system "cd $config{srcdir}; git commit -m \"$message\" test2.mdwn 2>/dev/null";
+system "cd $config{srcdir}; git push origin 2>/dev/null";
+
+@changes = IkiWiki::rcs_recentchanges(3);
+
+is($#changes, 2);
+is($changes[0]{message}[0]{"line"}, $message);
+is($changes[0]{pages}[0]{"page"}, "test2.mdwn");
+
+is($changes[1]{pages}[0]{"page"}, "test1.mdwn");
+
+system "rm -rf $dir";