Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[pkgsrc/trunk]: pkgsrc/regress/infra-unittests regress/infra-unittests: add t...
details: https://anonhg.NetBSD.org/pkgsrc/rev/a50cc1641ee2
branches: trunk
changeset: 429947:a50cc1641ee2
user: rillig <rillig%pkgsrc.org@localhost>
date: Sun Apr 26 12:46:01 2020 +0000
description:
regress/infra-unittests: add tests for patch(1)
diffstat:
regress/infra-unittests/patch.sh | 82 ++++++++++++++++++++++++++++++++++++++++
1 files changed, 82 insertions(+), 0 deletions(-)
diffs (86 lines):
diff -r 99d0c775b36b -r a50cc1641ee2 regress/infra-unittests/patch.sh
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/regress/infra-unittests/patch.sh Sun Apr 26 12:46:01 2020 +0000
@@ -0,0 +1,82 @@
+#! /bin/sh
+# $NetBSD: patch.sh,v 1.1 2020/04/26 12:46:01 rillig Exp $
+#
+# Test cases for patching files using patch(1).
+#
+
+set -eu
+
+. "./test.subr"
+
+if test_case_begin "patch matches exactly"; then
+ cd "$tmpdir"
+
+ create_file_lines "to-be-patched" \
+ "1" "2" "3" "4" "5" "6" "7"
+
+ create_file "4-four.patch" <<EOF
+--- before
++++ to-be-patched
+@@ -1,7 +1,7 @@
+ 1
+ 2
+ 3
+-4
++four
+ 5
+ 6
+ 7
+EOF
+
+ patch -s -p0 < "4-four.patch"
+
+ assert_that "to-be-patched" --file-is-lines \
+ "1" "2" "3" "four" "5" "6" "7"
+
+ test_case_end
+fi
+
+
+if test_case_begin "line numbers in patch are way out of bounds"; then
+ cd "$tmpdir"
+
+ # BSD patch:
+ #
+ # If the line numbers in the patch are beyond the size of the file,
+ # /usr/bin/patch logs an information that "it is ignored", but it does
+ # not say exactly what "it" is.
+ #
+ # This may look frightening, but since the patch is applied anyway,
+ # "it" probably refers to the line numbers only, not to the hunk as
+ # a whole.
+ #
+ # https://github.com/openbsd/src/commit/328a6cea628e2916 (2003-07-16)
+
+ create_file_lines "to-be-patched" \
+ "1" "2" "3" "4" "5" "6" "7"
+
+ create_file "4-four.patch" <<EOF
+--- before
++++ to-be-patched
+@@ -1000,7 +1000,7 @@
+ 1
+ 2
+ 3
+-4
++four
+ 5
+ 6
+ 7
+EOF
+
+ patch -s -p0 < "4-four.patch" 2> "stderr" \
+ && exitcode=0 || exitcode=$?
+
+ assert_that "$exitcode" --equals "0"
+ assert_that "stderr" --file-is-lines \
+ "No such line 999 in input file, ignoring"
+ assert_that "to-be-patched" --file-is-lines \
+ "1" "2" "3" "four" "5" "6" "7"
+
+ test_case_end
+fi
Home |
Main Index |
Thread Index |
Old Index