This article explores the concept, advantages, disadvantages, and a demonstration example of Continuous Integration (CI).
Historical Review
First, let’s take a brief look at the history.
In 1999, Kent Beck explored this topic in depth in his first book on Extreme Programming. In 2001, CruiseControl, one of the first open source CI tools, was born.
Why use CI?
The goal of CI is to execute automated tests after every code commit. This ensures that the code always remains functional. We call this continuous integration because every time the code is modified it is verified to ensure no regression issues occur.
Advantages
- Catch errors early: Problems are identified quickly, allowing for timely responses.
- Improving quality: Systematic testing ensures more robust code.
- Time Saving: Automated pipelines reduce the need for repetitive manual testing.
Disadvantages
- Initial Cost: Setting up CI can require significant initial investment and expertise.
- Execution time: Complex pipelines may extend the time it takes for developers to verify their code.
How it works
Before we understand how it works, let’s understand some terminology:
- Jobs: An instance of a container (usually Docker) used to execute scripts. This may include commands, tests, or simple operations such as echo.
- Pipeline: A series of jobs organized in sequence or in parallel. Each commit triggers this series of actions to validate the changes.
The principle is simple: each job returns a status code (success or failure). If a job fails, the pipeline will stop or skip subsequent steps depending on configuration.
Practical drill
We will use GitLab CI based examples. Can be configured through .gitlab-ci.yml
files.
Basic Example
<code>image: alpine:latest myjobname: script: - make</code>
Compile flags
Add compilation flags, there are two methods:
- Pass rules in Makefile.
- Pass flags directly in CI commands.
<code>myjobname_hard: script: - CFLAGS="-Wall -Werror" make # 或者 - make compile_flags</code>
Using Criterion for testing and flagging
Criterion is a C language unit testing library.
Criterion installation
Before using Criterion for testing, you need to install Criterion.
<code>before_script: - apt-get update && apt-get install -y libcriterion-dev script: - ./configure - make test</code>
Multi-stage construction
Split unit testing and functional testing into multiple phases, you can:
- Better Organized
- Better view of results
<code>stages: - build - test build: stage: build script: - make all test-unit: stage: test script: - make unit-test test-functional: stage: test script: - make functional-test</code>
Use Clang to format code
Code formatting is crucial to maintaining a clean code base.
<code>image: alpine:latest myjobname: script: - make</code>
Cache
In some cases it is useful to cache files or folders to avoid reloading them every time the pipeline is run.
A common example is the node_modules/
folder in JavaScript.
<code>myjobname_hard: script: - CFLAGS="-Wall -Werror" make # 或者 - make compile_flags</code>
Of course, you can use additional options in the pipeline configuration to clear the cache if needed.
Artifact
Artifacts are CI-generated files that can be shared or downloaded across jobs.
For example, testing or coverage reports.
<code>before_script: - apt-get update && apt-get install -y libcriterion-dev script: - ./configure - make test</code>
Test Coverage
Test coverage can be measured by integrating tools like gcovr or Cobertura in your CI pipeline.
<code>stages: - build - test build: stage: build script: - make all test-unit: stage: test script: - make unit-test test-functional: stage: test script: - make functional-test</code>
Report
This code block allows you to integrate coverage reporting into your merge requests so that you can see the code that is not covered as well as the coverage percentage.
<code>clang_format: stage: format before_script: - apt-get -qq update && apt-get -qq install -y clang-format autotools-dev autoconf-archive gcovr libcriterion-dev script: - clang-format -i $(find src/ -type f -name "*.c") --dry-run --Werror</code>
Customized environment
You can specify the base environment for CI by selecting a specific Docker image.
<code>cache: paths: - node_modules/ install: script: - npm install</code>
Combining the above content, you can get the following example:
<code>artifacts: paths: - build/ - reports/</code>
Note that the
.h
file is missing andbefore_script
is missing.
Additional supplements
You can also check for junk files to make sure make clean
is working properly.
<code>test-coverage: stage: test script: - gcovr --html --html-details -o coverage.html artifacts: paths: - coverage.html</code>
Summary
Continuous integration is an extremely powerful tool. While it can be difficult to set up, the benefits are huge.
The above is the detailed content of Testing is cheating, compiling is doubting. For more information, please follow other related articles on the PHP Chinese website!

Working with XML data structures in C can use the TinyXML or pugixml library. 1) Use the pugixml library to parse and generate XML files. 2) Handle complex nested XML elements, such as book information. 3) Optimize XML processing code, and it is recommended to use efficient libraries and streaming parsing. Through these steps, XML data can be processed efficiently.

C still dominates performance optimization because its low-level memory management and efficient execution capabilities make it indispensable in game development, financial transaction systems and embedded systems. Specifically, it is manifested as: 1) In game development, C's low-level memory management and efficient execution capabilities make it the preferred language for game engine development; 2) In financial transaction systems, C's performance advantages ensure extremely low latency and high throughput; 3) In embedded systems, C's low-level memory management and efficient execution capabilities make it very popular in resource-constrained environments.

The choice of C XML framework should be based on project requirements. 1) TinyXML is suitable for resource-constrained environments, 2) pugixml is suitable for high-performance requirements, 3) Xerces-C supports complex XMLSchema verification, and performance, ease of use and licenses must be considered when choosing.

C# is suitable for projects that require development efficiency and type safety, while C is suitable for projects that require high performance and hardware control. 1) C# provides garbage collection and LINQ, suitable for enterprise applications and Windows development. 2)C is known for its high performance and underlying control, and is widely used in gaming and system programming.

C code optimization can be achieved through the following strategies: 1. Manually manage memory for optimization use; 2. Write code that complies with compiler optimization rules; 3. Select appropriate algorithms and data structures; 4. Use inline functions to reduce call overhead; 5. Apply template metaprogramming to optimize at compile time; 6. Avoid unnecessary copying, use moving semantics and reference parameters; 7. Use const correctly to help compiler optimization; 8. Select appropriate data structures, such as std::vector.

The volatile keyword in C is used to inform the compiler that the value of the variable may be changed outside of code control and therefore cannot be optimized. 1) It is often used to read variables that may be modified by hardware or interrupt service programs, such as sensor state. 2) Volatile cannot guarantee multi-thread safety, and should use mutex locks or atomic operations. 3) Using volatile may cause performance slight to decrease, but ensure program correctness.

Measuring thread performance in C can use the timing tools, performance analysis tools, and custom timers in the standard library. 1. Use the library to measure execution time. 2. Use gprof for performance analysis. The steps include adding the -pg option during compilation, running the program to generate a gmon.out file, and generating a performance report. 3. Use Valgrind's Callgrind module to perform more detailed analysis. The steps include running the program to generate the callgrind.out file and viewing the results using kcachegrind. 4. Custom timers can flexibly measure the execution time of a specific code segment. These methods help to fully understand thread performance and optimize code.

Using the chrono library in C can allow you to control time and time intervals more accurately. Let's explore the charm of this library. C's chrono library is part of the standard library, which provides a modern way to deal with time and time intervals. For programmers who have suffered from time.h and ctime, chrono is undoubtedly a boon. It not only improves the readability and maintainability of the code, but also provides higher accuracy and flexibility. Let's start with the basics. The chrono library mainly includes the following key components: std::chrono::system_clock: represents the system clock, used to obtain the current time. std::chron


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

Notepad++7.3.1
Easy-to-use and free code editor

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
