mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 03:37:43 +00:00
Tests: Convert pledge-test-failures.cpp to be LibTest based.
This commit is contained in:
parent
122869f086
commit
41387df5f8
2 changed files with 30 additions and 32 deletions
30
Userland/Tests/Kernel/TestKernelPledge.cpp
Normal file
30
Userland/Tests/Kernel/TestKernelPledge.cpp
Normal file
|
@ -0,0 +1,30 @@
|
|||
/*
|
||||
* Copyright (c) 2018-2021, the SerenityOS developers.
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <LibTest/TestCase.h>
|
||||
#include <unistd.h>
|
||||
|
||||
TEST_CASE(test_nonexistent_pledge)
|
||||
{
|
||||
auto res = pledge("testing123", "notthere");
|
||||
if (res >= 0)
|
||||
FAIL("Pledging on existent promises should fail.");
|
||||
}
|
||||
|
||||
TEST_CASE(test_pledge_failures)
|
||||
{
|
||||
auto res = pledge("stdio unix rpath", "stdio");
|
||||
if (res < 0)
|
||||
FAIL("Initial pledge is expected to work.");
|
||||
|
||||
res = pledge("stdio unix", "stdio unix");
|
||||
if (res >= 0)
|
||||
FAIL("Additional execpromise \"unix\" should have failed");
|
||||
|
||||
res = pledge("stdio", "stdio");
|
||||
if (res < 0)
|
||||
FAIL("Reducing promises is expected to work.");
|
||||
}
|
|
@ -1,32 +0,0 @@
|
|||
/*
|
||||
* Copyright (c) 2018-2020, the SerenityOS developers.
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <unistd.h>
|
||||
|
||||
int main()
|
||||
{
|
||||
int res = pledge("stdio unix rpath", "stdio");
|
||||
if (res < 0) {
|
||||
perror("pledge");
|
||||
return 1;
|
||||
}
|
||||
|
||||
res = pledge("stdio unix", "stdio unix");
|
||||
if (res >= 0) {
|
||||
fprintf(stderr, "second pledge should have failed\n");
|
||||
return 1;
|
||||
}
|
||||
|
||||
res = pledge("stdio rpath", "stdio");
|
||||
if (res < 0) {
|
||||
perror("pledge");
|
||||
return 1;
|
||||
}
|
||||
|
||||
printf("PASS\n");
|
||||
return 0;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue