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 <errno.h> 17570af302Sopenharmony_ci#include <string.h> 18570af302Sopenharmony_ci#include <stdarg.h> 19570af302Sopenharmony_ci#include <syslog.h> 20570af302Sopenharmony_ci#include "test.h" 21570af302Sopenharmony_ci 22570af302Sopenharmony_ci#define INVALID_LEVEL (-1) 23570af302Sopenharmony_ci 24570af302Sopenharmony_ci/** 25570af302Sopenharmony_ci * @tc.name : vsyslog_0100 26570af302Sopenharmony_ci * @tc.desc : generates a log message 27570af302Sopenharmony_ci * @tc.level : Level 0 28570af302Sopenharmony_ci */ 29570af302Sopenharmony_civoid vsyslog_0100(char *s, ...) 30570af302Sopenharmony_ci{ 31570af302Sopenharmony_ci errno = 0; 32570af302Sopenharmony_ci va_list ap; 33570af302Sopenharmony_ci va_start(ap, s); 34570af302Sopenharmony_ci vsyslog(LOG_INFO, s, ap); 35570af302Sopenharmony_ci if (errno != 0) { 36570af302Sopenharmony_ci t_error("%s failed: errno = %d\n", __func__, errno); 37570af302Sopenharmony_ci } 38570af302Sopenharmony_ci va_end(ap); 39570af302Sopenharmony_ci} 40570af302Sopenharmony_ci 41570af302Sopenharmony_ci/** 42570af302Sopenharmony_ci * @tc.name : vsyslog_0200 43570af302Sopenharmony_ci * @tc.desc : generates a log message with an invalid level 44570af302Sopenharmony_ci * @tc.level : Level 2 45570af302Sopenharmony_ci */ 46570af302Sopenharmony_civoid vsyslog_0200(char *s, ...) 47570af302Sopenharmony_ci{ 48570af302Sopenharmony_ci errno = 0; 49570af302Sopenharmony_ci va_list ap; 50570af302Sopenharmony_ci va_start(ap, s); 51570af302Sopenharmony_ci vsyslog(INVALID_LEVEL, s, ap); 52570af302Sopenharmony_ci if (errno == 0) { 53570af302Sopenharmony_ci t_error("%s failed: errno = %d\n", __func__, errno); 54570af302Sopenharmony_ci } 55570af302Sopenharmony_ci va_end(ap); 56570af302Sopenharmony_ci} 57570af302Sopenharmony_ci 58570af302Sopenharmony_ciint main(int argc, char *argv[]) 59570af302Sopenharmony_ci{ 60570af302Sopenharmony_ci vsyslog_0100("vsyslog: %d", 1); 61570af302Sopenharmony_ci vsyslog_0200("vsyslog: %d", 1); 62570af302Sopenharmony_ci return t_status; 63570af302Sopenharmony_ci} 64