/* * Copyright (c) 2021 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include "log.h" #include "utils.h" #include "ClockID.h" using namespace testing::ext; class UsleepParamTest : public testing::TestWithParam { }; class SleepParamTest : public testing::TestWithParam { }; class SleepTest : public testing::Test { }; /** * @tc.number SUB_KERNEL_TIME_API_CLOCK_NANOSLEEP_0200 * @tc.name clock_nanosleep fail test - non-support clock_id * @tc.desc [C- SOFTWARE -0200] */ HWTEST_P(AllClockIDTest, testClockNanosleepInvalidID, Reliability | SmallTest | Level2) { clockid_t cid = GetParam(); const char* cname = ALL_CLOCKS_NAME[cid]; LOG("test %s", cname); struct timespec req = {0, 100}; struct timespec rem = {0}; int rt = clock_nanosleep(cid, 0, &req, &rem); if (cid == CLOCK_REALTIME) { ASSERT_EQ(rt, 0); } else if (cid == CLOCK_THREAD_CPUTIME_ID) { ASSERT_EQ(rt, EINVAL) << cname << " should not support.\n"; } else { ASSERT_EQ(rt, ENOTSUP) << cname << " should not support.\n"; } } INSTANTIATE_TEST_CASE_P(SleepTest, AllClockIDTest, ALL_CLOCK_IDS); /** * @tc.number SUB_KERNEL_TIME_API_CLOCK_NANOSLEEP_0300 * @tc.name clock_nanosleep fail test - invalid parameter * @tc.desc [C- SOFTWARE -0200] */ HWTEST_F(SleepTest, testClockNanosleepInvalidPara, Reliability | SmallTest | Level2) { struct timespec req = {0, 100}; struct timespec rem = {0}; int rt; // invlid clock_id int id = GetRandom(1000) + 12; LOG("check invlid clockid: %d...", id); rt = clock_nanosleep(id, 0, &req, &rem); EXPECT_EQ(rt, EINVAL); id = -GetRandom(1000) - 12; LOG("check invlid clockid: %d...", id); rt = clock_nanosleep(id, 0, &req, &rem); EXPECT_EQ(rt, EINVAL); // invlid flag int flag = TIMER_ABSTIME; LOG("check invlid flag: %d...", flag); rt = clock_nanosleep(CLOCK_REALTIME, flag, &req, &rem); EXPECT_EQ(rt, ENOTSUP); flag = GetRandom(100) + 1; LOG("check invlid flag: %d...", flag); rt = clock_nanosleep(CLOCK_REALTIME, flag, &req, &rem); EXPECT_EQ(rt, EINVAL); flag = -GetRandom(100) - 1; LOG("check invlid flag: %d...", flag); rt = clock_nanosleep(CLOCK_REALTIME, flag, &req, &rem); EXPECT_EQ(rt, EINVAL); // invlid timespec req.tv_sec = -1; req.tv_nsec = 1; LOG("check invlid timespec: tv_sec=-1 ..."); rt = clock_nanosleep(CLOCK_REALTIME, 0, &req, &rem); EXPECT_EQ(rt, EINVAL); req.tv_sec = 1; req.tv_nsec = -1; LOG("check invlid timespec: tv_nsec=-1 ..."); rt = clock_nanosleep(CLOCK_REALTIME, 0, &req, &rem); EXPECT_EQ(rt, EINVAL); req.tv_sec = 1; req.tv_nsec = 1000 * 1000 * 1000 + 1; LOG("check invlid timespec: tv_nsec overflow ..."); rt = clock_nanosleep(CLOCK_REALTIME, 0, &req, &rem); EXPECT_EQ(rt, EINVAL); // invlid remain // para not used, so not tested. }