Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/tests/usr.bin/indent tests/indent: cover more error cases an...
details: https://anonhg.NetBSD.org/src/rev/1195b5ea63f1
branches: trunk
changeset: 1024258:1195b5ea63f1
user: rillig <rillig%NetBSD.org@localhost>
date: Thu Oct 14 18:55:41 2021 +0000
description:
tests/indent: cover more error cases and inline indentation
diffstat:
tests/usr.bin/indent/t_errors.sh | 222 ++++++++++++++++++++++++++++++++++++++-
tests/usr.bin/indent/t_misc.sh | 24 ++++-
2 files changed, 244 insertions(+), 2 deletions(-)
diffs (295 lines):
diff -r 89fc8c41e7c1 -r 1195b5ea63f1 tests/usr.bin/indent/t_errors.sh
--- a/tests/usr.bin/indent/t_errors.sh Thu Oct 14 17:42:12 2021 +0000
+++ b/tests/usr.bin/indent/t_errors.sh Thu Oct 14 18:55:41 2021 +0000
@@ -1,5 +1,5 @@
#! /bin/sh
-# $NetBSD: t_errors.sh,v 1.2 2021/10/14 17:42:13 rillig Exp $
+# $NetBSD: t_errors.sh,v 1.3 2021/10/14 18:55:41 rillig Exp $
#
# Copyright (c) 2021 The NetBSD Foundation, Inc.
# All rights reserved.
@@ -85,6 +85,48 @@
-U./nonexistent
}
+atf_test_case 'option_tabsize_negative'
+option_tabsize_negative_body()
+{
+ expect_error \
+ 'indent: Command line: option "-ts" requires an integer parameter' \
+ -ts-1
+}
+
+atf_test_case 'option_tabsize_zero'
+option_tabsize_zero_body()
+{
+ expect_error \
+ 'indent: invalid tabsize 0' \
+ -ts0
+}
+
+atf_test_case 'option_tabsize_large'
+option_tabsize_large_body()
+{
+ # Integer overflow, on both ILP32 and LP64 platforms.
+ expect_error \
+ 'indent: invalid tabsize 81' \
+ -ts81
+}
+
+atf_test_case 'option_tabsize_very_large'
+option_tabsize_very_large_body()
+{
+ # Integer overflow, on both ILP32 and LP64 platforms.
+ expect_error \
+ 'indent: invalid tabsize -1294967296' \
+ -ts3000000000
+}
+
+atf_test_case 'option_indent_size_zero'
+option_indent_size_zero_body()
+{
+ expect_error \
+ 'indent: invalid indentation 0' \
+ -i0
+}
+
atf_test_case 'option_buffer_overflow'
option_buffer_overflow_body()
{
@@ -128,6 +170,168 @@
"$indent" -st < comment.c
}
+atf_test_case 'in_place_wrong_backup'
+in_place_wrong_backup_body()
+{
+ cat <<-\EOF > code.c
+ int decl;
+ EOF
+ cp code.c code.c.orig
+
+ # Due to the strange backup suffix '/subdir', indent tries to create
+ # a file named 'code.c/subdir', but 'code.c' is already a regular
+ # file, not a directory.
+ atf_check -s 'exit:1' \
+ -e 'inline:indent: code.c/subdir: Not a directory'"$nl" \
+ env SIMPLE_BACKUP_SUFFIX="/subdir" "$indent" code.c
+
+ # Since there was an early error, the original file is kept as is.
+ atf_check -o 'file:code.c.orig' \
+ cat code.c
+}
+
+atf_test_case 'argument_input_enoent'
+argument_input_enoent_body()
+{
+ atf_check -s 'exit:1' \
+ -e 'inline:indent: ./nonexistent.c: No such file or directory'"$nl" \
+ "$indent" ./nonexistent.c
+}
+
+atf_test_case 'argument_output_equals_input_name'
+argument_output_equals_input_name_body()
+{
+ echo '/* comment */' > code.c
+
+ atf_check -s 'exit:1' \
+ -e 'inline:indent: input and output files must be different'"$nl" \
+ "$indent" code.c code.c
+}
+
+atf_test_case 'argument_output_equals_input_file'
+argument_output_equals_input_file_body()
+{
+ echo '/* comment */' > code.c
+
+ atf_check \
+ "$indent" code.c ./code.c
+
+ # Oops, the file has become empty since the output is first emptied,
+ # before reading any of the input.
+ atf_check \
+ cat code.c
+}
+
+atf_test_case 'argument_output_enoent'
+argument_output_enoent_body()
+{
+ expect_error \
+ 'indent: subdir/nonexistent.c: No such file or directory' \
+ /dev/null subdir/nonexistent.c
+}
+
+atf_test_case 'argument_too_many'
+argument_too_many_body()
+{
+ echo '/* comment */' > arg1.c
+
+ expect_error \
+ 'indent: unknown parameter: arg3.c' \
+ arg1.c arg2.c arg3.c arg4.c
+}
+
+atf_test_case 'unexpected_end_of_file'
+unexpected_end_of_file_body()
+{
+ echo 'struct{' > code.c
+
+ expect_error \
+ 'Error@1: Stuff missing from end of file' \
+ code.c
+
+ atf_check \
+ -o 'inline:struct {'"$nl" \
+ cat code.c
+}
+
+atf_test_case 'unexpected_closing_brace_top_level'
+unexpected_closing_brace_top_level_body()
+{
+ echo '}' > code.c
+
+ expect_error \
+ 'Error@1: Statement nesting error' \
+ code.c
+ atf_check \
+ -o 'inline:}'"$nl" \
+ cat code.c
+}
+
+atf_test_case 'unexpected_closing_brace_decl'
+unexpected_closing_brace_decl_body()
+{
+ echo 'int i = 3};' > code.c
+
+ expect_error \
+ 'Error@1: Statement nesting error' \
+ code.c
+ # Despite the error message, the original file got overwritten with a
+ # best-effort rewrite of the code.
+ atf_check \
+ -o 'inline:int i = 3};'"$nl" \
+ cat code.c
+}
+
+atf_test_case 'preprocessing_overflow'
+preprocessing_overflow_body()
+{
+ cat <<-\EOF > code.c
+ #if 1
+ #if 2
+ #if 3
+ #if 4
+ #if 5
+ #if 6
+ #endif 6
+ #endif 5
+ #endif 4
+ #endif 3
+ #endif 2
+ #endif 1
+ #endif too much
+ EOF
+ cat <<-\EOF > stderr.exp
+ Error@6: #if stack overflow
+ Error@12: Unmatched #endif
+ Error@13: Unmatched #endif
+ EOF
+
+ atf_check -s 'exit:1' \
+ -e 'file:stderr.exp' \
+ "$indent" code.c
+}
+
+atf_test_case 'preprocessing_unrecognized'
+preprocessing_unrecognized_body()
+{
+ cat <<-\EOF > code.c
+ #unknown
+ # 3 "file.c"
+ #elif 3
+ #else
+ EOF
+ cat <<-\EOF > stderr.exp
+ Error@1: Unrecognized cpp directive
+ Error@2: Unrecognized cpp directive
+ Error@3: Unmatched #elif
+ Error@4: Unmatched #else
+ EOF
+
+ atf_check -s 'exit:1' \
+ -e 'file:stderr.exp' \
+ "$indent" code.c
+}
+
atf_init_test_cases()
{
atf_add_test_case 'option_unknown'
@@ -137,5 +341,21 @@
atf_add_test_case 'option_buffer_overflow'
atf_add_test_case 'option_typedefs_not_found'
atf_add_test_case 'option_special_missing_param'
+ atf_add_test_case 'option_tabsize_negative'
+ atf_add_test_case 'option_tabsize_zero'
+ atf_add_test_case 'option_tabsize_large'
+ atf_add_test_case 'option_tabsize_very_large'
+ atf_add_test_case 'option_indent_size_zero'
atf_add_test_case 'unterminated_comment'
+ atf_add_test_case 'in_place_wrong_backup'
+ atf_add_test_case 'argument_input_enoent'
+ atf_add_test_case 'argument_output_equals_input_name'
+ atf_add_test_case 'argument_output_equals_input_file'
+ atf_add_test_case 'argument_output_enoent'
+ atf_add_test_case 'argument_too_many'
+ atf_add_test_case 'unexpected_end_of_file'
+ atf_add_test_case 'unexpected_closing_brace_top_level'
+ atf_add_test_case 'unexpected_closing_brace_decl'
+ atf_add_test_case 'preprocessing_overflow'
+ atf_add_test_case 'preprocessing_unrecognized'
}
diff -r 89fc8c41e7c1 -r 1195b5ea63f1 tests/usr.bin/indent/t_misc.sh
--- a/tests/usr.bin/indent/t_misc.sh Thu Oct 14 17:42:12 2021 +0000
+++ b/tests/usr.bin/indent/t_misc.sh Thu Oct 14 18:55:41 2021 +0000
@@ -1,5 +1,5 @@
#! /bin/sh
-# $NetBSD: t_misc.sh,v 1.1 2021/10/14 17:42:13 rillig Exp $
+# $NetBSD: t_misc.sh,v 1.2 2021/10/14 18:55:41 rillig Exp $
#
# Copyright (c) 2021 The NetBSD Foundation, Inc.
# All rights reserved.
@@ -31,6 +31,27 @@
# used in t_indent.
indent=$(atf_config_get usr.bin.indent.test_indent /usr/bin/indent)
+nl='
+'
+
+atf_test_case 'in_place'
+in_place_body()
+{
+ cat <<-\EOF > code.c
+ int decl;
+ EOF
+ cat <<-\EOF > code.c.exp
+ int decl;
+ EOF
+ cp code.c code.c.orig
+
+ atf_check \
+ env SIMPLE_BACKUP_SUFFIX=".bak" "$indent" code.c
+ atf_check -o 'file:code.c.exp' \
+ cat code.c
+ atf_check -o 'file:code.c.orig' \
+ cat code.c.bak
+}
atf_test_case 'verbose_profile'
verbose_profile_body()
@@ -72,5 +93,6 @@
atf_init_test_cases()
{
+ atf_add_test_case 'in_place'
atf_add_test_case 'verbose_profile'
}
Home |
Main Index |
Thread Index |
Old Index