Vitest
Wallaby supports Vitest from v0.14.0 with node v16.12.0+.
Please report any issues or feedback to us via our github issues repository.
Starting Wallaby on a project with configured Vitest
To start Wallaby in VS Code you may run Select Configuration
command and then select Automatic Configuration <project directory>
option once. After that you may keep using Wallaby Start
command as usual and it will start Wallaby with automatic configuration.
To start Wallaby in Sublime Text you may use the Select for Wallaby.js Automatic Configuration
context menu item for your project folder in the project’s file tree. After that you may keep using Wallaby Start
command as usual and it will start Wallaby with automatic configuration.
To start Wallaby in Visual Studio, you may use the Start Wallaby.js (Automatic Configuration)
context menu item for your project folder in the Solution Explorer. After the first start,
the selected project will be remembered for your solution and Wallaby can be started with Tools->Start Wallaby.js (Alt-W, 1)
.
To start Wallaby in JetBrains IDEs, you may edit (or create a new) wallaby.js Run Configuration
by selecting Edit configurations
from the drop-down menu in the top right-hand corner of the navigation bar, or from the Run menu. In the run configuration editor set Configuration Type
filed value to Automatic
.
Overriding Automatic Configuration
Sometimes you may want to add/override some Wallaby configuration settings to the automatically detected settings. For example, if you want to exclude some tests when you are using Wallaby but not when you are running tests from the command-line or Continuous Integration build. You may configure an override in a configuration file or package.json
section. If you are not using vitest’s default configuration file naming convention (i.e. vitest.config.ts
, vite.config.ts
, etc.), then you may also configure the configuration file path.
After creating Wallaby config file to override automatic defaults in VS Code you need to run Select Configuration
command and then select the config file once. After that you may keep using Wallaby Start
command as usual and it will start Wallaby with the configuration file.
After creating Wallaby config file to override automatic defaults in JetBrains IDEs, you may edit (or create a new) wallaby.js Run Configuration
by selecting Edit configurations
from the drop-down menu in the top right-hand corner of the navigation bar, or from the Run menu. In the run configuration editor set Configuration Type
filed value to Configuration File
.
Note that if you are adding/overriding files
/tests
, then you need to add the autoDetect: true
setting:
wallaby.js
Using pnpm
Some Wallaby internals need to dynamically load your project dependencies and patch them both at runtime and in the file system. Depending on your project type and the packages you are using, sometimes Wallaby may fail to load without modifications to your .npmrc
file:
Using yarn2
Wallaby may report errors about missing dependencies when using Yarn 2. For example:
To fix this, you will need to add any listed dependencies to your project (e.g. yarn add -D @vitest/runner
).
Node settings
Node version
If you’d like to use your system default node.js version or any specific locally installed version instead of using the version configured for your IDE or editor, use the env.runner
property to specify a command to invoke node or a path to a node executable.
Node flags
If you need to pass some node flags, such as --harmony
, you may use env.params.runner
property for that:
Environment variables
If you need to pass some process.env
variables to the test environment, you may just set them right in the wallaby config file:
Alternatively, you may use env.params.env
property for it:
Troubleshooting
The first step of troubleshooting a project configured to use automatic configuration is to identify whether the same results are returned using npx vitest
. Running vitest from the command-line will usually show/highlight the cause of your problem.
If Wallaby is not working with vitest
, then you may like to try to downgrade to an earlier version of vitest to see if that fixes your problem. If this does fix your problem, please report this issue to the Wallaby team.
If you get stuck or something isn’t working for you, you may find further troubleshooting steps here or else find a similar solved issue in our github issues repository. If you can’t find a solution, create a new issue.