1570af302Sopenharmony_ci/** 2570af302Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd. 3570af302Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4570af302Sopenharmony_ci * you may not use this file except in compliance with the License. 5570af302Sopenharmony_ci * You may obtain a copy of the License at 6570af302Sopenharmony_ci * 7570af302Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8570af302Sopenharmony_ci * 9570af302Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10570af302Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11570af302Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12570af302Sopenharmony_ci * See the License for the specific language governing permissions and 13570af302Sopenharmony_ci * limitations under the License. 14570af302Sopenharmony_ci */ 15570af302Sopenharmony_ci 16570af302Sopenharmony_ci#include <math.h> 17570af302Sopenharmony_ci#include <stdlib.h> 18570af302Sopenharmony_ci#include "functionalext.h" 19570af302Sopenharmony_ci 20570af302Sopenharmony_ci#define TEST_JRAND_SIZE 3 21570af302Sopenharmony_ci#define TWO 2 22570af302Sopenharmony_ci#define THIRTYONE 31 23570af302Sopenharmony_ci 24570af302Sopenharmony_ci/** 25570af302Sopenharmony_ci * @tc.name : jrand48_0100 26570af302Sopenharmony_ci * @tc.desc : Use [1, 2, 3] as parameters to generate a long integer random number 27570af302Sopenharmony_ci * @tc.level : Level 0 28570af302Sopenharmony_ci */ 29570af302Sopenharmony_civoid jrand48_0100(void) 30570af302Sopenharmony_ci{ 31570af302Sopenharmony_ci unsigned short s[TEST_JRAND_SIZE] = {1, 2, 3}; 32570af302Sopenharmony_ci long rev = jrand48(s); 33570af302Sopenharmony_ci EXPECT_TRUE("jrand48_0100", rev < pow(TWO, THIRTYONE) && rev > -pow(TWO, THIRTYONE)); 34570af302Sopenharmony_ci} 35570af302Sopenharmony_ci 36570af302Sopenharmony_ci/** 37570af302Sopenharmony_ci * @tc.name : jrand48_0200 38570af302Sopenharmony_ci * @tc.desc : Use [0, 0, 0] as parameters to generate a long integer random number 39570af302Sopenharmony_ci * @tc.level : Level 0 40570af302Sopenharmony_ci */ 41570af302Sopenharmony_civoid jrand48_0200(void) 42570af302Sopenharmony_ci{ 43570af302Sopenharmony_ci unsigned short s[TEST_JRAND_SIZE] = {0, 0, 0}; 44570af302Sopenharmony_ci long rev = jrand48(s); 45570af302Sopenharmony_ci EXPECT_EQ("jrand48_0200", rev, 0); 46570af302Sopenharmony_ci} 47570af302Sopenharmony_ci 48570af302Sopenharmony_ci/** 49570af302Sopenharmony_ci * @tc.name : mrand48_0100 50570af302Sopenharmony_ci * @tc.desc : Verify mrand48 process success. Generate a long integer random number 51570af302Sopenharmony_ci * @tc.level : Level 0 52570af302Sopenharmony_ci */ 53570af302Sopenharmony_civoid mrand48_0100(void) 54570af302Sopenharmony_ci{ 55570af302Sopenharmony_ci unsigned short p[7] = {0x0102, 0x0304, 0x0506, 0x0708, 0x090a, 0x0b0c, 0x0d0e}; 56570af302Sopenharmony_ci lcong48(p); 57570af302Sopenharmony_ci long ret = mrand48(); 58570af302Sopenharmony_ci EXPECT_TRUE("mrand48_0100", ret < pow(TWO, THIRTYONE) && ret > -pow(TWO, THIRTYONE)); 59570af302Sopenharmony_ci} 60570af302Sopenharmony_ci 61570af302Sopenharmony_ciint main(void) 62570af302Sopenharmony_ci{ 63570af302Sopenharmony_ci mrand48_0100(); 64570af302Sopenharmony_ci jrand48_0100(); 65570af302Sopenharmony_ci jrand48_0200(); 66570af302Sopenharmony_ci return t_status; 67570af302Sopenharmony_ci}