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 <unistd.h>
249762338dSopenharmony_ci#include <malloc.h>
259762338dSopenharmony_ci#include <arpa/inet.h>
269762338dSopenharmony_ci#include <gtest/gtest.h>
279762338dSopenharmony_ci#include <netinet/in.h>
289762338dSopenharmony_ci#include <sys/stat.h>
299762338dSopenharmony_ci#include <sys/mman.h>
309762338dSopenharmony_ci#include <sys/inotify.h>
319762338dSopenharmony_ci#include <sys/socket.h>
329762338dSopenharmony_ci#include <sys/syscall.h>
339762338dSopenharmony_ci#include <sys/types.h>
349762338dSopenharmony_ci#include "securec.h"
359762338dSopenharmony_ci
369762338dSopenharmony_ciusing namespace testing::ext;
379762338dSopenharmony_cistatic const char* TEST_FILE = "/data/local/tmp/test_notify.txt";
389762338dSopenharmony_cistatic const char* TEST_DIR = "/data/local/tmp/notify";
399762338dSopenharmony_ci
409762338dSopenharmony_ci
419762338dSopenharmony_ciclass HatsInotifyTest : public testing::Test {
429762338dSopenharmony_cipublic:
439762338dSopenharmony_ci    static void SetUpTestCase();
449762338dSopenharmony_ci    static void TearDownTestCase();
459762338dSopenharmony_ci    void SetUp();
469762338dSopenharmony_ci    void TearDown();
479762338dSopenharmony_ciprivate:
489762338dSopenharmony_ci};
499762338dSopenharmony_civoid HatsInotifyTest::SetUp()
509762338dSopenharmony_ci{
519762338dSopenharmony_ci}
529762338dSopenharmony_ci
539762338dSopenharmony_civoid HatsInotifyTest::TearDown()
549762338dSopenharmony_ci{
559762338dSopenharmony_ci}
569762338dSopenharmony_ci
579762338dSopenharmony_civoid HatsInotifyTest::SetUpTestCase()
589762338dSopenharmony_ci{
599762338dSopenharmony_ci}
609762338dSopenharmony_ci
619762338dSopenharmony_civoid HatsInotifyTest::TearDownTestCase()
629762338dSopenharmony_ci{
639762338dSopenharmony_ci}
649762338dSopenharmony_ci
659762338dSopenharmony_ci/*
669762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0100
679762338dSopenharmony_ci * @tc.name   : InotifyAddWatchAccessSuccess_0001
689762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_ACCESS.
699762338dSopenharmony_ci * @tc.size   : MediumTest
709762338dSopenharmony_ci * @tc.type   : Function
719762338dSopenharmony_ci * @tc.level  : Level 1
729762338dSopenharmony_ci */
739762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchAccessSuccess_0001, Function | MediumTest | Level1)
749762338dSopenharmony_ci{
759762338dSopenharmony_ci    int fdTest = open(TEST_FILE, O_RDWR | O_CREAT, 0666);
769762338dSopenharmony_ci    EXPECT_TRUE(fdTest > 0);
779762338dSopenharmony_ci
789762338dSopenharmony_ci    int fd = inotify_init1(0);
799762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
809762338dSopenharmony_ci
819762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_FILE, IN_ACCESS);
829762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
839762338dSopenharmony_ci
849762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
859762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
869762338dSopenharmony_ci
879762338dSopenharmony_ci    close(fd);
889762338dSopenharmony_ci}
899762338dSopenharmony_ci
909762338dSopenharmony_ci/*
919762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0200
929762338dSopenharmony_ci * @tc.name   : InotifyAddWatchModifySuccess_0002
939762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_MODIFY、IN_ATTRIB、IN_CLOSE.
949762338dSopenharmony_ci * @tc.size   : MediumTest
959762338dSopenharmony_ci * @tc.type   : Function
969762338dSopenharmony_ci * @tc.level  : Level 1
979762338dSopenharmony_ci */
989762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchModifySuccess_0002, Function | MediumTest | Level1)
999762338dSopenharmony_ci{
1009762338dSopenharmony_ci    int fdTest = open(TEST_FILE, O_RDWR | O_CREAT, 0666);
1019762338dSopenharmony_ci    EXPECT_TRUE(fdTest > 0);
1029762338dSopenharmony_ci
1039762338dSopenharmony_ci    int fd = inotify_init1(IN_NONBLOCK);
1049762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
1059762338dSopenharmony_ci
1069762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_FILE, IN_MODIFY | IN_ATTRIB | IN_CLOSE);
1079762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
1089762338dSopenharmony_ci
1099762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
1109762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
1119762338dSopenharmony_ci
1129762338dSopenharmony_ci    close(fd);
1139762338dSopenharmony_ci}
1149762338dSopenharmony_ci
1159762338dSopenharmony_ci/*
1169762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0300
1179762338dSopenharmony_ci * @tc.name   : InotifyAddWatchMoveSuccess_0003
1189762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_MOVE、IN_OPEN、IN_CLOSE_NOWRITE.
1199762338dSopenharmony_ci * @tc.size   : MediumTest
1209762338dSopenharmony_ci * @tc.type   : Function
1219762338dSopenharmony_ci * @tc.level  : Level 1
1229762338dSopenharmony_ci */
1239762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchMoveSuccess_0003, Function | MediumTest | Level1)
1249762338dSopenharmony_ci{
1259762338dSopenharmony_ci    int fdTest = open(TEST_FILE, O_RDWR | O_CREAT, 0666);
1269762338dSopenharmony_ci    EXPECT_TRUE(fdTest > 0);
1279762338dSopenharmony_ci
1289762338dSopenharmony_ci    int fd = inotify_init1(IN_CLOEXEC);
1299762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
1309762338dSopenharmony_ci
1319762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_FILE, IN_MOVE | IN_OPEN | IN_CLOSE_NOWRITE);
1329762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
1339762338dSopenharmony_ci
1349762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
1359762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
1369762338dSopenharmony_ci
1379762338dSopenharmony_ci    close(fd);
1389762338dSopenharmony_ci}
1399762338dSopenharmony_ci
1409762338dSopenharmony_ci/*
1419762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0400
1429762338dSopenharmony_ci * @tc.name   : InotifyAddWatchCreateSuccess_0004
1439762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_CLOSE_WRITE、IN_CREATE.
1449762338dSopenharmony_ci * @tc.size   : MediumTest
1459762338dSopenharmony_ci * @tc.type   : Function
1469762338dSopenharmony_ci * @tc.level  : Level 1
1479762338dSopenharmony_ci */
1489762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchCreateSuccess_0004, Function | MediumTest | Level1)
1499762338dSopenharmony_ci{
1509762338dSopenharmony_ci    int fdTest = open(TEST_FILE, O_RDWR | O_CREAT, 0666);
1519762338dSopenharmony_ci    EXPECT_TRUE(fdTest > 0);
1529762338dSopenharmony_ci
1539762338dSopenharmony_ci    int fd = inotify_init1(IN_CLOEXEC);
1549762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
1559762338dSopenharmony_ci
1569762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_FILE, IN_CLOSE_WRITE | IN_CREATE);
1579762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
1589762338dSopenharmony_ci
1599762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
1609762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
1619762338dSopenharmony_ci
1629762338dSopenharmony_ci    close(fd);
1639762338dSopenharmony_ci}
1649762338dSopenharmony_ci
1659762338dSopenharmony_ci/*
1669762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0500
1679762338dSopenharmony_ci * @tc.name   : InotifyAddWatchMoveFromSuccess_0005
1689762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_MOVED_FROM、IN_DELETE_SELF、IN_MOVE_SELF.
1699762338dSopenharmony_ci * @tc.size   : MediumTest
1709762338dSopenharmony_ci * @tc.type   : Function
1719762338dSopenharmony_ci * @tc.level  : Level 1
1729762338dSopenharmony_ci */
1739762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchMoveFromSuccess_0005, Function | MediumTest | Level1)
1749762338dSopenharmony_ci{
1759762338dSopenharmony_ci    int fdTest = open(TEST_FILE, O_RDWR | O_CREAT, 0666);
1769762338dSopenharmony_ci    EXPECT_TRUE(fdTest > 0);
1779762338dSopenharmony_ci
1789762338dSopenharmony_ci    int fd = inotify_init1(IN_CLOEXEC);
1799762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
1809762338dSopenharmony_ci
1819762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_FILE, IN_MOVED_FROM | IN_DELETE_SELF | IN_MOVE_SELF);
1829762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
1839762338dSopenharmony_ci
1849762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
1859762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
1869762338dSopenharmony_ci
1879762338dSopenharmony_ci    close(fd);
1889762338dSopenharmony_ci}
1899762338dSopenharmony_ci
1909762338dSopenharmony_ci/*
1919762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0600
1929762338dSopenharmony_ci * @tc.name   : InotifyAddWatchMoveToSuccess_0006
1939762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_MOVED_TO、IN_UNMOUNT、IN_IGNORED、IN_Q_OVERFLOW.
1949762338dSopenharmony_ci * @tc.size   : MediumTest
1959762338dSopenharmony_ci * @tc.type   : Function
1969762338dSopenharmony_ci * @tc.level  : Level 1
1979762338dSopenharmony_ci */
1989762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchMoveToSuccess_0006, Function | MediumTest | Level1)
1999762338dSopenharmony_ci{
2009762338dSopenharmony_ci    int fdTest = open(TEST_FILE, O_RDWR | O_CREAT, 0666);
2019762338dSopenharmony_ci    EXPECT_TRUE(fdTest > 0);
2029762338dSopenharmony_ci
2039762338dSopenharmony_ci    int fd = inotify_init1(IN_CLOEXEC);
2049762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
2059762338dSopenharmony_ci
2069762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_FILE, IN_MOVED_TO | IN_UNMOUNT | IN_IGNORED | IN_Q_OVERFLOW);
2079762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
2089762338dSopenharmony_ci
2099762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
2109762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
2119762338dSopenharmony_ci
2129762338dSopenharmony_ci    close(fd);
2139762338dSopenharmony_ci}
2149762338dSopenharmony_ci
2159762338dSopenharmony_ci/*
2169762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0700
2179762338dSopenharmony_ci * @tc.name   : InotifyAddWatchDirSuccess_0007
2189762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_ONLYDIR、IN_DONT_FOLLOW、IN_EXCL_UNLINK.
2199762338dSopenharmony_ci * @tc.size   : MediumTest
2209762338dSopenharmony_ci * @tc.type   : Function
2219762338dSopenharmony_ci * @tc.level  : Level 1
2229762338dSopenharmony_ci */
2239762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchDirSuccess_0007, Function | MediumTest | Level1)
2249762338dSopenharmony_ci{
2259762338dSopenharmony_ci    mkdir(TEST_DIR, 0777);
2269762338dSopenharmony_ci
2279762338dSopenharmony_ci    int fd = inotify_init1(IN_CLOEXEC);
2289762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
2299762338dSopenharmony_ci
2309762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_DIR, IN_ONLYDIR | IN_DONT_FOLLOW | IN_EXCL_UNLINK);
2319762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
2329762338dSopenharmony_ci
2339762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
2349762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
2359762338dSopenharmony_ci
2369762338dSopenharmony_ci    close(fd);
2379762338dSopenharmony_ci}
2389762338dSopenharmony_ci
2399762338dSopenharmony_ci/*
2409762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0800
2419762338dSopenharmony_ci * @tc.name   : InotifyAddWatchMaskAddSuccess_0008
2429762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_MASK_ADD、IN_ISDIR、IN_ONESHOT.
2439762338dSopenharmony_ci * @tc.size   : MediumTest
2449762338dSopenharmony_ci * @tc.type   : Function
2459762338dSopenharmony_ci * @tc.level  : Level 1
2469762338dSopenharmony_ci */
2479762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchMaskAddSuccess_0008, Function | MediumTest | Level1)
2489762338dSopenharmony_ci{
2499762338dSopenharmony_ci    int fdTest = open(TEST_FILE, O_RDWR | O_CREAT, 0666);
2509762338dSopenharmony_ci    EXPECT_TRUE(fdTest > 0);
2519762338dSopenharmony_ci
2529762338dSopenharmony_ci    int fd = inotify_init1(IN_CLOEXEC);
2539762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
2549762338dSopenharmony_ci
2559762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_FILE, IN_MASK_ADD | IN_ISDIR | IN_ONESHOT);
2569762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
2579762338dSopenharmony_ci
2589762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
2599762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
2609762338dSopenharmony_ci
2619762338dSopenharmony_ci    close(fd);
2629762338dSopenharmony_ci}
2639762338dSopenharmony_ci
2649762338dSopenharmony_ci/*
2659762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_0900
2669762338dSopenharmony_ci * @tc.name   : InotifyAddWatchCloExecFailed_009
2679762338dSopenharmony_ci * @tc.desc   : Inotify adds watch with mask IN_CLOEXEC.
2689762338dSopenharmony_ci * @tc.size   : MediumTest
2699762338dSopenharmony_ci * @tc.type   : Function
2709762338dSopenharmony_ci * @tc.level  : Level 2
2719762338dSopenharmony_ci */
2729762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchCloExecFailed_009, Function | MediumTest | Level2)
2739762338dSopenharmony_ci{
2749762338dSopenharmony_ci    int fd = inotify_init1(IN_CLOEXEC);
2759762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
2769762338dSopenharmony_ci
2779762338dSopenharmony_ci    errno = 0;
2789762338dSopenharmony_ci    int wd = inotify_add_watch(fd, nullptr, IN_DELETE);
2799762338dSopenharmony_ci    EXPECT_EQ(wd, -1);
2809762338dSopenharmony_ci    EXPECT_EQ(errno, EFAULT);
2819762338dSopenharmony_ci
2829762338dSopenharmony_ci    close(fd);
2839762338dSopenharmony_ci}
2849762338dSopenharmony_ci
2859762338dSopenharmony_ci/*
2869762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_INOTIFY_1000
2879762338dSopenharmony_ci * @tc.name   : InotifyAddWatchIN_CLOEXECTestSuccess_0010
2889762338dSopenharmony_ci * @tc.desc   : inotify_adds_watch with mask IN_CLOEXEC success.
2899762338dSopenharmony_ci * @tc.size   : MediumTest
2909762338dSopenharmony_ci * @tc.type   : Function
2919762338dSopenharmony_ci * @tc.level  : Level 1
2929762338dSopenharmony_ci */
2939762338dSopenharmony_ciHWTEST_F(HatsInotifyTest, InotifyAddWatchIN_CLOEXECTestSuccess_0010, Function | MediumTest | Level1)
2949762338dSopenharmony_ci{
2959762338dSopenharmony_ci    int fdTest = open(TEST_FILE, O_RDWR | O_CREAT, 0666);
2969762338dSopenharmony_ci    EXPECT_TRUE(fdTest > 0);
2979762338dSopenharmony_ci
2989762338dSopenharmony_ci    int fd = inotify_init1(IN_CLOEXEC);
2999762338dSopenharmony_ci    EXPECT_TRUE(fd >= 0);
3009762338dSopenharmony_ci
3019762338dSopenharmony_ci    int wd = inotify_add_watch(fd, TEST_FILE, IN_MASK_ADD);
3029762338dSopenharmony_ci    EXPECT_TRUE(wd >= 0);
3039762338dSopenharmony_ci
3049762338dSopenharmony_ci    int ret = inotify_rm_watch(fd, wd);
3059762338dSopenharmony_ci    EXPECT_EQ(ret, 0);
3069762338dSopenharmony_ci
3079762338dSopenharmony_ci    close(fd);
3089762338dSopenharmony_ci}