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}