diff options
Diffstat (limited to 't/recipes/checks/shell')
53 files changed, 1538 insertions, 0 deletions
diff --git a/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/debian/install b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/debian/install new file mode 100644 index 0000000..f61094c --- /dev/null +++ b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/debian/install @@ -0,0 +1 @@ +has-hashbang usr/share/bash-completion/completions/ diff --git a/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/fill-values b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/fill-values new file mode 100644 index 0000000..23238ad --- /dev/null +++ b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/fill-values @@ -0,0 +1,3 @@ +Skeleton: upload-native +Testname: bash-completion-with-hashbang +Description: A bash completion script that designates an interpreter. diff --git a/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/orig/has-hashbang b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/orig/has-hashbang new file mode 100644 index 0000000..5f3d1be --- /dev/null +++ b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/build-spec/orig/has-hashbang @@ -0,0 +1,4 @@ +#!/bin/sh + +This would be a bash-completion script. They are intended to be +sourced and should not designate an interpreter via a hashbang. diff --git a/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/eval/desc b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/eval/desc new file mode 100644 index 0000000..776a730 --- /dev/null +++ b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/eval/desc @@ -0,0 +1,4 @@ +Testname: bash-completion-with-hashbang +Check: shell/bash/completion +See-Also: + https://salsa.debian.org/lintian/lintian/-/merge_requests/292#note_139494 diff --git a/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/eval/hints b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/eval/hints new file mode 100644 index 0000000..9a24bdc --- /dev/null +++ b/t/recipes/checks/shell/bash/completion/bash-completion-with-hashbang/eval/hints @@ -0,0 +1 @@ +bash-completion-with-hashbang (binary): bash-completion-with-hashbang /bin/sh [usr/share/bash-completion/completions/has-hashbang:1] diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/control.in b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/control.in new file mode 100644 index 0000000..24733b6 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/control.in @@ -0,0 +1,16 @@ +Source: [% $source %] +Priority: optional +Section: [% $section %] +Maintainer: [% $author %] +Standards-Version: [% $standards_version %] +Build-Depends: [% $build_depends %] +Rules-Requires-Root: no + +Package: [% $source %] +Architecture: [% $package_architecture %] +Depends: ${shlibs:Depends}, ${misc:Depends}, python2.7, csh, cwltool +Description: [% $description %] + This is a test package designed to exercise some feature or tag of + Lintian. It is part of the Lintian test suite and may do very odd + things. It should not be installed like a regular package. It may + be an empty package. diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/examples b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/examples new file mode 100644 index 0000000..dbf0e0e --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/examples @@ -0,0 +1,9 @@ +bin-env +no-interpreter +not-absolute +syntax +unusual +unversioned-pike +usr-bin-env-perl +usr-local +wrong-perl-path diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/install b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/install new file mode 100644 index 0000000..eb2fbdd --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/install @@ -0,0 +1,14 @@ +bin-env usr/bin/ +csh-shell usr/bin/ +cwl-runner usr/bin/ +no-interpreter usr/bin/ +not-absolute usr/bin/ +python2.7 usr/bin/ +syntax usr/bin/ +unusual usr/bin/ +unversioned-pike usr/bin/ +usr-bin-env-perl usr/bin/ +usr-local usr/bin/ +usr-local-bin-perl usr/bin/ +versioned-pike usr/bin/ +wrong-perl-path usr/bin/ diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/links b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/links new file mode 100644 index 0000000..ff8f522 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/links @@ -0,0 +1,14 @@ +usr/share/man/man1/interpreters.1 usr/share/man/man1/bin-env.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/csh-shell.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/cwl-runner.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/no-interpreter.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/not-absolute.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/python2.7.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/syntax.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/unusual.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/unversioned-pike.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/usr-bin-env-perl.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/usr-local.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/usr-local-bin-perl.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/versioned-pike.1 +usr/share/man/man1/interpreters.1 usr/share/man/man1/wrong-perl-path.1 diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/manpages b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/manpages new file mode 100644 index 0000000..74d51b8 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/debian/manpages @@ -0,0 +1 @@ +interpreters.1 diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/fill-values b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/fill-values new file mode 100644 index 0000000..f92de59 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/fill-values @@ -0,0 +1,3 @@ +Skeleton: upload-native +Testname: scripts-interpreters +Description: Check various script interpreter issues diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/bin-env b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/bin-env new file mode 100644 index 0000000..005e1a9 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/bin-env @@ -0,0 +1,2 @@ +#!/bin/env perl +print "Hello world\n"; diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/csh-shell b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/csh-shell new file mode 100644 index 0000000..3e39c0b --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/csh-shell @@ -0,0 +1 @@ +#!/bin/csh diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/cwl-runner b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/cwl-runner new file mode 100644 index 0000000..3f3280f --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/cwl-runner @@ -0,0 +1 @@ +#!/usr/bin/cwl-runner diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/interpreters.1 b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/interpreters.1 new file mode 100644 index 0000000..9e6dd89 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/interpreters.1 @@ -0,0 +1,5 @@ +.TH interpreters 1 "Debian Utilities" "DEBIAN" \" -*- nroff -*- +.SH NAME +interpreters \- test script + +Dummy manpage to avoid triggering warnings about it not existing. diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/no-interpreter b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/no-interpreter new file mode 100644 index 0000000..3487806 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/no-interpreter @@ -0,0 +1,3 @@ +#! +# Script missing any interpreter. +true diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/not-absolute b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/not-absolute new file mode 100644 index 0000000..ee656c6 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/not-absolute @@ -0,0 +1,2 @@ +#!perl +print "Hello world\n"; diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/python2.7 b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/python2.7 new file mode 100644 index 0000000..1989667 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/python2.7 @@ -0,0 +1,3 @@ +#!/usr/bin/python2.7 +import sys +sys.exit(0) diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/syntax b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/syntax new file mode 100644 index 0000000..c04b97f --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/syntax @@ -0,0 +1,4 @@ +#!/bin/sh +# A shell script with a syntax error. +if true ; then + echo True diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/unusual b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/unusual new file mode 100644 index 0000000..8a74f66 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/unusual @@ -0,0 +1,2 @@ +#!/usr/bin/lintian +use lintian shell to check package diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/unversioned-pike b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/unversioned-pike new file mode 100644 index 0000000..f1eaf01 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/unversioned-pike @@ -0,0 +1,4 @@ +#! /usr/bin/pike + +This is not a real pike script but sufficient to trigger a warning that the package +is missing a dependency for the interpreter. diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-bin-env-perl b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-bin-env-perl new file mode 100644 index 0000000..069c68b --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-bin-env-perl @@ -0,0 +1,3 @@ +#!/usr/bin/env perl + +print "Hello world\n"; diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-local b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-local new file mode 100644 index 0000000..be79cf8 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-local @@ -0,0 +1,2 @@ +#!/usr/local/bin/special-perl +print "Hello world\n"; diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-local-bin-perl b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-local-bin-perl new file mode 100644 index 0000000..3c8f6fa --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/usr-local-bin-perl @@ -0,0 +1,3 @@ +#!/usr/local/bin/perl + +print "Hello world\n"; diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/versioned-pike b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/versioned-pike new file mode 100644 index 0000000..6b3b65b --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/versioned-pike @@ -0,0 +1,4 @@ +#! /usr/bin/pike7.6 + +This is not a real pike script but sufficient to trigger a warning that the package +is missing a dependency for the interpreter. diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/wrong-perl-path b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/wrong-perl-path new file mode 100644 index 0000000..1602d4e --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/build-spec/orig/wrong-perl-path @@ -0,0 +1,2 @@ +#!/bin/perl +print "Hello world\n"; diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/eval/desc b/t/recipes/checks/shell/csh/scripts-interpreters/eval/desc new file mode 100644 index 0000000..4d07dd2 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/eval/desc @@ -0,0 +1,4 @@ +Testname: scripts-interpreters +Check: shell/csh +See-Also: + Bug#543873 diff --git a/t/recipes/checks/shell/csh/scripts-interpreters/eval/hints b/t/recipes/checks/shell/csh/scripts-interpreters/eval/hints new file mode 100644 index 0000000..1ce9224 --- /dev/null +++ b/t/recipes/checks/shell/csh/scripts-interpreters/eval/hints @@ -0,0 +1 @@ +scripts-interpreters (binary): csh-considered-harmful /bin/csh [usr/bin/csh-shell:1] diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/changelog.in b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/changelog.in new file mode 100644 index 0000000..a12fc8c --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/changelog.in @@ -0,0 +1,57 @@ +maintainer-scripts ([% $version %]) [% $distribution %]; urgency=low + + * Doing an upload for QA but I fail to give it a correct version number, + have some uploaders, and also fail to mention it... Bad me ;) + + -- Jeroen van Wolffelaar <jeroen@wolffelaar.nl> Sun, 18 Apr 2004 02:05:29 +0200 + +maintainer-scripts (6.1) unstable; urgency=low + + * I made this entry on my local PC, oops ;) + + -- Jeroen van Wolffelaar <jeroen@mordor> Sat, 21 Feb 2004 18:29:37 +0100 + +maintainer-scripts (6) unstable; urgency=low + + * added ldconfig calls to postrm to check test the postrm tests + from shared-libs + + -- Frank Lichtenheld <djpig@debian.org> Sat, 21 Feb 2004 18:29:36 +0100 + +maintainer-scripts (5) unstable; urgency=low + + * added bash style arrays to postinst, this one is for you Torsten (-: + + -- Sean 'Shaleh' Perry <shaleh@debian.org> Fri, 30 Mar 2001 23:27:06 -0800 + +maintainer-scripts (4) unstable; urgency=low + + * added a here document to the prerm, along with two more bashisms + * made postrm a bash script to check that bash scripts are not searched + + -- Sean 'Shaleh' Perry <shaleh@debian.org> Mon, 26 Feb 2001 13:02:57 -0800 + +maintainer-scripts (3) unstable; urgency=low + + * Added check for '.' called as '. foo || bar', lintian 1.11.15 failed this + thinking the '||' was a argument. + * also added an invalid call to '. foo bar' + * postinst now has a space between the #! and /bin/sh to test the interpreter + checking code. + + -- Sean 'Shaleh' Perry <shaleh@debian.org> Tue, 9 Jan 2001 23:06:25 -0800 + +maintainer-scripts (2) unstable; urgency=low + + * Fix location of changelog. + * prerm and postrm do 'update-alternatives --remove'; should only complain + about postrm. + + -- Colin Watson <cjw44@flatline.org.uk> Fri, 29 Dec 2000 06:01:24 +0000 + +maintainer-scripts (1) unstable; urgency=low + + * Initial version + * postinst and prerm set the usr/doc symlink + + -- Sean 'Shaleh' Perry <shaleh@debian.org> Thu, 16 Nov 2000 09:11:40 -0800 diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/config b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/config new file mode 100644 index 0000000..29abeba --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/config @@ -0,0 +1,3 @@ +#!/usr/bin/python + +# I use python, but that's not what I'm supposed to be allowed to use diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/control.in b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/control.in new file mode 100644 index 0000000..63dd2db --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/control.in @@ -0,0 +1,18 @@ +Source: maintainer-scripts +Section: misc +Priority: optional +Maintainer: QA group <packages@qa.debian.org> +Uploaders: Anyone but Jeroen <jeroen@wolffelaar.nl> +Build-Depends: [% $build_depends %] +Standards-Version: 3.1.1 +Rules-Requires-Root: binary-targets +XS-Dm-Upload-Allowed: Yes + +Package: maintainer-scripts +Architecture: [% $package_architecture %] +Depends: test +Description: test lintian's maintainer script checks + This is a test package designed to exercise some feature or tag of + Lintian. It is part of the Lintian test suite and may do very odd + things. It should not be installed like a regular package. It may + be an empty package. diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/postinst b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/postinst new file mode 100644 index 0000000..e56ed3b --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/postinst @@ -0,0 +1,181 @@ +#! /bin/sh -e + +if [ "$1" = "configure" ]; then + if [ -d /usr/doc -a ! -e /usr/doc/maintainer-scripts -a -d /usr/share/doc/maintainer-scripts ]; then + ln -sf ../share/doc/maintainer-scripts /usr/doc/maintainer-scripts + fi +fi + +# valid +. /usr/share/lintian/shell || exit 0 +. /usr/share/lintian/shell >/dev/null +. /usr/share/lintian/shell 2>/dev/null +. /usr/share/lintian/shell </dev/null +. "$(dirname $0)/shell" ; bar +# invalid +. /usr/share/lintian/shell foo +. "$(dirname $0)/shell" bar + +print "Hit enter to continue" +read + +H[0]='this is a string' +echo ${H[0]} +echo "Index 0's length is ${#H[0]}" +echo "All of the array is: ${H[@]}" + +install-info /usr/share/info/foo \ + --quiet \ # make it so + --section foo + +echo Please use update-rc.d or invoke-rc.d to set up blah blah. + +chown root.root /usr/share/doc/maintainer-scripts/changelog +chown root:root /usr/share/doc/maintainer-scripts/changelog + +$FOO=bar +update-rc.d foo defaults >/dev/null +update-rc.d $FOO defaults +update-rc.d foo remove + +# valid +FOO=/tmp +FOO=/var/tmp +: ${FOO:=/tmp} +FOO=`mktemp /tmp/scripts.XXXXXX` +rm "$FOO" +FOO=`tempfile -n/tmp/scripts.tmp` +mkdir /var/tmp/scripts +FOO="/tmp/false.positive.XXXXXX" +# invalid +echo foo >>/tmp/scripts.tmp +rm /tmp/scripts.tmp +rmdir /var/tmp/scripts + +# invalid, maintainer-script-hides-init-failure +invoke-rc.d foo start || exit 0 + +# The right way to invoke an rc script +if which invoke-rc.d >/dev/null 2>&1; then + invoke-rc.d package start +else + /etc/init.d/package start +fi + +# Example ucf invocation. +ucf /usr/share/foo/configuration /etc/foo.conf + +# Calling gconftool directly. +gconftool-2 --makefile-install-rule foo.schema + +# Calling gconf-schemas with no dependency. +gconf-schemas --register foo.schema + +# Calling update-xmlcatalog with no dependency. +update-xmlcatalog --add --type system --id "/usr/share/sgml/dtd/foo" \ + --package maintainer-scripts --root + +# Maintainer scripts shouldn't touch /var/lib/dpkg/status. This is the old +# recipe from the dpkg wiki that should be replaced with dpkg-query. +sed -n -e \"/^Conffiles:/,/^[^ ]/{\\\\' /etc/conffile'{s/.* //;p}}\" \ + /var/lib/dpkg/status + +# Don't modify these files. +echo 'broken 6714/tcp' >> /etc/services +cp /nonexistent /etc/protocols +mv /usr/share/doc/rpc /etc/rpc + +# But this is okay. +cp /etc/protocols /etc/protocols.new + +# This is also wrong. +echo 'broken' > /etc/inetd.conf +cp /etc/inetd.conf.new /etc/inetd.conf + +# But this is fine. +cp /etc/inetd.conf /srv/chroot/etc/inetd.conf + +# Deprecated +install-sgmlcatalog --install package +install-sgmlcatalog --remove package + +# This too is a heredoc. +some-program > /etc/config-file <<'EOF' +echo "All of the array is: ${H[@]}" +EOF + +# But this isn't. +cat '<<EOF' +echo "All of the array is: ${H[@]}" +EOF + +# This is a heredoc +cat <<-EOF +echo "All of the array is ${H[@]}" +EOF + +# As is this +cat <<';' +echo "All of the array is ${H[@]}" +; + +# and this +cat <<foo +echo "All of the array is ${H[@]}" +foobar +echo $HOSTNAME +foo + +# and again +cat <<\bar +echo "All of the array is ${H[@]}" +bar + +# yet another +cat <<"x++" +echo "All of the array is ${H[@]}" +x++ + +# Recognize single quotes even if they start at the beginning of a line. +echo not a bashism \ +'/{ptex,tex}/{amstex,plain,generic,}' + +# More bashisms. +echo -e 'foo\n' +echo "${!foo}" +cat $(\< file) +select foo in a b ; do echo $foo ; done +cnt=$((cnt + 1)) +if false ; then + exec -l /bin/sh + exec -c /bin/sh + exec -a foo /bin/sh +fi +let cnt++ +if test -a /etc/default ; then + echo "$RANDOM|stuff" +fi + +# Calling start-stop-daemon directly in an init script. +start-stop-daemon --start --quiet --name foo --startas /usr/bin/foo + +# But stopping it is fine -- we may be working around something else. +start-stop-daemon --stop --quiet --name foo --startas /usr/bin/foo + +# Deprecated chown use with flags. +chown -R root.root /usr/share/doc/maintainer-scripts + +case $mainscript in + /usr/bin/foo) foobarbaz;; +esac + +/usr/bin/baz; echo bar + +# Some comment checking +# This should flag $RANDOM +test $# -gt 2 && echo $RANDOM +# But these shouldn't +test 1=1 # echo $RANDOM +(test 1=1)# echo $RANDOM +test 1=1;# echo $RANDOM +backgroundtask &#echo $RA diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/postrm b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/postrm new file mode 100644 index 0000000..c0aaf19 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/postrm @@ -0,0 +1,47 @@ +#!/bin/bash +#set -e + +update-alternatives --remove dummy /usr/bin/dummy-alternative + +# Normally read in a maintainer script is not kosher, but here we're going +# to do it only if debconf doesn't exist. +if ! test -f /usr/share/debconf/confmodule ; then + echo "Hit enter" + read +fi + +# neither of the following should be detected as postrm-unsafe-ldconfig +# intended, without quotes + if [ "$1" = remove ]; then + ldconfig + fi +# reversed, many whitespace +if [ 'remove' = "$1" ] +then + + ldconfig +fi + +[ "remove" ="$1" ] && ldconfig + +update-rc.d bar remove + +# Shouldn't provoke an error despite no invoke-rc.d. +echo "/etc/init.d/package stop to stop something" + +# Shouldn't require a ucf dependency. Unfortunately, right now that's +# just because postrm isn't checked, not because we ensure that the +# invocation is conditional. +if which ucf >/dev/null; then + ucf --purge /etc/foo.conf +fi + +# This isn't allowed. +rm /tmp/foo /dev/device +rm /dev/device1 + +# But this is okay. +rm /tmp/foo > /dev/null + +# Not allowed here even with remove. +install-sgmlcatalog --remove package diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/preinst b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/preinst new file mode 100644 index 0000000..6058978 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/preinst @@ -0,0 +1,18 @@ +#!/bin/sh + +update-rc.d foo remove +update-rc.d bar defaults + +# Obsolete dpkg assertions. +dpkg --assert-support-predepends || exit 1 +dpkg --assert-working-epoch || exit 1 +dpkg --assert-long-filenames || exit 1 +dpkg --assert-multi-conrep || exit 1 + +/bin/grep -E --mmap "^Package: foo$" /var/lib/dpkg/status + +# continuation lines +update-alternatives --install /usr/bin/fakeroot fakeroot \ + /usr/bin/fakeroot-ng 5 \ + --slave /usr/share/man/man1/fakeroot.1.gz \ + fakeroot.1.gz /usr/share/man/man1/fakeroot-ng.1.gz diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/prerm b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/prerm new file mode 100644 index 0000000..076ecaf --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/prerm @@ -0,0 +1,188 @@ +#!/bin/sh + +if [ "$1" != "upgrade" ]; then + update-alternatives --remove dummy /usr/bin/dummy-alternative +fi + +if ([ "$1" = "upgrade" ] || [ "$1" = "remove" ]) && [ -L /usr/doc/maintainer-scripts ]; the +n + rm -f /usr/doc/maintainer-scripts +fi + +cat <<EOF +This is all really bad bash specific code!!! +read +source /bar/baz/bat foo +EOF + +# ok, back to checking +if [ "$2" == "purge" ]; then + rm -r /bar/baz +fi + +function foo( ) { + # but not here: local + local bar + echo "foo" &>/dev/null +} + +source $FOO + +trap "echo hi" EXIT HUP 3 + +if [[ "$2" = "purge" ]]; then + kill -HUP $$ +fi + +#this is ok though +if test -n $(echo foo | perl -pe 's/[[:space:]]//go'); then + echo 1 +fi + +update-rc.d foo remove + +# More false positives for bashism checks. None of these are errors. +echo "$line" | grep -q '{fonts/map,}/{\$progname,pdftex,dvips,}//' +echo "$line" | grep -q "${fonts},${foo}" +echo '$[1+2]' +printf "foo |& bar" +perl -e "print q( kill -HUP $? )" + +# Still catch disallowed expansions in double-quotes, though. +echo "${line:3:1}" + +# The wrong way to run an init script (no invoke-rc.d). +/etc/init.d/package stop + +# This is the only install-sgmlcatalog call that's allowed. +install-sgmlcatalog --quiet --remove package + +# More bashisms checks + +read -x foo +read -x +read -r foo +read foo +read + +echo "a\\b" +echo 'a\nb' + +echo "${UID}" +echo "$EUID" +echo "$SHLVL" +echo "$DIRSTACK" +echo "$SECONDS" +echo "$BASH" +echo "$BASH_FOO" +echo "$SHELLOPTS" +echo "$PIPESTATUS" + +bar="$(cut '-d|' -f2 <<< "$foo")" + +VAR=1 +VAR+=a + +echos() { + echo -n -e "bar" + echo -e -n "bar" + echo -en "bar" + echo -ne "bar" + echo "bar" + echo "echo -e foo" +} + +ech.os() { + echo foo >& 2 + echo foo >&bar + echo foo >& bar +} + +echoes() { + echo "abc\nxyz" + echo 'xyz\rabc' + echo foo\cbar + + echo -e "abc\nxyz" + echo -net 'xyz\rabc' + echo -e foo\cbar +} + +foobar.() { + suspend x + suspended x + caller x + complete x + compgen x + declare -a foo +} + +.foobar() { + typeset -x bar + disown 1 + builtin foo + set -B + alias -p + unalias -a +} + +IFS="()" + +ulimit +shopt +type -v bar +time ls +dirs +diff <(tac a) <(tac b) + +pushd + +local foo=bar +local -x foo + +popd + +readonly -f + +echo bar > /dev/tcp +export x +export -x x +export -p x + +sh -x +sh -D +sh --foo +sh +O + +# Brace expansion checks +echo {a,b} +echo {abc},{bcd} + +foobar() +{ + # This is a function +} + + foo.bar() +( + # This is a function with a bad name +) + +foobar@() +{ + # As is this +} + +# This is ok +read -r foo +# but these aren't +read -r +read -p "Would you like to restart the service?" foo bar +read --fish + +set -e + +source "$BAR" +source '$BAR' +source ~/bar +source a diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/rules b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/rules new file mode 100755 index 0000000..de4161e --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/rules @@ -0,0 +1,36 @@ +#!/usr/bin/make -f + +build-arch: + +build-indep: + +build: build-arch build-indep + +binary-arch: + +binary-indep: + install -d debian/tmp/DEBIAN + install -m 0755 debian/config debian/tmp/DEBIAN + install -m 0755 debian/preinst debian/tmp/DEBIAN + install -m 0755 debian/postinst debian/tmp/DEBIAN + install -m 0755 debian/prerm debian/tmp/DEBIAN + install -m 0755 debian/postrm debian/tmp/DEBIAN + install -m 0644 debian/triggers debian/tmp/DEBIAN + install -d debian/tmp/usr/share/doc/maintainer-scripts + install -m 0644 debian/changelog \ + debian/tmp/usr/share/doc/maintainer-scripts/changelog + gzip -n -9 debian/tmp/usr/share/doc/maintainer-scripts/changelog + dpkg-gencontrol -isp + dpkg --build debian/tmp .. + +binary: binary-arch binary-indep + +# Make sure we see dh_clean even in a rule clean depends on. Not the point of +# this test suite, but a convenient place to put it. +clean: clean1 clean2 clean3 +clean1: +clean2: + dh_clean +clean3: + +.PHONY: build-arch build-indep build binary-arch binary-indep binary clean diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/triggers b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/triggers new file mode 100644 index 0000000..f627094 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/triggers @@ -0,0 +1,4 @@ +# Example triggers file +activate foo + +interest bar diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/watch b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/watch new file mode 100644 index 0000000..430eea3 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/debian/watch @@ -0,0 +1,11 @@ +# A whitespace is fine for uscan: + version=5 + +# Following line should not be matched: +#opts=uversionmangle=s/$/+debian/,dversionmangle=s/foo/bar/ \ +# Following one is incorrect, there's a missing backslash at the end +opts=uversionmangle=s/$/+dfsg/,dversionmangle=s/foo/bar/ + +# 'active' is useless here, but it works anyway +options=active \ +http://domain.tld/foo-(.+)\.tar\.gz
\ No newline at end of file diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/fill-values b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/fill-values new file mode 100644 index 0000000..c281e87 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/build-spec/fill-values @@ -0,0 +1,6 @@ +Skeleton: upload-non-native +Testname: legacy-maintainer-scripts +Source: maintainer-scripts +Version: 7+dfsg-0.1 +Description: Legacy test "maintainer-scripts" +Extra-Build-Depends: dash (>= 0.5.10.2) diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/desc b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/desc new file mode 100644 index 0000000..6653368 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/desc @@ -0,0 +1,2 @@ +Testname: legacy-maintainer-scripts +Check: shell/non-posix/bash-centric diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/hints b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/hints new file mode 100644 index 0000000..d0656ee --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/hints @@ -0,0 +1,97 @@ +maintainer-scripts (binary): possible-bashism-in-maintainer-script '{a,b}' [prerm:158] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'unalias -a' [prerm:126] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'ulimit' [prerm:131] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'typeset' [prerm:121] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'time' [prerm:134] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'test -a' [postinst:155] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'suspend' [prerm:112] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'source ~/bar' [prerm:187] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'source a' [prerm:188] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'source /bar/baz/bat' [prerm:15] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'source '$BAR'' [prerm:186] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'source $FOO' [prerm:29] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'source "$BAR"' [prerm:185] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'shopt' [prerm:132] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'sh -D' [prerm:153] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'sh --foo' [prerm:154] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'sh +O' [prerm:155] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'set -B' [prerm:124] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'select foo' [postinst:147] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'readonly -f' [prerm:145] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'read' [prerm:66] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'read' [prerm:14] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'read' [postinst:20] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'read -x' [prerm:63] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'read -x' [prerm:62] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'read -r' [prerm:179] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'read -p' [prerm:180] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'read --fish' [prerm:181] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'pushd' [prerm:138] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'popd' [prerm:143] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'local -x' [prerm:141] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'let' [postinst:154] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'function foo(' [prerm:23] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'foobar@()' [prerm:171] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'foobar.() {' [prerm:111] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'foo.bar()' [prerm:166] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'export -x' [prerm:149] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'exec -l' [postinst:150] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'exec -c' [postinst:151] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'exec -a' [postinst:152] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo -ne' [prerm:90] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo -ne' [prerm:107] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo -n -e' [prerm:87] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo -en' [prerm:89] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo -e' [prerm:88] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo -e' [prerm:108] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo -e' [prerm:106] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo -e' [postinst:144] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo 'xyz\rabc'' [prerm:103] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo 'a\nb'' [prerm:69] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo "abc\nxyz"' [prerm:102] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'echo "a\\b"' [prerm:68] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'ech.os() {' [prerm:95] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'disown' [prerm:122] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'dirs' [prerm:135] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'declare' [prerm:117] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'complete' [prerm:115] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'compgen' [prerm:116] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'caller' [prerm:114] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'builtin' [prerm:123] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'alias -p' [prerm:125] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '[[' [prerm:33] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '[ "$2" ==' [prerm:19] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'VAR+=' [prerm:84] +maintainer-scripts (binary): possible-bashism-in-maintainer-script 'H[0]=' [postinst:22] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '>&bar' [prerm:97] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '>& bar' [prerm:98] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '<<<' [prerm:81] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '<(tac a)' [prerm:136] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '/dev/tcp' [prerm:147] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '.foobar() {' [prerm:120] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '. /usr/share/lintian/shell foo' [postinst:16] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '. "$(dirname $0)/shell"' [postinst:17] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '&>' [prerm:26] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${line:3:1}' [prerm:52] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${UID' [prerm:71] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:25] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:136] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:131] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:124] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:119] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:114] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:109] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:104] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${H[0]}' [postinst:23] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${#H[0]}' [postinst:24] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '${!foo}' [postinst:145] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$SHLVL' [prerm:73] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$SHELLOPTS' [prerm:78] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$SECONDS' [prerm:75] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$RANDOM' [postinst:176] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$RANDOM' [postinst:156] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$PIPESTATUS' [prerm:79] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$HOSTNAME' [postinst:126] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$EUID' [prerm:72] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$DIRSTACK' [prerm:74] +maintainer-scripts (binary): possible-bashism-in-maintainer-script '$BASH_FOO' [prerm:77] diff --git a/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/post-test b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/post-test new file mode 100644 index 0000000..faeef0b --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/legacy-maintainer-scripts/eval/post-test @@ -0,0 +1 @@ +s/\(current is ([0-9]+\.)+[0-9]\)/(current is CURRENT)/ diff --git a/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/debian/install b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/debian/install new file mode 100644 index 0000000..aaad16b --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/debian/install @@ -0,0 +1 @@ +scripts/* usr/bin diff --git a/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/fill-values b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/fill-values new file mode 100644 index 0000000..8efbbf3 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/fill-values @@ -0,0 +1,4 @@ +Testname: regular-shipped +Skeleton: upload-non-native +Description: Check bashism detection +Extra-Build-Depends: dash (>= 0.5.10.2) diff --git a/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/orig/scripts/one b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/orig/scripts/one new file mode 100644 index 0000000..7004ffc --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/orig/scripts/one @@ -0,0 +1,87 @@ +#! /bin/sh -e + +# valid +. /usr/share/lintian/shell || exit 0 +. /usr/share/lintian/shell >/dev/null +. /usr/share/lintian/shell 2>/dev/null +. /usr/share/lintian/shell </dev/null +. "$(dirname $0)/shell" ; bar +# invalid +. /usr/share/lintian/shell foo +. "$(dirname $0)/shell" bar + +print "Hit enter to continue" +read + +H[0]='this is a string' +echo ${H[0]} +echo "Index 0's length is ${#H[0]}" +echo "All of the array is: ${H[@]}" + +# This too is a heredoc. +some-program > /etc/config-file <<'EOF' +echo "All of the array is: ${H[@]}" +EOF + +# But this isn't. +cat '<<EOF' +echo "All of the array is: ${H[@]}" +EOF + +# This is a heredoc +cat <<-EOF +echo "All of the array is ${H[@]}" +EOF + +# As is this +cat <<';' +echo "All of the array is ${H[@]}" +; + +# and this +cat <<foo +echo "All of the array is ${H[@]}" +foobar +echo $HOSTNAME +foo + +# and again +cat <<\bar +echo "All of the array is ${H[@]}" +bar + +# yet another +cat <<"x++" +echo "All of the array is ${H[@]}" +x++ + +# Recognize single quotes even if they start at the beginning of a line. +echo not a bashism \ +'/{ptex,tex}/{amstex,plain,generic,}' + +# More bashisms. +echo -e 'foo\n' +echo "${!foo}" +cat $(\< file) +select foo in a b ; do echo $foo ; done +cnt=$((cnt + 1)) +if false ; then + exec -l /bin/sh + exec -c /bin/sh + exec -a foo /bin/sh +fi +let cnt++ +if test -a /etc/default ; then + echo "$RANDOM|stuff" +fi + +# Some comment checking +# This should flag $RANDOM +test $# -gt 2 && echo $RANDOM +# But these shouldn't +test 1=1 # echo $RANDOM +(test 1=1)# echo $RANDOM +test 1=1;# echo $RANDOM +backgroundtask &#echo $RA + +#DEBHELPER# diff --git a/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/orig/scripts/two b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/orig/scripts/two new file mode 100644 index 0000000..84098f7 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/build-spec/orig/scripts/two @@ -0,0 +1,186 @@ +#!/bin/sh + +set -e + +cat <<EOF +This is all really bad bash specific code!!! +read +source /bar/baz/bat foo +EOF + +# ok, back to checking +if [ "$2" == "purge" ]; then + rm -r /bar/baz +fi + +function foo( ) { + # but not here: local + local bar + echo "foo" &>/dev/null +} + +source $FOO + +trap "echo hi" EXIT HUP 3 + +if [[ "$2" = "purge" ]]; then + kill -HUP $$ +fi + +#this is ok though +if test -n $(echo foo | perl -pe 's/[[:space:]]//go'); then + echo 1 +fi + +# More false positives for bashism checks. None of these are errors. +echo "$line" | grep -q '{fonts/map,}/{\$progname,pdftex,dvips,}//' +echo "$line" | grep -q "${fonts},${foo}" +echo '$[1+2]' +printf "foo |& bar" +perl -e "print q( kill -HUP $? )" + +# Still catch disallowed expansions in double-quotes, though. +echo "${line:3:1}" + +# More bashisms checks + +read -x foo +read -x +read -r foo +read foo +read + +echo "a\\b" +echo 'a\nb' + +echo "${UID}" +echo "$EUID" +echo "$SHLVL" +echo "$DIRSTACK" +echo "$SECONDS" +echo "$BASH" +echo "$BASH_FOO" +echo "$SHELLOPTS" +echo "$PIPESTATUS" + +bar="$(cut '-d|' -f2 <<< "$foo")" + +VAR=1 +VAR+=a + +echos() { + echo -n -e "bar" + echo -e -n "bar" + echo -en "bar" + echo -ne "bar" + echo "bar" + echo "echo -e foo" +} + +ech.os() { + echo foo >& 2 + echo foo >&bar + echo foo >& bar +} + +echoes() { + echo "abc\nxyz" + echo 'xyz\rabc' + echo foo\cbar + + echo -e "abc\nxyz" + echo -net 'xyz\rabc' + echo -e foo\cbar +} + +foobar.() { + suspend x + suspended x + caller x + complete x + compgen x + declare -a foo +} + +.foobar() { + typeset -x bar + disown 1 + builtin foo + set -B + alias -p + unalias -a +} + +IFS="()" + +ulimit +shopt +type -v bar +time ls +dirs +diff <(tac a) <(tac b) + +pushd + +local foo=bar +local -x foo + +popd + +readonly -f + +echo bar > /dev/tcp +export x +export -x x +export -p x + +sh -x +sh -D +sh --foo +sh +O + +# Brace expansion checks +echo {a,b} +echo {abc},{bcd} + +foobar() +{ + # This is a function +} + + foo.bar() +( + # This is a function with a bad name +) + +foobar@() # foo +{ + # As is this +} + +# This is ok +read -r foo +# but these aren't +read -r +read -p "Would you like to restart the service?" foo bar +read --fish + +source "$BAR" +source '$BAR' +source ~/bar +source a + +# An example from the X maintainer scripts that used to trigger the trap +# bashism check. +trap "message;\ + message \"Received signal. Aborting $THIS_PACKAGE package $THIS_SCRIPT script.\";\ + message;\ + exit 1" HUP INT QUIT TERM + +# Also allow for extended single quotes containing double quotes. +trap 'message; + message "Received signal. Aborting $THIS_PACKAGE package $THIS_SCRIPT script."; + message; + exit 1' HUP INT QUIT TERM + +#DEBHELPER# diff --git a/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/eval/desc b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/eval/desc new file mode 100644 index 0000000..aa7af08 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/eval/desc @@ -0,0 +1,2 @@ +Testname: regular-shipped +Check: shell/non-posix/bash-centric diff --git a/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/eval/hints b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/eval/hints new file mode 100644 index 0000000..94e10dc --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/regular-shipped/eval/hints @@ -0,0 +1,97 @@ +regular-shipped (binary): bash-term-in-posix-shell '{a,b}' [usr/bin/two:143] +regular-shipped (binary): bash-term-in-posix-shell 'unalias -a' [usr/bin/two:111] +regular-shipped (binary): bash-term-in-posix-shell 'ulimit' [usr/bin/two:116] +regular-shipped (binary): bash-term-in-posix-shell 'typeset' [usr/bin/two:106] +regular-shipped (binary): bash-term-in-posix-shell 'time' [usr/bin/two:119] +regular-shipped (binary): bash-term-in-posix-shell 'test -a' [usr/bin/one:74] +regular-shipped (binary): bash-term-in-posix-shell 'suspend' [usr/bin/two:97] +regular-shipped (binary): bash-term-in-posix-shell 'source ~/bar' [usr/bin/two:170] +regular-shipped (binary): bash-term-in-posix-shell 'source a' [usr/bin/two:171] +regular-shipped (binary): bash-term-in-posix-shell 'source /bar/baz/bat' [usr/bin/two:8] +regular-shipped (binary): bash-term-in-posix-shell 'source '$BAR'' [usr/bin/two:169] +regular-shipped (binary): bash-term-in-posix-shell 'source $FOO' [usr/bin/two:22] +regular-shipped (binary): bash-term-in-posix-shell 'source "$BAR"' [usr/bin/two:168] +regular-shipped (binary): bash-term-in-posix-shell 'shopt' [usr/bin/two:117] +regular-shipped (binary): bash-term-in-posix-shell 'sh -D' [usr/bin/two:138] +regular-shipped (binary): bash-term-in-posix-shell 'sh --foo' [usr/bin/two:139] +regular-shipped (binary): bash-term-in-posix-shell 'sh +O' [usr/bin/two:140] +regular-shipped (binary): bash-term-in-posix-shell 'set -B' [usr/bin/two:109] +regular-shipped (binary): bash-term-in-posix-shell 'select foo' [usr/bin/one:66] +regular-shipped (binary): bash-term-in-posix-shell 'readonly -f' [usr/bin/two:130] +regular-shipped (binary): bash-term-in-posix-shell 'read' [usr/bin/two:7] +regular-shipped (binary): bash-term-in-posix-shell 'read' [usr/bin/two:51] +regular-shipped (binary): bash-term-in-posix-shell 'read' [usr/bin/one:14] +regular-shipped (binary): bash-term-in-posix-shell 'read -x' [usr/bin/two:48] +regular-shipped (binary): bash-term-in-posix-shell 'read -x' [usr/bin/two:47] +regular-shipped (binary): bash-term-in-posix-shell 'read -r' [usr/bin/two:164] +regular-shipped (binary): bash-term-in-posix-shell 'read -p' [usr/bin/two:165] +regular-shipped (binary): bash-term-in-posix-shell 'read --fish' [usr/bin/two:166] +regular-shipped (binary): bash-term-in-posix-shell 'pushd' [usr/bin/two:123] +regular-shipped (binary): bash-term-in-posix-shell 'popd' [usr/bin/two:128] +regular-shipped (binary): bash-term-in-posix-shell 'local -x' [usr/bin/two:126] +regular-shipped (binary): bash-term-in-posix-shell 'let' [usr/bin/one:73] +regular-shipped (binary): bash-term-in-posix-shell 'function foo(' [usr/bin/two:16] +regular-shipped (binary): bash-term-in-posix-shell 'foobar@()' [usr/bin/two:156] +regular-shipped (binary): bash-term-in-posix-shell 'foobar.() {' [usr/bin/two:96] +regular-shipped (binary): bash-term-in-posix-shell 'foo.bar()' [usr/bin/two:151] +regular-shipped (binary): bash-term-in-posix-shell 'export -x' [usr/bin/two:134] +regular-shipped (binary): bash-term-in-posix-shell 'exec -l' [usr/bin/one:69] +regular-shipped (binary): bash-term-in-posix-shell 'exec -c' [usr/bin/one:70] +regular-shipped (binary): bash-term-in-posix-shell 'exec -a' [usr/bin/one:71] +regular-shipped (binary): bash-term-in-posix-shell 'echo -ne' [usr/bin/two:92] +regular-shipped (binary): bash-term-in-posix-shell 'echo -ne' [usr/bin/two:75] +regular-shipped (binary): bash-term-in-posix-shell 'echo -n -e' [usr/bin/two:72] +regular-shipped (binary): bash-term-in-posix-shell 'echo -en' [usr/bin/two:74] +regular-shipped (binary): bash-term-in-posix-shell 'echo -e' [usr/bin/two:93] +regular-shipped (binary): bash-term-in-posix-shell 'echo -e' [usr/bin/two:91] +regular-shipped (binary): bash-term-in-posix-shell 'echo -e' [usr/bin/two:73] +regular-shipped (binary): bash-term-in-posix-shell 'echo -e' [usr/bin/one:63] +regular-shipped (binary): bash-term-in-posix-shell 'echo 'xyz\rabc'' [usr/bin/two:88] +regular-shipped (binary): bash-term-in-posix-shell 'echo 'a\nb'' [usr/bin/two:54] +regular-shipped (binary): bash-term-in-posix-shell 'echo "abc\nxyz"' [usr/bin/two:87] +regular-shipped (binary): bash-term-in-posix-shell 'echo "a\\b"' [usr/bin/two:53] +regular-shipped (binary): bash-term-in-posix-shell 'ech.os() {' [usr/bin/two:80] +regular-shipped (binary): bash-term-in-posix-shell 'disown' [usr/bin/two:107] +regular-shipped (binary): bash-term-in-posix-shell 'dirs' [usr/bin/two:120] +regular-shipped (binary): bash-term-in-posix-shell 'declare' [usr/bin/two:102] +regular-shipped (binary): bash-term-in-posix-shell 'complete' [usr/bin/two:100] +regular-shipped (binary): bash-term-in-posix-shell 'compgen' [usr/bin/two:101] +regular-shipped (binary): bash-term-in-posix-shell 'caller' [usr/bin/two:99] +regular-shipped (binary): bash-term-in-posix-shell 'builtin' [usr/bin/two:108] +regular-shipped (binary): bash-term-in-posix-shell 'alias -p' [usr/bin/two:110] +regular-shipped (binary): bash-term-in-posix-shell '[[' [usr/bin/two:26] +regular-shipped (binary): bash-term-in-posix-shell '[ "$2" ==' [usr/bin/two:12] +regular-shipped (binary): bash-term-in-posix-shell 'VAR+=' [usr/bin/two:69] +regular-shipped (binary): bash-term-in-posix-shell 'H[0]=' [usr/bin/one:16] +regular-shipped (binary): bash-term-in-posix-shell '>&bar' [usr/bin/two:82] +regular-shipped (binary): bash-term-in-posix-shell '>& bar' [usr/bin/two:83] +regular-shipped (binary): bash-term-in-posix-shell '<<<' [usr/bin/two:66] +regular-shipped (binary): bash-term-in-posix-shell '<(tac a)' [usr/bin/two:121] +regular-shipped (binary): bash-term-in-posix-shell '/dev/tcp' [usr/bin/two:132] +regular-shipped (binary): bash-term-in-posix-shell '.foobar() {' [usr/bin/two:105] +regular-shipped (binary): bash-term-in-posix-shell '. /usr/share/lintian/shell foo' [usr/bin/one:10] +regular-shipped (binary): bash-term-in-posix-shell '. "$(dirname $0)/shell"' [usr/bin/one:11] +regular-shipped (binary): bash-term-in-posix-shell '&>' [usr/bin/two:19] +regular-shipped (binary): bash-term-in-posix-shell '${line:3:1}' [usr/bin/two:43] +regular-shipped (binary): bash-term-in-posix-shell '${UID' [usr/bin/two:56] +regular-shipped (binary): bash-term-in-posix-shell '${H[@]}' [usr/bin/one:55] +regular-shipped (binary): bash-term-in-posix-shell '${H[@]}' [usr/bin/one:50] +regular-shipped (binary): bash-term-in-posix-shell '${H[@]}' [usr/bin/one:43] +regular-shipped (binary): bash-term-in-posix-shell '${H[@]}' [usr/bin/one:38] +regular-shipped (binary): bash-term-in-posix-shell '${H[@]}' [usr/bin/one:33] +regular-shipped (binary): bash-term-in-posix-shell '${H[@]}' [usr/bin/one:28] +regular-shipped (binary): bash-term-in-posix-shell '${H[@]}' [usr/bin/one:23] +regular-shipped (binary): bash-term-in-posix-shell '${H[@]}' [usr/bin/one:19] +regular-shipped (binary): bash-term-in-posix-shell '${H[0]}' [usr/bin/one:17] +regular-shipped (binary): bash-term-in-posix-shell '${#H[0]}' [usr/bin/one:18] +regular-shipped (binary): bash-term-in-posix-shell '${!foo}' [usr/bin/one:64] +regular-shipped (binary): bash-term-in-posix-shell '$SHLVL' [usr/bin/two:58] +regular-shipped (binary): bash-term-in-posix-shell '$SHELLOPTS' [usr/bin/two:63] +regular-shipped (binary): bash-term-in-posix-shell '$SECONDS' [usr/bin/two:60] +regular-shipped (binary): bash-term-in-posix-shell '$RANDOM' [usr/bin/one:80] +regular-shipped (binary): bash-term-in-posix-shell '$RANDOM' [usr/bin/one:75] +regular-shipped (binary): bash-term-in-posix-shell '$PIPESTATUS' [usr/bin/two:64] +regular-shipped (binary): bash-term-in-posix-shell '$HOSTNAME' [usr/bin/one:45] +regular-shipped (binary): bash-term-in-posix-shell '$EUID' [usr/bin/two:57] +regular-shipped (binary): bash-term-in-posix-shell '$DIRSTACK' [usr/bin/two:59] +regular-shipped (binary): bash-term-in-posix-shell '$BASH_FOO' [usr/bin/two:62] diff --git a/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/debian/postinst b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/debian/postinst new file mode 100644 index 0000000..7004ffc --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/debian/postinst @@ -0,0 +1,87 @@ +#! /bin/sh -e + +# valid +. /usr/share/lintian/shell || exit 0 +. /usr/share/lintian/shell >/dev/null +. /usr/share/lintian/shell 2>/dev/null +. /usr/share/lintian/shell </dev/null +. "$(dirname $0)/shell" ; bar +# invalid +. /usr/share/lintian/shell foo +. "$(dirname $0)/shell" bar + +print "Hit enter to continue" +read + +H[0]='this is a string' +echo ${H[0]} +echo "Index 0's length is ${#H[0]}" +echo "All of the array is: ${H[@]}" + +# This too is a heredoc. +some-program > /etc/config-file <<'EOF' +echo "All of the array is: ${H[@]}" +EOF + +# But this isn't. +cat '<<EOF' +echo "All of the array is: ${H[@]}" +EOF + +# This is a heredoc +cat <<-EOF +echo "All of the array is ${H[@]}" +EOF + +# As is this +cat <<';' +echo "All of the array is ${H[@]}" +; + +# and this +cat <<foo +echo "All of the array is ${H[@]}" +foobar +echo $HOSTNAME +foo + +# and again +cat <<\bar +echo "All of the array is ${H[@]}" +bar + +# yet another +cat <<"x++" +echo "All of the array is ${H[@]}" +x++ + +# Recognize single quotes even if they start at the beginning of a line. +echo not a bashism \ +'/{ptex,tex}/{amstex,plain,generic,}' + +# More bashisms. +echo -e 'foo\n' +echo "${!foo}" +cat $(\< file) +select foo in a b ; do echo $foo ; done +cnt=$((cnt + 1)) +if false ; then + exec -l /bin/sh + exec -c /bin/sh + exec -a foo /bin/sh +fi +let cnt++ +if test -a /etc/default ; then + echo "$RANDOM|stuff" +fi + +# Some comment checking +# This should flag $RANDOM +test $# -gt 2 && echo $RANDOM +# But these shouldn't +test 1=1 # echo $RANDOM +(test 1=1)# echo $RANDOM +test 1=1;# echo $RANDOM +backgroundtask &#echo $RA + +#DEBHELPER# diff --git a/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/debian/prerm b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/debian/prerm new file mode 100644 index 0000000..84098f7 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/debian/prerm @@ -0,0 +1,186 @@ +#!/bin/sh + +set -e + +cat <<EOF +This is all really bad bash specific code!!! +read +source /bar/baz/bat foo +EOF + +# ok, back to checking +if [ "$2" == "purge" ]; then + rm -r /bar/baz +fi + +function foo( ) { + # but not here: local + local bar + echo "foo" &>/dev/null +} + +source $FOO + +trap "echo hi" EXIT HUP 3 + +if [[ "$2" = "purge" ]]; then + kill -HUP $$ +fi + +#this is ok though +if test -n $(echo foo | perl -pe 's/[[:space:]]//go'); then + echo 1 +fi + +# More false positives for bashism checks. None of these are errors. +echo "$line" | grep -q '{fonts/map,}/{\$progname,pdftex,dvips,}//' +echo "$line" | grep -q "${fonts},${foo}" +echo '$[1+2]' +printf "foo |& bar" +perl -e "print q( kill -HUP $? )" + +# Still catch disallowed expansions in double-quotes, though. +echo "${line:3:1}" + +# More bashisms checks + +read -x foo +read -x +read -r foo +read foo +read + +echo "a\\b" +echo 'a\nb' + +echo "${UID}" +echo "$EUID" +echo "$SHLVL" +echo "$DIRSTACK" +echo "$SECONDS" +echo "$BASH" +echo "$BASH_FOO" +echo "$SHELLOPTS" +echo "$PIPESTATUS" + +bar="$(cut '-d|' -f2 <<< "$foo")" + +VAR=1 +VAR+=a + +echos() { + echo -n -e "bar" + echo -e -n "bar" + echo -en "bar" + echo -ne "bar" + echo "bar" + echo "echo -e foo" +} + +ech.os() { + echo foo >& 2 + echo foo >&bar + echo foo >& bar +} + +echoes() { + echo "abc\nxyz" + echo 'xyz\rabc' + echo foo\cbar + + echo -e "abc\nxyz" + echo -net 'xyz\rabc' + echo -e foo\cbar +} + +foobar.() { + suspend x + suspended x + caller x + complete x + compgen x + declare -a foo +} + +.foobar() { + typeset -x bar + disown 1 + builtin foo + set -B + alias -p + unalias -a +} + +IFS="()" + +ulimit +shopt +type -v bar +time ls +dirs +diff <(tac a) <(tac b) + +pushd + +local foo=bar +local -x foo + +popd + +readonly -f + +echo bar > /dev/tcp +export x +export -x x +export -p x + +sh -x +sh -D +sh --foo +sh +O + +# Brace expansion checks +echo {a,b} +echo {abc},{bcd} + +foobar() +{ + # This is a function +} + + foo.bar() +( + # This is a function with a bad name +) + +foobar@() # foo +{ + # As is this +} + +# This is ok +read -r foo +# but these aren't +read -r +read -p "Would you like to restart the service?" foo bar +read --fish + +source "$BAR" +source '$BAR' +source ~/bar +source a + +# An example from the X maintainer scripts that used to trigger the trap +# bashism check. +trap "message;\ + message \"Received signal. Aborting $THIS_PACKAGE package $THIS_SCRIPT script.\";\ + message;\ + exit 1" HUP INT QUIT TERM + +# Also allow for extended single quotes containing double quotes. +trap 'message; + message "Received signal. Aborting $THIS_PACKAGE package $THIS_SCRIPT script."; + message; + exit 1' HUP INT QUIT TERM + +#DEBHELPER# diff --git a/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/fill-values b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/fill-values new file mode 100644 index 0000000..ab87d45 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/build-spec/fill-values @@ -0,0 +1,4 @@ +Skeleton: upload-native +Testname: scripts-bashisms +Description: Check bashism detection +Extra-Build-Depends: dash (>= 0.5.10.2) diff --git a/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/eval/desc b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/eval/desc new file mode 100644 index 0000000..ea622da --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/eval/desc @@ -0,0 +1,2 @@ +Testname: scripts-bashisms +Check: shell/non-posix/bash-centric diff --git a/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/eval/hints b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/eval/hints new file mode 100644 index 0000000..a1208c1 --- /dev/null +++ b/t/recipes/checks/shell/non-posix/bash-centric/scripts-bashisms/eval/hints @@ -0,0 +1,97 @@ +scripts-bashisms (binary): possible-bashism-in-maintainer-script '{a,b}' [prerm:143] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'unalias -a' [prerm:111] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'ulimit' [prerm:116] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'typeset' [prerm:106] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'time' [prerm:119] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'test -a' [postinst:74] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'suspend' [prerm:97] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'source ~/bar' [prerm:170] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'source a' [prerm:171] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'source /bar/baz/bat' [prerm:8] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'source '$BAR'' [prerm:169] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'source $FOO' [prerm:22] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'source "$BAR"' [prerm:168] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'shopt' [prerm:117] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'sh -D' [prerm:138] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'sh --foo' [prerm:139] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'sh +O' [prerm:140] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'set -B' [prerm:109] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'select foo' [postinst:66] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'readonly -f' [prerm:130] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'read' [prerm:7] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'read' [prerm:51] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'read' [postinst:14] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'read -x' [prerm:48] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'read -x' [prerm:47] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'read -r' [prerm:164] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'read -p' [prerm:165] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'read --fish' [prerm:166] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'pushd' [prerm:123] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'popd' [prerm:128] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'local -x' [prerm:126] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'let' [postinst:73] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'function foo(' [prerm:16] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'foobar@()' [prerm:156] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'foobar.() {' [prerm:96] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'foo.bar()' [prerm:151] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'export -x' [prerm:134] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'exec -l' [postinst:69] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'exec -c' [postinst:70] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'exec -a' [postinst:71] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo -ne' [prerm:92] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo -ne' [prerm:75] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo -n -e' [prerm:72] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo -en' [prerm:74] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo -e' [prerm:93] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo -e' [prerm:91] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo -e' [prerm:73] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo -e' [postinst:63] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo 'xyz\rabc'' [prerm:88] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo 'a\nb'' [prerm:54] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo "abc\nxyz"' [prerm:87] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'echo "a\\b"' [prerm:53] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'ech.os() {' [prerm:80] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'disown' [prerm:107] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'dirs' [prerm:120] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'declare' [prerm:102] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'complete' [prerm:100] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'compgen' [prerm:101] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'caller' [prerm:99] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'builtin' [prerm:108] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'alias -p' [prerm:110] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '[[' [prerm:26] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '[ "$2" ==' [prerm:12] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'VAR+=' [prerm:69] +scripts-bashisms (binary): possible-bashism-in-maintainer-script 'H[0]=' [postinst:16] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '>&bar' [prerm:82] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '>& bar' [prerm:83] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '<<<' [prerm:66] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '<(tac a)' [prerm:121] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '/dev/tcp' [prerm:132] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '.foobar() {' [prerm:105] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '. /usr/share/lintian/shell foo' [postinst:10] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '. "$(dirname $0)/shell"' [postinst:11] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '&>' [prerm:19] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${line:3:1}' [prerm:43] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${UID' [prerm:56] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:55] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:50] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:43] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:38] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:33] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:28] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:23] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[@]}' [postinst:19] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${H[0]}' [postinst:17] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${#H[0]}' [postinst:18] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '${!foo}' [postinst:64] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$SHLVL' [prerm:58] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$SHELLOPTS' [prerm:63] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$SECONDS' [prerm:60] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$RANDOM' [postinst:80] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$RANDOM' [postinst:75] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$PIPESTATUS' [prerm:64] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$HOSTNAME' [postinst:45] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$EUID' [prerm:57] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$DIRSTACK' [prerm:59] +scripts-bashisms (binary): possible-bashism-in-maintainer-script '$BASH_FOO' [prerm:62] |