From dd3bbb976be76325f4115f9f0ef51b3e6dde75c5 Mon Sep 17 00:00:00 2001 From: Tavian Barnes Date: Mon, 9 Nov 2020 17:01:33 -0500 Subject: opt: Predicates aren't true when they're false This unfortunate typo was mostly harmless; since the predicates were always assumed to be true, they wouldn't conflict. The exception is -user/-group, which set -nouser/-nogroup to false for users/groups that exist. Even -O0 wasn't enough to suppress the bug, due to a missing optlevel check fixed in the previous commit. Fixes: 305ee902874b49351f4916e303c293523f11570b --- tests.sh | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'tests.sh') diff --git a/tests.sh b/tests.sh index 7276672..673e155 100755 --- a/tests.sh +++ b/tests.sh @@ -196,6 +196,7 @@ posix_tests=( test_group_name test_group_id + test_group_nogroup test_links test_links_plus @@ -244,6 +245,7 @@ posix_tests=( test_user_name test_user_id + test_user_nouser # Closed file descriptors test_closed_stdin @@ -1376,6 +1378,11 @@ function test_user_id() { bfs_diff basic -user "$(id -u)" } +function test_user_nouser() { + # Regression test: this was wrongly optimized to -false + bfs_diff basic -user "$(id -u)" \! -nouser +} + function test_group_name() { bfs_diff basic -group "$(id -gn)" } @@ -1384,6 +1391,11 @@ function test_group_id() { bfs_diff basic -group "$(id -g)" } +function test_group_nogroup() { + # Regression test: this was wrongly optimized to -false + bfs_diff basic -group "$(id -g)" \! -nogroup +} + function test_daystart() { bfs_diff basic -daystart -mtime 0 } -- cgit v1.2.3