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