/* * * Copyright (c) International Business Machines Corp., 2001 * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See * the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ /* * NAME * chroot01.c * * DESCRIPTION * Testcase to check the whether chroot sets errno to EPERM. * * ALGORITHM * As a non-root user attempt to perform chroot() to a directory. The * chroot() call should fail with EPERM * * USAGE: * chroot01 [-c n] [-e] [-i n] [-I x] [-P x] [-t] * where, -c n : Run n copies concurrently. * -e : Turn on errno logging. * -i n : Execute test n times. * -I x : Execute test for x seconds. * -P x : Pause for x seconds between iterations. * -t : Turn on syscall timing. * * HISTORY * 07/2001 Ported by Wayne Boyer * * RESTRICTIONS * Must be run as non-root user. */ #include #include #include "test.h" #include "safe_macros.h" #include char *TCID = "chroot01"; int TST_TOTAL = 1; int fail; char *path; char nobody_uid[] = "nobody"; struct passwd *ltpuser; void setup(void); void cleanup(void); int main(int ac, char **av) { int lc; tst_parse_opts(ac, av, NULL, NULL); setup(); for (lc = 0; TEST_LOOPING(lc); lc++) { tst_count = 0; TEST(chroot(path)); if (TEST_RETURN != -1) tst_resm(TFAIL, "call succeeded unexpectedly"); else if (errno != EPERM) tst_resm(TFAIL | TTERRNO, "chroot failed unexpectedly"); else tst_resm(TPASS, "chroot set errno to EPERM."); } cleanup(); tst_exit(); } void setup(void) { tst_require_root(); tst_tmpdir(); path = tst_get_tmpdir(); if ((ltpuser = getpwnam(nobody_uid)) == NULL) tst_brkm(TBROK | TERRNO, cleanup, "getpwnam(\"nobody\") failed"); SAFE_SETEUID(cleanup, ltpuser->pw_uid); tst_sig(NOFORK, DEF_HANDLER, cleanup); TEST_PAUSE; } void cleanup(void) { SAFE_SETEUID(NULL, 0); free(path); tst_rmdir(); }