Dev test (#6)
* #feat 增强Fatal级别的底色,修改logging类的方法 * 更新版本号 * 加入test脚本 * fix:conanfile * test action
This commit is contained in:
17
.github/workflows/linux_test.yml
vendored
Normal file
17
.github/workflows/linux_test.yml
vendored
Normal file
@@ -0,0 +1,17 @@
|
||||
|
||||
name: test on Linux
|
||||
|
||||
on:
|
||||
push:
|
||||
branches: ["mian"]
|
||||
pull_request:
|
||||
branches: ["mian"]
|
||||
|
||||
jobs:
|
||||
test:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: checkout code
|
||||
uses: actions/checkout@v4
|
||||
- name: test
|
||||
run: bash ./test.sh
|
||||
@@ -1,5 +1,8 @@
|
||||
cmake_minimum_required( VERSION 3.28)
|
||||
project(logging)
|
||||
|
||||
option(TEST "是否启动单元测试" ON)
|
||||
option(SHARED "是否编译为动态库" OFF)
|
||||
|
||||
set(LIBRARY_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/lib)
|
||||
set(ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/lib)
|
||||
@@ -11,7 +14,7 @@ include_directories(${CMAKE_SOURCE_DIR}/include)
|
||||
add_subdirectory(src)
|
||||
|
||||
#测试单元
|
||||
if (SKIPTEST)
|
||||
else()
|
||||
if (TEST)
|
||||
enable_testing()
|
||||
add_subdirectory(tests)
|
||||
endif()
|
||||
|
||||
27
conanfile.py
27
conanfile.py
@@ -1,11 +1,8 @@
|
||||
from conan import ConanFile
|
||||
from conan.tools.cmake import CMake, CMakeToolchain, CMakeDeps, cmake_layout
|
||||
from conan.tools.files import copy, get
|
||||
from conan.tools.build import check_min_cppstd
|
||||
from conan import tools
|
||||
from conan.tools.files import copy
|
||||
import os
|
||||
|
||||
|
||||
class loggingRecipe(ConanFile):
|
||||
name = "logging"
|
||||
version = "0.2.3"
|
||||
@@ -16,11 +13,11 @@ class loggingRecipe(ConanFile):
|
||||
topics = ("logging", "C", "simple", "easy-to-use", "log","Logging")
|
||||
|
||||
settings = "os", "compiler", "build_type", "arch"
|
||||
options = {"shared": [True, False], "fPIC": [True, False]}
|
||||
default_options = {"shared": False, "fPIC": True}
|
||||
options = {"shared": [True, False], "fPIC": [True, False],"test":[True,False]}
|
||||
default_options = {"shared": False, "fPIC": True,"test":True}
|
||||
|
||||
|
||||
exports_sources = "include/*", "CMakeLists.txt", "src/*"
|
||||
exports_sources = "include/*", "CMakeLists.txt", "src/*", "tests/*"
|
||||
|
||||
def config_options(self):
|
||||
if self.settings.os == "Windows":
|
||||
@@ -30,8 +27,6 @@ class loggingRecipe(ConanFile):
|
||||
if self.options.shared:
|
||||
self.options.rm_safe("fPIC")
|
||||
|
||||
|
||||
|
||||
def layout(self):
|
||||
cmake_layout(self)
|
||||
|
||||
@@ -39,18 +34,16 @@ class loggingRecipe(ConanFile):
|
||||
deps = CMakeDeps(self)
|
||||
deps.generate()
|
||||
tc = CMakeToolchain(self)
|
||||
tc.variables["SKIPTEST"]=True
|
||||
if self.options.shared:
|
||||
tc.variables["SHARED"] = True
|
||||
else:
|
||||
tc.variables["SHARED"] = False
|
||||
tc.variables["TEST"] = True if self.options.test else False
|
||||
tc.variables["SHARED"] = True if self.options.shared else False
|
||||
tc.generate()
|
||||
|
||||
def build(self):
|
||||
cmake = CMake(self)
|
||||
cmake.configure()
|
||||
cmake.build(target="Logging")
|
||||
|
||||
cmake.build()
|
||||
if self.options.test:
|
||||
cmake.test()
|
||||
|
||||
def package(self):
|
||||
copy(self, "LICENSE", src=self.source_folder, dst=os.path.join(self.package_folder, "licenses"))
|
||||
@@ -62,4 +55,4 @@ class loggingRecipe(ConanFile):
|
||||
copy(self, pattern="*.dylib", src=self.build_folder, dst=os.path.join(self.package_folder, "lib"), keep_path=False)
|
||||
|
||||
def package_info(self):
|
||||
self.cpp_info.libs = ["Logging"]
|
||||
self.cpp_info.libs = ["logging"]
|
||||
@@ -1,4 +1,4 @@
|
||||
project(Logging)
|
||||
project(logging)
|
||||
|
||||
aux_source_directory(${CMAKE_CURRENT_SOURCE_DIR} SRC)
|
||||
aux_source_directory(${CMAKE_CURRENT_SOURCE_DIR}/handler SRC)
|
||||
|
||||
@@ -9,6 +9,7 @@
|
||||
#include <string.h>
|
||||
#include <time.h>
|
||||
|
||||
|
||||
#define RED "\033[0;31m"
|
||||
#define RED_B "\033[0;41m"
|
||||
#define GREEN "\033[0;32m"
|
||||
@@ -16,9 +17,7 @@
|
||||
#define BLUE "\033[0;34m"
|
||||
#define RESET "\033[0m"
|
||||
#define CYAN "\033[0;36m"
|
||||
#define MAGENTA "\033[0;35m"
|
||||
#define WHITE "\033[0;37m"
|
||||
#define BLACK "\033[0;30m"
|
||||
|
||||
|
||||
#define LOG_BUFFER_SIZE 1024
|
||||
|
||||
|
||||
2
test.sh
Executable file
2
test.sh
Executable file
@@ -0,0 +1,2 @@
|
||||
#!/bin/bash
|
||||
cmake build -B build . && cd build && make && ctest
|
||||
@@ -1,8 +1,14 @@
|
||||
project(test)
|
||||
|
||||
enable_testing()
|
||||
|
||||
#测试简单基本应用
|
||||
add_executable(${PROJECT_NAME}simple test_simple.c)
|
||||
target_link_libraries(${PROJECT_NAME}simple Logging)
|
||||
target_link_libraries(${PROJECT_NAME}simple logging)
|
||||
add_test(test_simple ${CMAKE_SOURCE_DIR}/bin/${PROJECT_NAME}simple)
|
||||
|
||||
|
||||
#测试拦截器
|
||||
add_executable(${PROJECT_NAME}interceptor test_interceptor.c)
|
||||
target_link_libraries(${PROJECT_NAME}interceptor Logging)
|
||||
target_link_libraries(${PROJECT_NAME}interceptor logging)
|
||||
add_test(test_interceptor ${CMAKE_SOURCE_DIR}/bin/${PROJECT_NAME}interceptor)
|
||||
Reference in New Issue
Block a user