Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/tests/usr.bin/patch patch(1): add test cases for various bac...



details:   https://anonhg.NetBSD.org/src/rev/61d0c77856a6
branches:  trunk
changeset: 959603:61d0c77856a6
user:      nia <nia%NetBSD.org@localhost>
date:      Sat Feb 20 08:59:24 2021 +0000

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

diffstat:

 tests/usr.bin/patch/t_patch.sh |  112 ++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 110 insertions(+), 2 deletions(-)

diffs (129 lines):

diff -r 8824c57990ef -r 61d0c77856a6 tests/usr.bin/patch/t_patch.sh
--- a/tests/usr.bin/patch/t_patch.sh    Sat Feb 20 03:25:35 2021 +0000
+++ b/tests/usr.bin/patch/t_patch.sh    Sat Feb 20 08:59:24 2021 +0000
@@ -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 @@
        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
 }



Home | Main Index | Thread Index | Old Index