aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDag-Erling Smørgrav <des@FreeBSD.org>2023-06-15 19:23:19 +0000
committerDag-Erling Smørgrav <des@FreeBSD.org>2023-07-03 15:13:11 +0000
commit77d9e708c07b7bbbebc8e729f8fb339fb99c2d99 (patch)
treeb822f6ccd43470a63d496240bf5962a5629960a8
parentd2ee65f43d03f144b1bd22fa41748523c981db8e (diff)
downloadsrc-77d9e708c07b7bbbebc8e729f8fb339fb99c2d99.tar.gz
src-77d9e708c07b7bbbebc8e729f8fb339fb99c2d99.zip
asa: Error out if writing to stdout failed.
MFC after: 1 week Sponsored by: Klara, Inc. Reviewed by: markj Differential Revision: https://reviews.freebsd.org/D40562 (cherry picked from commit 9e379f9639d51442ad1d5e1800c687ef2c954901) asa: Read from stdin if *argv is "-". MFC after: 1 week Sponsored by: Klara, Inc. Reviewed by: markj Differential Revision: https://reviews.freebsd.org/D40563 (cherry picked from commit f08f90e6987775f88d25efbd8762c361819f40ba) asa: Add some unit tests. MFC after: 1 week Sponsored by: Klara, Inc. Reviewed by: markj Differential Revision: https://reviews.freebsd.org/D40564 (cherry picked from commit b7412da2e122d9274341ef840c6918409bc523b3)
-rw-r--r--etc/mtree/BSD.tests.dist2
-rw-r--r--usr.bin/asa/Makefile5
-rw-r--r--usr.bin/asa/asa.c25
-rw-r--r--usr.bin/asa/tests/Makefile4
-rw-r--r--usr.bin/asa/tests/asa_test.sh99
5 files changed, 126 insertions, 9 deletions
diff --git a/etc/mtree/BSD.tests.dist b/etc/mtree/BSD.tests.dist
index eb62812bfcd8..35d8e9505b9a 100644
--- a/etc/mtree/BSD.tests.dist
+++ b/etc/mtree/BSD.tests.dist
@@ -886,6 +886,8 @@
usr.bin
apply
..
+ asa
+ ..
awk
..
basename
diff --git a/usr.bin/asa/Makefile b/usr.bin/asa/Makefile
index c2a221ae027b..a29db0f31781 100644
--- a/usr.bin/asa/Makefile
+++ b/usr.bin/asa/Makefile
@@ -1,6 +1,7 @@
-# $NetBSD: Makefile,v 1.2 1995/03/25 18:04:51 glass Exp $
-# $FreeBSD$
+.include <src.opts.mk>
PROG= asa
+HAS_TESTS=
+SUBDIR.${MK_TESTS}= tests
.include <bsd.prog.mk>
diff --git a/usr.bin/asa/asa.c b/usr.bin/asa/asa.c
index 22174ed340cd..a6c3d7d7c1e5 100644
--- a/usr.bin/asa/asa.c
+++ b/usr.bin/asa/asa.c
@@ -43,6 +43,7 @@ __FBSDID("$FreeBSD$");
#include <err.h>
#include <stdio.h>
#include <stdlib.h>
+#include <string.h>
#include <unistd.h>
static void asa(FILE *);
@@ -71,16 +72,23 @@ main(int argc, char *argv[])
asa(stdin);
else {
while ((fn = *argv++) != NULL) {
- if ((fp = fopen(fn, "r")) == NULL) {
- warn("%s", fn);
- exval = 1;
- continue;
- }
- asa(fp);
- fclose(fp);
+ if (strcmp(fn, "-") == 0) {
+ asa(stdin);
+ } else {
+ if ((fp = fopen(fn, "r")) == NULL) {
+ warn("%s", fn);
+ exval = 1;
+ continue;
+ }
+ asa(fp);
+ fclose(fp);
+ }
}
}
+ if (fflush(stdout) != 0)
+ err(1, "stdout");
+
exit(exval);
}
@@ -140,4 +148,7 @@ asa(FILE *f)
putchar('\n');
}
+
+ if (ferror(stdout) != 0)
+ err(1, "stdout");
}
diff --git a/usr.bin/asa/tests/Makefile b/usr.bin/asa/tests/Makefile
new file mode 100644
index 000000000000..c8c0cde1b3a2
--- /dev/null
+++ b/usr.bin/asa/tests/Makefile
@@ -0,0 +1,4 @@
+PACKAGE= tests
+ATF_TESTS_SH= asa_test
+
+.include <bsd.test.mk>
diff --git a/usr.bin/asa/tests/asa_test.sh b/usr.bin/asa/tests/asa_test.sh
new file mode 100644
index 000000000000..429342d530e4
--- /dev/null
+++ b/usr.bin/asa/tests/asa_test.sh
@@ -0,0 +1,99 @@
+#
+# Copyright (c) 2023 Klara, Inc.
+#
+# SPDX-License-Identifier: BSD-2-Clause
+#
+
+a="The magic words are"
+b="Squeamish Ossifrage"
+
+atf_check_asa() {
+ atf_check -o file:"$2" asa "$1"
+ atf_check -o file:"$2" asa <"$1"
+ atf_check -o file:"$2" asa - <"$1"
+}
+
+atf_test_case space
+space_head() {
+ atf_set descr "First character on line is ' '"
+}
+space_body() {
+ printf " %s\n %s\n" "$a" "$b" >infile
+ printf "%s\n%s\n" "$a" "$b" >outfile
+ atf_check_asa infile outfile
+}
+
+atf_test_case zero
+zero_head() {
+ atf_set descr "First character on line is '0'"
+}
+zero_body() {
+ printf " %s\n0%s\n" "$a" "$b" >infile
+ printf "%s\n\n%s\n" "$a" "$b" >outfile
+ atf_check_asa infile outfile
+}
+
+atf_test_case one
+one_head() {
+ atf_set descr "First character on line is '1'"
+}
+one_body() {
+ printf " %s\n1%s\n" "$a" "$b" >infile
+ printf "%s\f%s\n" "$a" "$b" >outfile
+ atf_check_asa infile outfile
+}
+
+atf_test_case plus
+plus_head() {
+ atf_set descr "First character on line is '+'"
+}
+plus_body() {
+ printf " %s\n+%s\n" "$a" "$b" >infile
+ printf "%s\r%s\n" "$a" "$b" >outfile
+ atf_check_asa infile outfile
+}
+
+atf_test_case plus_top
+plus_top_head() {
+ atf_set descr "First character in input is '+'"
+}
+plus_top_body() {
+ printf "+%s\n+%s\n" "$a" "$b" >infile
+ printf "%s\r%s\n" "$a" "$b" >outfile
+ atf_check_asa infile outfile
+}
+
+atf_test_case stdout
+stdout_head() {
+ atf_set descr "Failure to write to stdout"
+}
+stdout_body() {
+ (
+ trap "" PIPE
+ echo " $a $b" | asa 2>stderr
+ echo $? >result
+ ) | true
+ atf_check -o inline:"1\n" cat result
+ atf_check -o match:"stdout" cat stderr
+}
+
+atf_test_case dashdash
+dashdash_head() {
+ atf_set descr "Use -- to end options"
+}
+dashdash_body() {
+ echo " $a $b" >-infile
+ atf_check -s not-exit:0 -e match:"illegal option" asa -infile
+ atf_check -o inline:"$a $b\n" asa -- -infile
+}
+
+atf_init_test_cases()
+{
+ atf_add_test_case space
+ atf_add_test_case zero
+ atf_add_test_case one
+ atf_add_test_case plus
+ atf_add_test_case plus_top
+ atf_add_test_case stdout
+ atf_add_test_case dashdash
+}