8 Commits

Author SHA1 Message Date
0fa6097bbf Merge branch 'dev' of github.com:WangZhongDian/logging into dev 2024-11-02 12:54:18 +08:00
f6e2c31c85 修复错别字 2024-11-02 12:51:03 +08:00
youmetme
c7c6af7dcf Merge branch 'main' into dev 2024-11-02 12:37:14 +08:00
0d78195e4e test action 2024-11-02 12:34:15 +08:00
01273809da fix:conanfile 2024-11-01 17:30:39 +08:00
4213c38730 加入test脚本 2024-10-10 22:12:50 +08:00
9963f68175 更新版本号 2024-09-21 15:08:39 +08:00
85ae9d3deb #feat 增强Fatal级别的底色,修改logging类的方法 2024-09-21 11:45:41 +08:00
7 changed files with 52 additions and 32 deletions

17
.github/workflows/linux_test.yml vendored Normal file
View File

@@ -0,0 +1,17 @@
name: test on Linux
on:
push:
branches: ["main"]
pull_request:
branches: ["main"]
jobs:
test:
runs-on: ubuntu-latest
steps:
- name: checkout code
uses: actions/checkout@v4
- name: test
run: bash ./test.sh

View File

@@ -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()

View File

@@ -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"]

View File

@@ -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)

View File

@@ -9,16 +9,15 @@
#include <string.h>
#include <time.h>
#define RED "\033[0;31m"
#define RED_B "\033[0;41m"
#define GREEN "\033[0;32m"
#define YELLOW "\033[0;33m"
#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 RED "\033[0;31m"
#define RED_B "\033[0;41m"
#define GREEN "\033[0;32m"
#define YELLOW "\033[0;33m"
#define BLUE "\033[0;34m"
#define RESET "\033[0m"
#define CYAN "\033[0;36m"
#define LOG_BUFFER_SIZE 1024

2
test.sh Executable file
View File

@@ -0,0 +1,2 @@
#!/bin/bash
cmake build -B build . && cd build && make && ctest

View File

@@ -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)