blob: 1cef06fa1e443dc226ac0dce3a344052502c6557 [file] [log] [blame]
// SPDX-License-Identifier: GPL-2.0-or-later
/*
* Copyright (c) Wipro Technologies Ltd, 2002. All Rights Reserved.
* Author: Nirmala Devi Dhanasekar <nirmala.devi@wipro.com>
*
* Verify that umount(2) returns -1 and sets errno to EPERM if the user
* is not the super-user.
*/
#include <errno.h>
#include <pwd.h>
#include <sys/mount.h>
#include <sys/types.h>
#include <unistd.h>
#include "tst_test.h"
#define MNTPOINT "mntpoint"
static int mount_flag;
static void verify_umount(void)
{
TEST(umount(MNTPOINT));
if (TST_RET != -1) {
tst_res(TFAIL, "umount() succeeds unexpectedly");
return;
}
if (TST_ERR != EPERM) {
tst_res(TFAIL | TTERRNO, "umount() should fail with EPERM");
return;
}
tst_res(TPASS | TTERRNO, "umount() fails as expected");
}
static void setup(void)
{
struct passwd *pw;
SAFE_MKDIR(MNTPOINT, 0775);
SAFE_MOUNT(tst_device->dev, MNTPOINT, tst_device->fs_type, 0, NULL);
mount_flag = 1;
pw = SAFE_GETPWNAM("nobody");
SAFE_SETEUID(pw->pw_uid);
}
static void cleanup(void)
{
if (seteuid(0))
tst_res(TWARN | TERRNO, "seteuid(0) Failed");
if (mount_flag)
tst_umount(MNTPOINT);
}
static struct tst_test test = {
.needs_root = 1,
.format_device = 1,
.setup = setup,
.cleanup = cleanup,
.test_all = verify_umount,
};