Module Name:    src
Committed By:   nia
Date:           Sat Feb 20 08:59:24 UTC 2021

Modified Files:
        src/tests/usr.bin/patch: t_patch.sh

Log Message:
patch(1): add test cases for various backup file formats


To generate a diff of this commit:
cvs rdiff -u -r1.1 -r1.2 src/tests/usr.bin/patch/t_patch.sh

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/tests/usr.bin/patch/t_patch.sh
diff -u src/tests/usr.bin/patch/t_patch.sh:1.1 src/tests/usr.bin/patch/t_patch.sh:1.2
--- src/tests/usr.bin/patch/t_patch.sh:1.1	Wed Jun 24 09:21:43 2020
+++ src/tests/usr.bin/patch/t_patch.sh	Sat Feb 20 08:59:24 2021
@@ -1,6 +1,6 @@
-# $NetBSD: t_patch.sh,v 1.1 2020/06/24 09:21:43 jruoho Exp $
+# $NetBSD: t_patch.sh,v 1.2 2021/02/20 08:59:24 nia Exp $
 #
-# Copyright (c) 2020 The NetBSD Foundation, Inc.
+# Copyright (c) 2020, 2021 The NetBSD Foundation, Inc.
 # All rights reserved.
 #
 # Redistribution and use in source and binary forms, with or without
@@ -71,8 +71,116 @@ long_lines_body()
 	patch_lines 10000
 }
 
+atf_test_case backup_simple
+backup_simple_head()
+{
+	atf_set "descr" "Test backup type 'simple' (-V simple)"
+}
+
+backup_simple_body()
+{
+	# Create the backup file so it's overwritten.
+	touch to_patch.orig
+	printf '%s\n' 'original file' > to_patch
+
+	cat << EOF > test_diff.patch
+--- original_file       2021-02-20 09:21:07.100869692 +0100
++++ new_file    2021-02-20 09:21:10.912906887 +0100
+@@ -1 +1 @@
+-original text
++new text
+EOF
+	cksum=$(sha256 -n to_patch | cut -d' ' -f1)
+	patch -V simple to_patch < test_diff.patch
+	atf_check [ -f to_patch.orig ]
+	origfile_cksum=$(sha256 -n to_patch.orig | cut -d' ' -f1)
+	atf_check_equal "$cksum" "$origfile_cksum"
+	atf_check grep -q -m 1 '^new text$' to_patch
+}
+
+atf_test_case backup_none
+backup_none_head()
+{
+	atf_set "descr" "Test backup type 'none' (-V none)"
+}
+
+backup_none_body()
+{
+	printf '%s\n' 'original file' > to_patch
+
+	cat << EOF > test_diff.patch
+--- original_file       2021-02-20 09:21:07.100869692 +0100
++++ new_file    2021-02-20 09:21:10.912906887 +0100
+@@ -1 +1 @@
+-original text
++new text
+EOF
+	# Patch would mistakenly create 'simple' backup files when unwanted:
+	# http://mail-index.netbsd.org/tech-userlevel/2021/02/19/msg012901.html
+	patch -V none to_patch < test_diff.patch
+	atf_check [ ! -f to_patch.orig ]
+	atf_check grep -q -m 1 '^new text$' to_patch
+
+	# Environment variables should be overriden.
+	printf '%s\n' 'original file' > to_patch
+	VERSION_CONTROL=existing patch -V none to_patch \
+	    < test_diff.patch
+	atf_check [ ! -f to_patch.orig ]
+	atf_check grep -q -m 1 '^new text$' to_patch
+
+	# --posix should imply -V none.
+	printf '%s\n' 'original file' > to_patch
+	patch --posix to_patch < test_diff.patch
+	atf_check [ ! -f to_patch.orig ]
+	atf_check grep -q -m 1 '^new text$' to_patch
+}
+
+atf_test_case backup_numbered
+backup_numbered_head()
+{
+	atf_set "descr" "Test backup type 'numbered' (-V numbered)"
+}
+
+backup_numbered_body()
+{
+	printf '%s\n' 'original file' > to_patch
+
+	cat << EOF > test_diff.patch
+--- original_file       2021-02-20 09:21:07.100869692 +0100
++++ new_file    2021-02-20 09:21:10.912906887 +0100
+@@ -1 +1 @@
+-original text
++new text
+EOF
+	cksum1=$(sha256 -n to_patch | cut -d' ' -f1)
+	patch -V numbered to_patch < test_diff.patch
+	atf_check grep -q -m 1 '^new text$' to_patch
+
+	cat << EOF > test_diff2.patch
+--- new_file	2021-02-20 09:44:52.363230019 +0100
++++ newer_file	2021-02-20 09:43:54.592863401 +0100
+@@ -1 +1 @@
+-new text
++newer text
+EOF
+	cksum2=$(sha256 -n to_patch | cut -d' ' -f1)
+	patch -V numbered to_patch < test_diff2.patch
+	atf_check grep -q -m 1 '^newer text$' to_patch
+
+	# Make sure the backup files match the original files.
+	origfile_cksum1=$(sha256 -n to_patch.~1~ | cut -d' ' -f1)
+	origfile_cksum2=$(sha256 -n to_patch.~2~ | cut -d' ' -f1)
+	atf_check [ -f to_patch.~1~ ]
+	atf_check_equal "$cksum1" "$origfile_cksum1"
+	atf_check [ -f to_patch.~2~ ]
+	atf_check_equal "$cksum2" "$origfile_cksum2"
+}
+
 atf_init_test_cases()
 {
 	atf_add_test_case lines
 	atf_add_test_case long_lines
+	atf_add_test_case backup_simple
+	atf_add_test_case backup_none
+	atf_add_test_case backup_numbered
 }

Reply via email to