“This article has participated in the good article call order activity, click to see: back end, big front end double track submission, 20,000 yuan prize pool for you to challenge!”
Does the background
When using Sonarqube to scan static code, there is often some code that doesn't conform to its rules. Of course, some code is unavoidable and can't be changed, but there is some complex logical code with room for improvement that is worth changing, but the development cycle is a little tighter. If you want to verify that the code has room for improvement, you need to write your own unit test code, and then override the unit tests of its statement branch and conditional branch. It turns out that it's really hard to cover all of the test scenarios when you're doing manual testing, so the logical code doesn't cover all of the tests.Copy the code
Does plan
Although there is no way to cover, but also have to do < have to find something to do >, so clone code to the local unit test < no design, just simple data coverage first - some branches >, but this is not intuitive, you can not know which code your unit tests to test. So to introduce a tool that detects code coverage: Jacoco, which was previously integrated and used in the Eclipse tools.Copy the code
Does the action
- 1, first step: POM configuration < this time using IntelliJ IDEA tool >
<dependency>
<groupId>org.jacoco</groupId>
<artifactId>jacoco-maven-plugin</artifactId>
<version>0.8.4</version>
</dependency>
<plugin>
<groupId>org.jacoco</groupId>
<artifactId>jacoco-maven-plugin</artifactId>
<version>0.8.4</version>
<configuration>
<destFile>target/coverage-reports/jacoco-unit.exec</destFile>
<dataFile>target/coverage-reports/jacoco-unit.exec</dataFile>
<includes>
<include>**/service/**</include>
<include>**/controller/**</include>
<! --<include>**/service/impl/*.class</include>-->
</includes>
<! -- rule = override rule -->
<rules>
<rule implementation="org.jacoco.maven.RuleConfiguration">
<element>BUNDLE</element>
<limits>
<! -- Specify method override to 50% -->
<limit implementation="org.jacoco.report.check.Limit">
<counter>METHOD</counter>
<value>COVEREDRATIO</value>
<minimum>0.50</minimum>
</limit>
<! -- specify branch coverage to 50% -->
<limit implementation="org.jacoco.report.check.Limit">
<counter>BRANCH</counter>
<value>COVEREDRATIO</value>
<minimum>0.50</minimum>
</limit>
<! -- Specify 100% class coverage, no class can be lost -->
<limit implementation="org.jacoco.report.check.Limit">
<counter>CLASS</counter>
<value>MISSEDCOUNT</value>
<maximum>0</maximum>
</limit>
</limits>
</rule>
</rules>
</configuration>
<executions>
<execution>
<id>jacoco-initialize</id>
<goals>
<goal>prepare-agent</goal>
</goals>
</execution>
<! -- Check the code to control whether the project builds successfully or fails -->
<execution>
<id>check</id>
<goals>
<goal>check</goal>
</goals>
</execution>
<! You can see the detailed results of the inspection in target/site/index.html -->
<execution>
<id>jacoco-site</id>
<phase>package</phase>
<goals>
<goal>report</goal>
</goals>
</execution>
</executions>
</plugin>
Copy the code
- 2. Configure IDEA tool
- 3. Click the Set button
- 4, select TestNG framework < personal habit, know that most background development also like to use Junit>
- 5. Follow the configuration above to start executing the test case, remember to select Coverage
- 6. Warm tip: The name of the package to create the test case should be the same as the code under SRC /main/ Java, otherwise it will not be found
- 7, click 6, you can generate code coverage HTML test report anywhere, you can customize the output path, the effect is as follows:
※ Summary: Understand how jacoco works and why it is used
Principle: Simple to use ASM to dynamically modify the bytecode, piling in the code, so as to carry out statistics; The purpose: very simply, to check our code’s logical coverage and improve the quality of our code.