blob: f66551fccf9a8ccd175691fd148b039ec1c23ddf [file] [log] [blame]
#!/usr/bin/env perl
#
# Copyright (C) 2010 Chris Jerdonek (chris.jerdonek@gmail.com)
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
# * Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# * Redistributions in binary form must reproduce the above
# copyright notice, this list of conditions and the following disclaimer
# in the documentation and/or other materials provided with the
# distribution.
# * Neither the name of Apple Inc. ("Apple") nor the names of
# its contributors may be used to endorse or promote products derived
# from this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
# Unit tests of parseDiffHeader().
use strict;
use warnings;
use Test::More;
use VCSUtils;
# The unit tests for parseGitDiffHeader() and parseSvnDiffHeader()
# already thoroughly test parsing each format.
#
# For parseDiffHeader(), it should suffice to verify that -- (1) for each
# format, the method can return non-trivial values back for each key
# supported by that format (e.g. "sourceRevision" for SVN), (2) the method
# correctly sets default values when specific key-values are not set
# (e.g. undef for "sourceRevision" for Git), and (3) key-values unique to
# this method are set correctly (e.g. "scmFormat").
my @testCaseHashRefs = (
####
# SVN test cases
##
{ # New test
diffName => "SVN: non-trivial copiedFromPath and sourceRevision values",
inputText => <<'END',
Index: index_path.py
===================================================================
--- index_path.py (revision 53048) (from copied_from_path.py:53048)
+++ index_path.py (working copy)
@@ -0,0 +1,7 @@
+# Python file...
END
expectedReturn => [
{
svnConvertedText => <<'END',
Index: index_path.py
===================================================================
--- index_path.py (revision 53048) (from copied_from_path.py:53048)
+++ index_path.py (working copy)
END
copiedFromPath => "copied_from_path.py",
indexPath => "index_path.py",
isSvn => 1,
sourceRevision => 53048,
},
"@@ -0,0 +1,7 @@\n"],
expectedNextLine => "+# Python file...\n",
},
####
# Git test cases
##
{ # New test case
diffName => "Git: Non-zero executable bit",
inputText => <<'END',
diff --git a/foo.exe b/foo.exe
old mode 100644
new mode 100755
END
expectedReturn => [
{
svnConvertedText => <<'END',
Index: foo.exe
old mode 100644
new mode 100755
END
executableBitDelta => 1,
indexPath => "foo.exe",
isGit => 1,
},
undef],
expectedNextLine => undef,
},
####
# Unified patch cases
##
{
diffName => "Unified: Modified file",
inputText => <<'END',
--- Foo/bar.h
+++ Foo/bar.h
END
expectedReturn => [
{
svnConvertedText => <<'END',
Index: Foo/bar.h
index 0000000..0000000
--- Foo/bar.h
+++ Foo/bar.h
END
indexPath => 'Foo/bar.h',
isUnified => 1,
},
undef],
expectedNextLine => undef,
}
);
my $testCasesCount = @testCaseHashRefs;
plan(tests => 2 * $testCasesCount); # Total number of assertions.
foreach my $testCase (@testCaseHashRefs) {
my $testNameStart = "parseDiffHeader(): $testCase->{diffName}: comparing";
my $fileHandle;
open($fileHandle, "<", \$testCase->{inputText});
my $line = <$fileHandle>;
my @got = VCSUtils::parseDiffHeader($fileHandle, $line);
my $expectedReturn = $testCase->{expectedReturn};
is_deeply(\@got, $expectedReturn, "$testNameStart return value.");
my $gotNextLine = <$fileHandle>;
is($gotNextLine, $testCase->{expectedNextLine}, "$testNameStart next read line.");
}