Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/tests/usr.bin/printf Stop assuming that printf handles optio...
details: https://anonhg.NetBSD.org/src/rev/408aeab7b5fe
branches: trunk
changeset: 962431:408aeab7b5fe
user: kre <kre%NetBSD.org@localhost>
date: Sun Jul 21 15:25:59 2019 +0000
description:
Stop assuming that printf handles options in any way at all
(it doesn't - that is, shouldn't) which includes processing -- as an
"end of options". The first arg is (always) the format string.
Remove/fix tests that assumed the contrary.
Problem (with printf) pointed out on tech-userlevel by Thierry Laronde.
diffstat:
tests/usr.bin/printf/printf.sh | 37 +++++++++++++++++--------------------
1 files changed, 17 insertions(+), 20 deletions(-)
diffs (69 lines):
diff -r f2e4ad83efd9 -r 408aeab7b5fe tests/usr.bin/printf/printf.sh
--- a/tests/usr.bin/printf/printf.sh Sun Jul 21 15:25:39 2019 +0000
+++ b/tests/usr.bin/printf/printf.sh Sun Jul 21 15:25:59 2019 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: printf.sh,v 1.3 2018/09/14 19:57:57 kre Exp $
+# $NetBSD: printf.sh,v 1.4 2019/07/21 15:25:59 kre Exp $
#
# Copyright (c) 2018 The NetBSD Foundation, Inc.
# All rights reserved.
@@ -206,23 +206,21 @@
{
setmsg basic
- for A in '' -- -@ # hope that '@' is not an option to printf...
+ if (do_printf >/dev/null 2>&1)
+ then
+ atf_fail "with no args successful"
+ fi
+ if test -n "$( do_printf 2>/dev/null )"
+ then
+ atf_fail "with no args produces text on stdout"
+ fi
+ if test -z "$( do_printf 2>&1 )"
+ then
+ atf_fail "with no args no err/usage message"
+ fi
+
+ for A in - -- X 1
do
- if (do_printf $A >/dev/null 2>&1)
- then
- atf_fail "${A:-with no args} successful"
- fi
- if test -n "$( do_printf 2>/dev/null )"
- then
- atf_fail "${A:-with no args} produces text on stdout"
- fi
- if test -z "$( do_printf 2>&1 )"
- then
- atf_fail "${A:-with no args} no err/usage message"
- fi
-
- test -z "$A" && continue
-
if (do_printf "%${A}%" >/dev/null 2>&1)
then
atf_fail "%${A}% successful"
@@ -232,11 +230,10 @@
expect abcd abcd
expect % %%
expect xxx%yyy xxx%%yyy
- expect -123 -- -123
+ expect -123 -123
# technically these are all unspecified, but the only rational thing
expect_fail '' %3%
- expect_fail '' -123
expect_fail a a%.%
expect_fail '' '%*%b' # cannot continue after bad format
expect_fail a a%-%b # hence 'b' is not part of output
@@ -1126,7 +1123,7 @@
}
define G_floats '%G (floating) conversions'
-# It is difficul;t to test correct results from the %a conversions,
+# It is difficult to test correct results from the %a conversions,
# as they depend upon the underlying floating point format (not
# necessarily IEEE) and other factors chosen by the implementation,
# eg: the (floating) number 1 could be 0x8p-3 0x4p-2 0x1p-1 even
Home |
Main Index |
Thread Index |
Old Index