/**
 * Copyright (c) 2025 Huawei Technologies Co., Ltd.
 * This program is free software, you can redistribute it and/or modify it under the terms and conditions of
 * CANN Open Software License Agreement Version 2.0 (the "License").
 * Please refer to the License for details. You may not use this file except in compliance with the License.
 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED,
 * INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
 * See LICENSE in the root of the software repository for the full text of the License.
 */
#include <dlfcn.h>
#include "gtest/gtest.h"
#include "mockcpp/mockcpp.hpp"
#include "bqs_log.h"
#include "bqs_feature_ctrl.h"
#include "securec.h"

using namespace bqs;

class QsLogStest : public ::testing::Test {
public:
    virtual void SetUp() {}

    virtual void TearDown() {
        GlobalMockObject::verify();
    }
};

TEST_F(QsLogStest, OpenLogSo001)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(false));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, OpenLogSo002)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, OpenLogSo003)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    setenv("ASCEND_AICPU_PATH", "/home", 1);
    MOCKER(memset_s).stubs().will(returnValue(EINVAL));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, OpenLogSo004)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    setenv("ASCEND_AICPU_PATH", "/home", 1);
    MOCKER(memset_s).stubs().will(returnValue(EOK));
    char *a = nullptr;
    MOCKER(realpath).stubs().will(returnValue(a));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, OpenLogSo005)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    setenv("ASCEND_AICPU_PATH", "/home", 1);
    MOCKER(memset_s).stubs().will(returnValue(EOK));
    char_t path[] = "test";
    MOCKER(realpath).stubs().will(returnValue(&path[0U]));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}


TEST_F(QsLogStest, OpenLogSo006)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    setenv("ASCEND_AICPU_PATH", "/home", 1);
    MOCKER(memset_s).stubs().will(returnValue(EOK)).then(returnValue(EINVAL));
    char_t path[] = "test";
    MOCKER(realpath).stubs().will(returnValue(&path[0U]));
    uint64_t rest = 0;
    MOCKER(dlopen).stubs().will(returnValue((void*)(&rest)));
    MOCKER(dlsym).stubs().will(returnValue(static_cast<void *>(nullptr)));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, OpenLogSo007)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    setenv("ASCEND_AICPU_PATH", "/home", 1);
    MOCKER(memset_s).stubs().will(returnValue(EOK)).then(returnValue(EOK));
    char_t path[] = "test";
    char *a = nullptr;
    MOCKER(realpath).stubs().will(returnValue(&path[0U])).then(returnValue(a));
    uint64_t rest = 0;
    MOCKER(dlopen).stubs().will(returnValue((void*)(&rest)));
    MOCKER(dlsym).stubs().will(returnValue(static_cast<void *>(nullptr)));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, OpenLogSo008)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    setenv("ASCEND_AICPU_PATH", "/home", 1);
    MOCKER(memset_s).stubs().will(returnValue(EOK)).then(returnValue(EOK));
    char_t path[] = "test";
    MOCKER(realpath).stubs().will(returnValue(&path[0U]));
    uint64_t rest = 0;
    MOCKER(dlopen).stubs().will(returnValue((void*)(&rest))).then(returnValue((void*)1));
    MOCKER(dlsym).stubs().will(returnValue(static_cast<void *>(nullptr)));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, OpenLoLogPrintNormal001)
{
    bqs::HostQsLog::GetInstance().LogPrintNormal(0, 0, "[tid:%llu] ", 1);
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, OpenLoLogLogPrintError001)
{
    bqs::HostQsLog::GetInstance().LogPrintError(0, "[tid:%llu] ", 1);
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, CheckLogLevel001)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    bqs::HostQsLog::GetInstance().CheckLogLevel(0, 1);
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, CheckLogLevel002)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    MOCKER_CPP(&bqs::HostQsLog::CheckLogLevelHost).stubs().will(returnValue(true));
    bqs::HostQsLog::GetInstance().CheckLogLevel(0, 1);
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}

TEST_F(QsLogStest, CheckLogLevel003)
{
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    MOCKER_CPP(&bqs::FeatureCtrl::IsHostQs).stubs().will(returnValue(true));
    setenv("ASCEND_AICPU_PATH", "/home", 1);
    MOCKER(memset_s).stubs().will(returnValue(EOK)).then(returnValue(EOK));
    char_t path[] = "test";
    void *a = dlsym(RTLD_DEFAULT, "CheckLogLevel");
    MOCKER(realpath).stubs().will(returnValue(&path[0U]));
    uint64_t rest = 0;
    MOCKER(dlopen).stubs().will(returnValue((void*)(&rest))).then(returnValue((void*)1));
    MOCKER(dlsym).stubs().will(returnValue(a));
    bqs::HostQsLog::GetInstance().OpenLogSo();
    bqs::HostQsLog::GetInstance().CheckLogLevel(0, 1);
    EXPECT_NE(&(bqs::HostQsLog::GetInstance()), nullptr);
}