git: 22561b00abac - stable/13 - Integrate contrib/file/tests with kyua/atf
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Wed, 02 Mar 2022 21:57:28 UTC
The branch stable/13 has been updated by vangyzen: URL: https://cgit.FreeBSD.org/src/commit/?id=22561b00abac7dd1b933689005a7563f88ef0e84 commit 22561b00abac7dd1b933689005a7563f88ef0e84 Author: Eric van Gyzen <vangyzen@FreeBSD.org> AuthorDate: 2022-02-16 15:50:43 +0000 Commit: Eric van Gyzen <vangyzen@FreeBSD.org> CommitDate: 2022-03-02 21:56:31 +0000 Integrate contrib/file/tests with kyua/atf This could be done better by making each test a separate ATF test case. This exercise is left for the reader. Reviewed by: delphij (earlier version) MFC after: 1 week Sponsored by: Dell EMC Isilon Differential Revision: https://reviews.freebsd.org/D34303 (cherry picked from commit 1581ec9a4502c1f0e4f0ce290190864abf946d6f) --- etc/mtree/BSD.tests.dist | 2 ++ usr.bin/file/Makefile | 5 ++++ usr.bin/file/tests/Makefile | 8 ++++++ usr.bin/file/tests/file_test.sh | 54 +++++++++++++++++++++++++++++++++++++++++ 4 files changed, 69 insertions(+) diff --git a/etc/mtree/BSD.tests.dist b/etc/mtree/BSD.tests.dist index e3195c47ee88..75fbc64dce9c 100644 --- a/etc/mtree/BSD.tests.dist +++ b/etc/mtree/BSD.tests.dist @@ -1006,6 +1006,8 @@ .. file2c .. + file + .. find .. fold diff --git a/usr.bin/file/Makefile b/usr.bin/file/Makefile index f31c50ad86da..0a7c327c91f1 100644 --- a/usr.bin/file/Makefile +++ b/usr.bin/file/Makefile @@ -20,6 +20,8 @@ # ever read sources, credits must appear in the documentation. # 4. This notice may not be removed or altered. +.include <src.opts.mk> + SRCDIR= ${SRCTOP}/contrib/file .PATH: ${SRCDIR}/src .PATH: ${SRCDIR}/doc @@ -38,6 +40,9 @@ FILEVER!= awk '$$1 == "\#define" && $$2 == "VERSION" { print $$3; exit }' \ CLEANFILES+= ${MAN} +HAS_TESTS= +SUBDIR.${MK_TESTS}+= tests + .include <bsd.prog.mk> .for mp in ${MAN} diff --git a/usr.bin/file/tests/Makefile b/usr.bin/file/tests/Makefile new file mode 100644 index 000000000000..ea0ebaa12ce2 --- /dev/null +++ b/usr.bin/file/tests/Makefile @@ -0,0 +1,8 @@ +PACKAGE= tests +ATF_TESTS_SH= file_test + +SRCDIR= ${SRCTOP}/contrib/file/tests +_files!= echo ${SRCDIR}/*.testfile ${SRCDIR}/*.result ${SRCDIR}/*.magic +${PACKAGE}FILES+=${_files} + +.include <bsd.test.mk> diff --git a/usr.bin/file/tests/file_test.sh b/usr.bin/file/tests/file_test.sh new file mode 100644 index 000000000000..e6e398f6e51d --- /dev/null +++ b/usr.bin/file/tests/file_test.sh @@ -0,0 +1,54 @@ +#!/usr/libexec/atf-sh +# +# SPDX-License-Identifier: BSD-2-Clause +# +# Copyright (c) 2022 Eric van Gyzen +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions +# are met: +# 1. Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# 2. 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. +# +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. + +atf_test_case contrib_file_tests cleanup +contrib_file_tests_body() { + srcdir="$(atf_get_srcdir)" + + for testfile in "${srcdir}"/*.testfile; do + test_name="${testfile%.testfile}" + result_file="${test_name}.result" + magic_file="${test_name}.magic" + file_args= + if [ -e "${magic_file}" ]; then + file_args="${file_args} --magic-file ${magic_file}" + fi + # The result files were created in UTC. + TZ=Z atf_check -o save:actual_output file ${file_args} \ + --brief "$testfile" + atf_check -o save:trimmed_output tr -d '\012' < actual_output + atf_check cmp trimmed_output "$result_file" + done +} + +contrib_file_tests_cleanup() { + rm -f actual_output trimmed_output +} + +atf_init_test_cases() { + atf_add_test_case contrib_file_tests +}