7.1. Medusa Testing Tools
In this chapter, you'll learn about Medusa's testing tools and how to install and configure them.
@medusajs/test-utils Package#
Medusa provides a Testing Framework to create integration tests for your custom API routes, modules, or other Medusa customizations.
To use the Testing Framework, install @medusajs/test-utils as a devDependency:
Install and Configure Jest#
Writing tests with @medusajs/test-utils's tools requires installing and configuring Jest in your project.
Run the following command to install the required Jest dependencies:
Then, create the file jest.config.js with the following content:
1const { loadEnv } = require("@medusajs/framework/utils")2loadEnv("test", process.cwd())3 4module.exports = {5 transform: {6 "^.+\\.[jt]s$": [7 "@swc/jest",8 {9 jsc: {10 parser: { syntax: "typescript", decorators: true },11 target: "es2021",12 },13 },14 ],15 },16 testEnvironment: "node",17 moduleFileExtensions: ["js", "ts", "json"],18 modulePathIgnorePatterns: ["dist/"],19 setupFiles: ["./integration-tests/setup.js"],20}21 22if (process.env.TEST_TYPE === "integration:http") {23 module.exports.testMatch = ["**/integration-tests/http/*.spec.[jt]s"]24} else if (process.env.TEST_TYPE === "integration:modules") {25 module.exports.testMatch = ["**/src/modules/*/__tests__/**/*.[jt]s"]26} else if (process.env.TEST_TYPE === "unit") {27 module.exports.testMatch = ["**/src/**/__tests__/**/*.unit.spec.[jt]s"]28}
Next, create the integration-tests/setup.js file with the following content:
@medusajs/framework package. If you're using an older version of Medusa, change the require statement to @mikro-orm/core.Add Test Commands#
Finally, add the following scripts to package.json:
1"scripts": {2 // ...3 "test:integration:http": "TEST_TYPE=integration:http NODE_OPTIONS=--experimental-vm-modules jest --silent=false --runInBand --forceExit",4 "test:integration:modules": "TEST_TYPE=integration:modules NODE_OPTIONS=--experimental-vm-modules jest --silent=false --runInBand --forceExit",5 "test:unit": "TEST_TYPE=unit NODE_OPTIONS=--experimental-vm-modules jest --silent --runInBand --forceExit"6},
You now have two commands:
- test:integration:httpto run integration tests (for example, for API routes and workflows) available under the- integration-tests/httpdirectory.
- test:integration:modulesto run integration tests for modules available in any- __tests__directory under- src/modules.
- test:unitto run unit tests in any- __tests__directory under the- srcdirectory.
Test Tools and Writing Tests#
The next chapters explain how to use the testing tools provided by @medusajs/test-utils to write tests.


