19762338dSopenharmony_ci/* 29762338dSopenharmony_ci * Copyright (C) 2024 HiHope Open Source Organization. 39762338dSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 49762338dSopenharmony_ci * you may not use this file except in compliance with the License. 59762338dSopenharmony_ci * You may obtain a copy of the License at 69762338dSopenharmony_ci * 79762338dSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 89762338dSopenharmony_ci * 99762338dSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 109762338dSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 119762338dSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 129762338dSopenharmony_ci * See the License for the specific language governing permissions and 139762338dSopenharmony_ci * limitations under the License. 149762338dSopenharmony_ci */ 159762338dSopenharmony_ci 169762338dSopenharmony_ci#include <cerrno> 179762338dSopenharmony_ci#include <cstdio> 189762338dSopenharmony_ci#include <cstdlib> 199762338dSopenharmony_ci#include <csignal> 209762338dSopenharmony_ci#include <string> 219762338dSopenharmony_ci#include <vector> 229762338dSopenharmony_ci#include <fcntl.h> 239762338dSopenharmony_ci#include <sched.h> 249762338dSopenharmony_ci#include <unistd.h> 259762338dSopenharmony_ci#include <bits/syscall.h> 269762338dSopenharmony_ci#include <gtest/gtest.h> 279762338dSopenharmony_ci#include <sys/ptrace.h> 289762338dSopenharmony_ci#include <sys/stat.h> 299762338dSopenharmony_ci#include <sys/types.h> 309762338dSopenharmony_ci#include "securec.h" 319762338dSopenharmony_ci 329762338dSopenharmony_ciusing namespace testing::ext; 339762338dSopenharmony_ciusing namespace std; 349762338dSopenharmony_ci 359762338dSopenharmony_cistatic const int STACK_SIZE = 8 * 1024 * 1024; 369762338dSopenharmony_cistatic const char *TEST_FILE = "/data/local/tmp/exec_test.txt"; 379762338dSopenharmony_ci 389762338dSopenharmony_cistruct CloneFlag { 399762338dSopenharmony_ci int id; 409762338dSopenharmony_ci int flag; 419762338dSopenharmony_ci}; 429762338dSopenharmony_ci 439762338dSopenharmony_ciclass ProcessApiTest : public testing::Test { 449762338dSopenharmony_cipublic: 459762338dSopenharmony_ci static void SetUpTestCase(); 469762338dSopenharmony_ci static void TearDownTestCase(); 479762338dSopenharmony_ci void SetUp(); 489762338dSopenharmony_ci void TearDown(); 499762338dSopenharmony_ciprivate: 509762338dSopenharmony_ci}; 519762338dSopenharmony_civoid ProcessApiTest::SetUp() 529762338dSopenharmony_ci{ 539762338dSopenharmony_ci} 549762338dSopenharmony_civoid ProcessApiTest::TearDown() 559762338dSopenharmony_ci{ 569762338dSopenharmony_ci} 579762338dSopenharmony_civoid ProcessApiTest::SetUpTestCase() 589762338dSopenharmony_ci{ 599762338dSopenharmony_ci} 609762338dSopenharmony_civoid ProcessApiTest::TearDownTestCase() 619762338dSopenharmony_ci{ 629762338dSopenharmony_ci} 639762338dSopenharmony_ci 649762338dSopenharmony_cistatic int CloneTest(void *arg) 659762338dSopenharmony_ci{ 669762338dSopenharmony_ci return 0; 679762338dSopenharmony_ci} 689762338dSopenharmony_ci 699762338dSopenharmony_ci/* 709762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0100 719762338dSopenharmony_ci * @tc.name : CloneSuccess_0001 729762338dSopenharmony_ci * @tc.desc : success. 739762338dSopenharmony_ci * @tc.size : MediumTest 749762338dSopenharmony_ci * @tc.type : Function 759762338dSopenharmony_ci * @tc.level : Level 1 769762338dSopenharmony_ci */ 779762338dSopenharmony_ciHWTEST_F(ProcessApiTest, CloneSuccess_0001, Function | MediumTest | Level1) 789762338dSopenharmony_ci{ 799762338dSopenharmony_ci int i; 809762338dSopenharmony_ci int pid = -1; 819762338dSopenharmony_ci struct CloneFlag cloneFlag[] = { 829762338dSopenharmony_ci {1, CLONE_VM | CLONE_FS | CLONE_FILES | SIGCHLD}, 839762338dSopenharmony_ci {2, CSIGNAL}, 849762338dSopenharmony_ci {3, CLONE_VFORK}, 859762338dSopenharmony_ci {4, CLONE_PARENT}, 869762338dSopenharmony_ci {5, CLONE_NEWNS}, 879762338dSopenharmony_ci {6, CLONE_SETTLS}, 889762338dSopenharmony_ci {7, CLONE_PARENT_SETTID}, 899762338dSopenharmony_ci {8, CLONE_CHILD_CLEARTID}, 909762338dSopenharmony_ci {9, CLONE_CHILD_SETTID}, 919762338dSopenharmony_ci {10, CLONE_NEWUTS}, 929762338dSopenharmony_ci {11, CLONE_NEWIPC}, 939762338dSopenharmony_ci {13, CLONE_NEWPID}, 949762338dSopenharmony_ci {14, CLONE_NEWNET}, 959762338dSopenharmony_ci }; 969762338dSopenharmony_ci char *stack = new char[STACK_SIZE]; 979762338dSopenharmony_ci for (i = 0; i < sizeof(cloneFlag) / sizeof(cloneFlag[0]); i++) { 989762338dSopenharmony_ci pid = clone(CloneTest, &stack[STACK_SIZE - 1], cloneFlag[i].flag, nullptr); 999762338dSopenharmony_ci EXPECT_TRUE(pid > 0); 1009762338dSopenharmony_ci waitpid(pid, nullptr, 0); 1019762338dSopenharmony_ci } 1029762338dSopenharmony_ci free(stack); 1039762338dSopenharmony_ci} 1049762338dSopenharmony_ci 1059762338dSopenharmony_ci/* 1069762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0200 1079762338dSopenharmony_ci * @tc.name : CloneInvalidFlagFailed_0002 1089762338dSopenharmony_ci * @tc.desc : clone flag invalid failed errno EINVAL. 1099762338dSopenharmony_ci * @tc.size : MediumTest 1109762338dSopenharmony_ci * @tc.type : Function 1119762338dSopenharmony_ci * @tc.level : Level 2 1129762338dSopenharmony_ci */ 1139762338dSopenharmony_ciHWTEST_F(ProcessApiTest, CloneInvalidFlagFailed_0002, Function | MediumTest | Level2) 1149762338dSopenharmony_ci{ 1159762338dSopenharmony_ci errno = 0; 1169762338dSopenharmony_ci char *stack = new char[STACK_SIZE]; 1179762338dSopenharmony_ci pid_t pid = clone(CloneTest, &stack[STACK_SIZE - 1], -1, nullptr); 1189762338dSopenharmony_ci EXPECT_EQ(pid, -1); 1199762338dSopenharmony_ci EXPECT_EQ(errno, EINVAL); 1209762338dSopenharmony_ci} 1219762338dSopenharmony_ci 1229762338dSopenharmony_ci/* 1239762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0300 1249762338dSopenharmony_ci * @tc.name : ExecveCmdSuccess_0003 1259762338dSopenharmony_ci * @tc.desc : execve exec cmd touch success. 1269762338dSopenharmony_ci * @tc.size : MediumTest 1279762338dSopenharmony_ci * @tc.type : Function 1289762338dSopenharmony_ci * @tc.level : Level 1 1299762338dSopenharmony_ci */ 1309762338dSopenharmony_ciHWTEST_F(ProcessApiTest, ExecveCmdSuccess_0003, Function | MediumTest | Level1) 1319762338dSopenharmony_ci{ 1329762338dSopenharmony_ci int ret; 1339762338dSopenharmony_ci pid_t pid = fork(); 1349762338dSopenharmony_ci if (pid == 0) { 1359762338dSopenharmony_ci char cmd[] = "touch"; 1369762338dSopenharmony_ci char file[] = "/data/local/tmp/exec_test.txt"; 1379762338dSopenharmony_ci char *argv[] = {cmd, file, nullptr}; 1389762338dSopenharmony_ci char *envp[] = { nullptr }; 1399762338dSopenharmony_ci ret = execve("/bin/touch", argv, envp); 1409762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1419762338dSopenharmony_ci exit(0); 1429762338dSopenharmony_ci } 1439762338dSopenharmony_ci waitpid(pid, nullptr, 0); 1449762338dSopenharmony_ci EXPECT_EQ(access(TEST_FILE, F_OK), 0); 1459762338dSopenharmony_ci remove(TEST_FILE); 1469762338dSopenharmony_ci} 1479762338dSopenharmony_ci 1489762338dSopenharmony_ci/* 1499762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0400 1509762338dSopenharmony_ci * @tc.name : ExecveInvalidParamFailed_0004 1519762338dSopenharmony_ci * @tc.desc : execve exec cmd touch success. 1529762338dSopenharmony_ci * @tc.size : MediumTest 1539762338dSopenharmony_ci * @tc.type : Function 1549762338dSopenharmony_ci * @tc.level : Level 2 1559762338dSopenharmony_ci */ 1569762338dSopenharmony_ciHWTEST_F(ProcessApiTest, ExecveInvalidParamFailed_0004, Function | MediumTest | Level2) 1579762338dSopenharmony_ci{ 1589762338dSopenharmony_ci errno = 0; 1599762338dSopenharmony_ci char cmd[] = "touch"; 1609762338dSopenharmony_ci char file[] = "/data/local/tmp/exec_test.txt"; 1619762338dSopenharmony_ci char *argv[] = {cmd, file, nullptr}; 1629762338dSopenharmony_ci char *envp[] = { nullptr }; 1639762338dSopenharmony_ci int ret = execve(nullptr, argv, envp); 1649762338dSopenharmony_ci EXPECT_EQ(ret, -1); 1659762338dSopenharmony_ci EXPECT_EQ(errno, EFAULT); 1669762338dSopenharmony_ci} 1679762338dSopenharmony_ci 1689762338dSopenharmony_ci/* 1699762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0500 1709762338dSopenharmony_ci * @tc.name : ExecveatSuccess_0005 1719762338dSopenharmony_ci * @tc.desc : success. 1729762338dSopenharmony_ci * @tc.size : MediumTest 1739762338dSopenharmony_ci * @tc.type : Function 1749762338dSopenharmony_ci * @tc.level : Level 1 1759762338dSopenharmony_ci */ 1769762338dSopenharmony_ciHWTEST_F(ProcessApiTest, ExecveatSuccess_0005, Function | MediumTest | Level1) 1779762338dSopenharmony_ci{ 1789762338dSopenharmony_ci int ret; 1799762338dSopenharmony_ci char cmd[] = "ls"; 1809762338dSopenharmony_ci char *argv[] = {cmd, nullptr}; 1819762338dSopenharmony_ci char *envp[] = { nullptr }; 1829762338dSopenharmony_ci int fd = open("/bin", O_RDONLY | O_DIRECTORY); 1839762338dSopenharmony_ci EXPECT_TRUE(fd > 0); 1849762338dSopenharmony_ci 1859762338dSopenharmony_ci pid_t pid = fork(); 1869762338dSopenharmony_ci if (pid == 0) { 1879762338dSopenharmony_ci ret = syscall(__NR_execveat, fd, cmd, argv, envp, 0); 1889762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1899762338dSopenharmony_ci exit(0); 1909762338dSopenharmony_ci } 1919762338dSopenharmony_ci waitpid(pid, nullptr, 0); 1929762338dSopenharmony_ci} 1939762338dSopenharmony_ci 1949762338dSopenharmony_ci/* 1959762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0600 1969762338dSopenharmony_ci * @tc.name : ExecveatInvalidFlagsFailed_0006 1979762338dSopenharmony_ci * @tc.desc : execveat invalid flags -1 failed errno EINVAL. 1989762338dSopenharmony_ci * @tc.size : MediumTest 1999762338dSopenharmony_ci * @tc.type : Function 2009762338dSopenharmony_ci * @tc.level : Level 2 2019762338dSopenharmony_ci */ 2029762338dSopenharmony_ciHWTEST_F(ProcessApiTest, ExecveatInvalidFlagsFailed_0006, Function | MediumTest | Level2) 2039762338dSopenharmony_ci{ 2049762338dSopenharmony_ci int ret; 2059762338dSopenharmony_ci char cmd[] = "ls"; 2069762338dSopenharmony_ci char *argv[] = {cmd, nullptr}; 2079762338dSopenharmony_ci char *envp[] = { nullptr }; 2089762338dSopenharmony_ci int fd = open("/bin", O_RDONLY | O_DIRECTORY); 2099762338dSopenharmony_ci EXPECT_TRUE(fd > 0); 2109762338dSopenharmony_ci 2119762338dSopenharmony_ci pid_t pid = fork(); 2129762338dSopenharmony_ci if (pid == 0) { 2139762338dSopenharmony_ci errno = 0; 2149762338dSopenharmony_ci ret = syscall(__NR_execveat, fd, cmd, argv, envp, -1); 2159762338dSopenharmony_ci EXPECT_EQ(ret, -1); 2169762338dSopenharmony_ci EXPECT_EQ(errno, EINVAL); 2179762338dSopenharmony_ci exit(0); 2189762338dSopenharmony_ci } 2199762338dSopenharmony_ci waitpid(pid, nullptr, 0); 2209762338dSopenharmony_ci} 2219762338dSopenharmony_ci 2229762338dSopenharmony_ci/* 2239762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0700 2249762338dSopenharmony_ci * @tc.name : ExitGroupSyscallSuccess_0007 2259762338dSopenharmony_ci * @tc.desc : __NR_exit_group syscall test success. 2269762338dSopenharmony_ci * @tc.size : MediumTest 2279762338dSopenharmony_ci * @tc.type : Function 2289762338dSopenharmony_ci * @tc.level : Level 1 2299762338dSopenharmony_ci */ 2309762338dSopenharmony_ciHWTEST_F(ProcessApiTest, ExitGroupSyscallSuccess_0007, Function | MediumTest | Level1) 2319762338dSopenharmony_ci{ 2329762338dSopenharmony_ci int ret; 2339762338dSopenharmony_ci pid_t pid; 2349762338dSopenharmony_ci 2359762338dSopenharmony_ci pid = fork(); 2369762338dSopenharmony_ci if (pid == 0) { 2379762338dSopenharmony_ci ret = syscall(__NR_exit_group, 0); 2389762338dSopenharmony_ci EXPECT_EQ(ret, 0); 2399762338dSopenharmony_ci exit(0); 2409762338dSopenharmony_ci } 2419762338dSopenharmony_ci waitpid(pid, nullptr, 0); 2429762338dSopenharmony_ci} 2439762338dSopenharmony_ci 2449762338dSopenharmony_ci/* 2459762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0800 2469762338dSopenharmony_ci * @tc.name : GetPidSuccess_0008 2479762338dSopenharmony_ci * @tc.desc : success. 2489762338dSopenharmony_ci * @tc.size : MediumTest 2499762338dSopenharmony_ci * @tc.type : Function 2509762338dSopenharmony_ci * @tc.level : Level 1 2519762338dSopenharmony_ci */ 2529762338dSopenharmony_ciHWTEST_F(ProcessApiTest, GetPidSuccess_0008, Function | MediumTest | Level1) 2539762338dSopenharmony_ci{ 2549762338dSopenharmony_ci pid_t pid = getpid(); 2559762338dSopenharmony_ci EXPECT_TRUE(pid >= 0); 2569762338dSopenharmony_ci} 2579762338dSopenharmony_ci 2589762338dSopenharmony_ci/* 2599762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_0900 2609762338dSopenharmony_ci * @tc.name : GetppidGetParentPidSuccess_0009 2619762338dSopenharmony_ci * @tc.desc : getppid get parent pid success. 2629762338dSopenharmony_ci * @tc.size : MediumTest 2639762338dSopenharmony_ci * @tc.type : Function 2649762338dSopenharmony_ci * @tc.level : Level 1 2659762338dSopenharmony_ci */ 2669762338dSopenharmony_ciHWTEST_F(ProcessApiTest, GetppidGetParentPidSuccess_0009, Function | MediumTest | Level1) 2679762338dSopenharmony_ci{ 2689762338dSopenharmony_ci pid_t ppid = getppid(); 2699762338dSopenharmony_ci EXPECT_TRUE(ppid >= 0); 2709762338dSopenharmony_ci} 2719762338dSopenharmony_ci 2729762338dSopenharmony_ci/* 2739762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_1000 2749762338dSopenharmony_ci * @tc.name : GetSidSuccess_0010 2759762338dSopenharmony_ci * @tc.desc : success. 2769762338dSopenharmony_ci * @tc.size : MediumTest 2779762338dSopenharmony_ci * @tc.type : Function 2789762338dSopenharmony_ci * @tc.level : Level 1 2799762338dSopenharmony_ci */ 2809762338dSopenharmony_ciHWTEST_F(ProcessApiTest, GetSidSuccess_0010, Function | MediumTest | Level1) 2819762338dSopenharmony_ci{ 2829762338dSopenharmony_ci pid_t pid = getpid(); 2839762338dSopenharmony_ci EXPECT_TRUE(pid >= 0); 2849762338dSopenharmony_ci 2859762338dSopenharmony_ci pid_t sid = getsid(pid); 2869762338dSopenharmony_ci EXPECT_TRUE(sid >= 0); 2879762338dSopenharmony_ci} 2889762338dSopenharmony_ci 2899762338dSopenharmony_ci/* 2909762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_1100 2919762338dSopenharmony_ci * @tc.name : GetTidSuccess_0011 2929762338dSopenharmony_ci * @tc.desc : success. 2939762338dSopenharmony_ci * @tc.size : MediumTest 2949762338dSopenharmony_ci * @tc.type : Function 2959762338dSopenharmony_ci * @tc.level : Level 1 2969762338dSopenharmony_ci */ 2979762338dSopenharmony_ciHWTEST_F(ProcessApiTest, GetTidSuccess_0011, Function | MediumTest | Level1) 2989762338dSopenharmony_ci{ 2999762338dSopenharmony_ci pid_t tid = gettid(); 3009762338dSopenharmony_ci EXPECT_TRUE(tid >= 0); 3019762338dSopenharmony_ci} 3029762338dSopenharmony_ci 3039762338dSopenharmony_ci/* 3049762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_1200 3059762338dSopenharmony_ci * @tc.name : SetTidAddressSuccess_0012 3069762338dSopenharmony_ci * @tc.desc : success. 3079762338dSopenharmony_ci * @tc.size : MediumTest 3089762338dSopenharmony_ci * @tc.type : Function 3099762338dSopenharmony_ci * @tc.level : Level 1 3109762338dSopenharmony_ci */ 3119762338dSopenharmony_ciHWTEST_F(ProcessApiTest, SetTidAddressSuccess_0001, Function | MediumTest | Level1) 3129762338dSopenharmony_ci{ 3139762338dSopenharmony_ci int newTid = -1; 3149762338dSopenharmony_ci int ret = syscall(__NR_set_tid_address, &newTid); 3159762338dSopenharmony_ci EXPECT_EQ(ret, getpid()); 3169762338dSopenharmony_ci} 3179762338dSopenharmony_ci 3189762338dSopenharmony_ci/* 3199762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_PROCESS_1300 3209762338dSopenharmony_ci * @tc.name : UnshareFlagsTest_0013 3219762338dSopenharmony_ci * @tc.desc : unshare success. 3229762338dSopenharmony_ci * @tc.size : MediumTest 3239762338dSopenharmony_ci * @tc.type : Function 3249762338dSopenharmony_ci * @tc.level : Level 1 3259762338dSopenharmony_ci */ 3269762338dSopenharmony_ciHWTEST_F(ProcessApiTest, UnshareFlagsTest_0013, Function | MediumTest | Level1) 3279762338dSopenharmony_ci{ 3289762338dSopenharmony_ci int32_t ret = unshare(CLONE_NEWPID); 3299762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3309762338dSopenharmony_ci 3319762338dSopenharmony_ci ret = unshare(CLONE_FILES); 3329762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3339762338dSopenharmony_ci 3349762338dSopenharmony_ci ret = unshare(CLONE_FS); 3359762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3369762338dSopenharmony_ci 3379762338dSopenharmony_ci ret = unshare(CLONE_NEWNS); 3389762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3399762338dSopenharmony_ci 3409762338dSopenharmony_ci ret = unshare(CLONE_NEWUTS); 3419762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3429762338dSopenharmony_ci 3439762338dSopenharmony_ci ret = unshare(CLONE_NEWIPC); 3449762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3459762338dSopenharmony_ci 3469762338dSopenharmony_ci ret = unshare(CLONE_NEWNET); 3479762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3489762338dSopenharmony_ci} 349