| #!/bin/bash |
| |
| [ -f testing.sh ] && . testing.sh |
| |
| if [ "$(id -u)" -ne 0 ] |
| then |
| echo "$SHOWSKIP: chown (not root)" |
| continue 2>/dev/null |
| exit |
| fi |
| |
| # We chown between user "root" and the last user in /etc/passwd, |
| # and group "root" and the last group in /etc/group. |
| |
| USR="$(sed -n '$s/:.*//p' /etc/passwd)" |
| GRP="$(sed -n '$s/:.*//p' /etc/group)" |
| |
| # Set up a little testing hierarchy |
| |
| rm -rf testdir && |
| mkdir testdir && |
| touch testdir/file |
| F=testdir/file |
| |
| # Wrapper to reset groups and return results |
| |
| OUT="&& echo \$(ls -l testdir/file | awk '{print \$3,\$4}')" |
| |
| #testing "name" "command" "result" "infile" "stdin" |
| |
| # Basic smoketest |
| testing "initial" "chown root:root $F $OUT" "root root\n" "" "" |
| testing "usr:grp" "chown $USR:$GRP $F $OUT" "$USR $GRP\n" "" "" |
| testing "root" "chown root $F $OUT" "root $GRP\n" "" "" |
| # TODO: can we test "owner:"? |
| testing ":grp" "chown root:root $F && chown :$GRP $F $OUT" \ |
| "root $GRP\n" "" "" |
| testing ":" "chown $USR:$GRP $F && chown : $F $OUT" \ |
| "$USR $GRP\n" "" "" |
| |
| rm -rf testdir |