In this blog, software developers and architects who have a basic knowledge of the MuleSoft Anypoint development environment will learn useful development best practices about the MUnit 2 testing framework.
MUnit 2 Overview:
MUnit 2 is a Mule application testing framework that allows you to easily build automated tests for your integrations and APIs. It works with all Mule versions, including the more recent Mule 4. MUnit 2 is also fully integrated with Anypoint Studio, allowing you to create, design, and run MUnit tests just like you would with Mule applications.
With MUnit 2, you can create your test by writing Mule code, mocking processors, spying any processor, verifying processor calls, enabling or ignoring particular tests, tagging tests, checking visual coverage in Studio, and generating coverage reports.
How to make MUnit 2 work for you
The MUnit 2 framework enables developers to create test suites, which are grouped into unit tests as resources within the Mule project.
The following screenshot shows a sample of what these resources look like in the project. Each Test Suite results in a separate configuration file (like Mule Configuration files), where each test is analogous to an ordinary Process Flow.
There are no rules for how you should organize your test suites.
Generally, test suites are organised in one of two ways:
For us, the best way to structure Test Suites is by interface or API, as this approach allows for increased modularity, better maintenance, and easier development of microservices (think of each API as a microservice).
The MUnit message processors allow you to:
Create a groovy script as follows, named “mockDbRowScript” which, in this example, returns the proper structure:
import org.mule.util.CaseInsensitiveHashMap;
LinkedList<CaseInsensitiveHashMap<String, String>> rSet = new
LinkedList<CaseInsensitiveHashMap<String, String>>();
CaseInsensitiveHashMap<String, String> rowDataMap = new
CaseInsensitiveHashMap<String, String>();
rowDataMap.put(“PHONE”, “(815)-254-0356”);
rowDataMap.put(“DISTANCE”, “1.3 miles”);
rowDataMap.put(“ADDRESS2”, “Romeoville IL 60446”);
rowDataMap.put(“UID”, “1000”);
rowDataMap.put(“ADDRESS1”, “13546 State Route 30”);
rowDataMap.put(“SERVICES”, “Gift Cards”);
rSet.add(rowDataMap);
return rSet;
This is referenced from the mock code with a call to the “resultOfScript” function.
There are two ways to test: Going through the APIkit router, or not going through the APIkit router.
When using MUnit for APIkit-based projects, the developer can right-click on the APIkit Router to generate useful test skeletons.
Depending on the projects, reasonable numbers can be in the 80-90% range.
Provides a metric on how much of a Mule application code has been executed by a set of MUnit tests.
MUnit Coverage is based on the amount of message processors executed.
MUnit Coverage provides metrics for:- Application overall coverage
 Resource coverage: Refers to each Mule configuration file under src/main/app.  Each   of is considered a resource   by MUnit Coverage.
Flow coverage: Refers to any of the following Flows, Sub-flows, and Batch jobs.
Properly configured, MUnit 2 can generate a coverage report in the “target” directory of your build. By default, the report comes in HTML format, you can also configure JSON format, which better supports automated tasks.
The code coverage behavior can be configured in the POM file using the Maven MUnit Plugin:
<project .....
...
<plugins>
<plugin>
.....
</plugin>
...
<plugin>
<groupId>com.mulesoft.munit.tools</groupId>
<artifactId>munit-maven-plugin</artifactId>
<version>${munit.version}</version>
...
<configuration>
<coverage>
<runCoverage>true</runCoverage>
<failBuild>true</failBuild>
<requiredApplicationCoverage><numeric>
</requiredApplicationCoverage>
<requiredResourceCoverage><numeric>
</requiredResourceCoverage>
<requiredFlowCoverage><numeric>
</requiredFlowCoverage>
<formats>
<format>html</format>
<format>json</format>
</formats>
</coverage>
</configuration>
</plugin>
</plugins>
....
Maven is a software packaging framework that specifies how an application (usually Java) should be assembled, including any dependencies it may have.
By default, most Mule applications are built using Maven because of its many useful features, such as its efficient support of dependency management.
MUnit test cases are executed for every Maven build. For each and every code, check-in into the project code repository, such as SVN or GIT, the configured Jenkins JOB (a CI/CD process) is executed. Part of the configured JOB is to run the MUnit tests. If the test cases fail, the Maven build will also fail. If the test cases pass, the build will pass and the artifact will be moved to the artifact repository. This process will take place for every code check-in into the code repository.
The CI/CD (Continuous Integration / Continuous Deployment) process relies on tools like Maven to enable parallel and continuous code development and deployment.
MUnit allows tests to be run inside of MuleSoft Anypoint Studio, which is a useful step to perform while coding. However, prior to committing/pushing your software to the code repository, you need to test the MUnit artifacts in the same way they are going to be executed in the scope of your project. For example, you would need to test from the command line if you are using Jenkins.
Running a specific test suite from command line:
mvn clean test -Dmunit.test=<regex-test-suite>
Running test with regular expression:
mvn clean test -Dmunit.test=.*my-test.*
Run a specific test inside that test suite:
mvn clean test -Dmunit.test=<regex-test-suite>#<regex-test-name>
Skip MUnit Tests:
–DskipTests or –DskipMunitTests
Best Practices:
Click here to see an example of the process of creating a series of MUnit tests, which are aimed at validating the behaviour of a simple code sample.
If you would like to find out more about the MUnit 2 testing framework, do give us a call at +44 (0)203 475 7980 or email us at Salesforce@coforge.com
Other useful links:
An example of how to create an MUnit 2 test