[not support vitest@v0.18.0] test successfully, but loading infinitely.
SoonIter opened this issue ยท 35 comments
Describe the bug
A clear and concise description of what the bug is.
I installed vitest V0.18.0,and it doesn`t work.
To Reproduce
Steps to reproduce the behavior on the example project:
- npx degit SoonIter/sooniter-lib-template-monorepo my-lib-name
- run ni
- go to the "test" folder
- run this one is Ok,
Expected behavior
work well
Maybe the problem is to run-once or run-watch.
Version 0.2.20
After downgrading the vitest to @0.15.2, it works well.
The last working version is vitest 0.16.1
โ the extension is broken fromvitest 0.17.0
.
Hi @SoonIter ,Please upgrade vitest
to the latest version.
Hi @SoonIter ,Please upgrade
vitest
to the latest version.
OK, it now works well with vitest v0.18.1
The latest vitest extension release, v0.2.20 (from 15 days ago), doesn't work with vitest v0.18.1 for me. Just get an infinite spinner.
Try the example project linked to above with this:
"devDependencies": {
"envinfo": "^7.8.1",
"vite": "^3.0.0",
"vitest": "^0.18.1"
}
Same issue as @beorn. I think this issue should be re-opened.
same!
Same issue as @beorn. I think this issue should be re-opened.
pnpm monorepo here with vitest 0.19.1
, the same problem.
Greetings. Same here.
I can run the tests and they pass from the terminal. However, running them from the extension gets the indicator spinning forever.
BTW, I also cloned your repo to test with your samples and the issue still exists.
macOS Big Sur 11.6.5
Version: 1.70.0-insider
"typescript": "^4.7.4",
"vite": "^3.0.4",
"vitest": "^0.20.2"
Please, help.
Same problem for me...
check the docs of Vitest vitest docs options Do not watch option --run
you can see more on this #31
@rokbot So it seems it doesn't hang anymore - it runs - but test results are not found. It helps troubleshooting the issue, but it's not a workaround as far as I can see?
I wish this can be fixed soon ~
The issue here is actually fixed and the "Test result not found" error comes from wrong configuration.
This extension depends on the watch function of vitest. We aren't supposed to run it with vitest run
because it messes with the API connection. Remove run
from your vitest.commandLine
and don't forget to include --
to the line if it calls an external script, otherwise the API wouldn't be started at all.
@Pustinyak I tried:
"vitest.commandLine": "npx vitest",
"vitest.commandLine": "npx vitest watch",
they all have the same issue.
@Pustinyak what version of vitest
you are using?
Hey @xieyuheng, I should've mentioned that my solution is better suited for monorepo. I see in your cicada-next
repo you have the latest version, so does it work for you now? I'm also using the latest one.
Any update on this? This extension seems broken for the latest 3 months of vitest releases (starting with v0.17.0), and there are quite a few duplicated issues/reports about it.
I haven't found a workaround... If you have any โ please share.
@beorn This seems to be fixed with some workaround/tool and [kudos to the development team ๐ ]. I will edit some of my posts to match the current state of this and help others troubleshoot this issue
I tried once the solution proposed by @Pustinyak but sadly doesn't work for me
The steps that worked for me and probably for you are these:
- First you will need a tool from the awesome @antfu ๐ if you don't have it yet
npm i -g @antfu/ni
- Then if you ran
npm init vue@latest
and add vitest in the prompts you will get in your package.json the scripttest:unit
so put that in your workspace settings for Vitest extension likenr test:unit
(see the image below) - Run the tests in vscode, (and doesn't matter what package manager you are using which is something very nice) you should get something like these:
I am also experiencing this issue. Using vitest 0.16.0
works fine, any version above that does not.
One important note is that on working versions (0.16.0
) there's a log message "WS Open", indicating the plugin is connecting to the vitest API (which I assume it needs for getting results).
On later versions, "WS Open" never happens, and instead "WS Close" gets spammed near endlessly.
Looking at the Release notes for 0.17.0
, the thing that stands out to me is "Vite HMR support". I'm not smart enough to figure anything more out than this, but my bet is that something changed in the vitest API in this PR that is now causing the plugin to be unable to connect.
Update: The cause of the problem is that vitest tends to bind the API on ::1
(ipv6) while the plugin tries to connect on 127.0.0.1
(ipv4).
I guess vitest and the plugin both resolve localhost
in a different way. That's weird and unfortunate.
We can force vitest to listen on the ipv4 address by passing --api.host 127.0.0.1
to it, and that does make everything work. Unfortunately we can't currently put that in the vitest.commandLine
, as the plugin sets --api [port]
which overwrites that.
However, if we would change the plugin code to use --api.port [port]
instead, then we would be able to do this. I will create a PR to do this.
I don't see any possible issues this could cause. All it does is create the option for people with this issue to add the host to the command line, working around the problem.
The true solution would be to resolve localhost
in the same way as vitest
or forcing vitest
to bind on whatever the plugin resolves to. However, this is a bit out of my comfort zone. It's probably better to come up with a solution that works (tho isn't perfect) than to ask an open-source maintainer to do work for me.
adding to @c00 reply, a temporary workaround is to prepend require("node:dns").setDefaultResultOrder("verbatim");
to ~/.vscode/extensions/zixuanchen.vitest-explorer-0.2.29/dist/extension.js
. I spent the whole day troubleshooting and re-witting most of the extension yesterday, I think it needs to be re-architectured to work a different way (to not manually look and parse specs and to just spawn vitest watch server, and trigger manual re-runs via WS instead).
Update: The cause of the problem is that vitest tends to bind the API on
::1
(ipv6) while the plugin tries to connect on127.0.0.1
(ipv4)I guess vitest and the plugin both resolve
localhost
in a different way. That's weird and unfortunate.We can force vitest to listen on the ipv4 address by passing
--api.host 127.0.0.1
to it, and that does make everything work. Unfortunately we can't currently put that in thevitest.commandLine
, as the plugin sets--api [port]
which overwrites that.However, if we would change the plugin code to use
--api.port [port]
instead, then we would be able to do this. I will create a PR to do this.I don't see any possible issues this could cause. All it does is create the option for people with this issue to add the host to the command line, working around the problem.
The true solution would be to resolve
localhost
in the same way asvitest
or forcingvitest
to bind on whatever the plugin resolves to. However, this is a bit out of my comfort zone. It's probably better to come up with a solution that works (tho isn't perfect) than to ask an open-source maintainer to do work for me.
I fixed a lot of this a few days ago. To be clear, this all broke with the release of Vite 3.0 (3.0.0-alpha.11, to be exact). It happened with this commit where they changed the default host from 127.0.0.1
to localhost
. But there was also a problem (in Windows, at least) where the "Debug Test" was failing because the test file path being passed to vitest was not being properly compared, so it would never pass their filter match. They're using a glob module, which makes use of process.cwd()
, and that (for some reason) was converting the drive name in the file path from C:/
to c:/
, which differs from the C:/
filter being passed from the vscode plugin. In vitest, they're doing a case-sensitive match with .includes()
, which obviously fails. Anyway, I modified my vscode plugin extension to use --api.port
and --api.host
, and I also made it use process.cwd()
to construct the test file path so that it would have the same capitalization that vitest produces with its glob matching module. This is just a workaround, though, not a "proper" fix. The vitest code is in some serious need of refactoring.
If anyone is interested, I can post the modified vscode extension file in a fork of this project. Alternatively, there is another option for people who don't want to modify their extension. Here's a little wrapper for vitest.mjs that I wrote that intercepts calls to vitest, "fixes" the arguments passed in, and passes them along to the real vitest.mjs.
// node_modules/vitest/vitest.mjs
import path from 'path';
import { spawnSync } from 'node:child_process';
const [ node, module, ...origArgs ] = process.argv;
const args = origArgs.map((arg, i) => {
if (arg === '--api') {
return '--api.port';
}
if (origArgs[i - 1] === '-t') {
return arg.replace(/[$^+?()[\]]/g, '\\$&');
}
if (/\.(?:js|mjs|cjs|ts|mts|cts|jsx|tsx)$/.test(arg)) {
const cwd = process.cwd();
return path.join(cwd, path.relative(cwd, arg));
}
return arg;
});
if (!args.includes('--api.host')) {
args.push('--api.host', '127.0.0.1');
}
spawnSync(node, [module.replace(/\.m?js$/, '.real$&'), ...args], { stdio: [0, 1, 2] });
To use it, you can simply install the latest vite and vitest, rename vitest.mjs
to vitest.real.mjs
, and create a new vitest.mjs
with the code above. If you want this to work for future projects, you can use pnpm link
or whatever to make all of this easier with symlinks. You don't have to bother modifying the vitest plugin's commandLine
option this way. The commandLine option isn't even used by the plugin's statusbar button. Instead, it scans your node_modules
directory in your project directory for vitest.
@falynx great, but I already try on window and it seem not work, did I do correct?
@hiepxanh Hmm, your file setup looks fine, but you seem to be receiving a few different errors that may not be related. So instead of starting with your particular setup, why don't we start from the vitest sample project as a baseline.
Here are the steps:
- If you've been messing around with the extension code, reinstall it to make sure it's clean with no modifications.
- Ensure you don't have any straggling vitest
commandLine
settings. Make sure all settings are clean/default. git clone https://github.com/zxch3n/vitest-ext-basic-example
cd vitest-ext-basic-example
pnpm update --latest
mv node_modules/vitest/vitest.mjs node_modules/vitest/vitest.real.mjs
code node_modules/vitest/vitest.mjs
- Copy/paste the code above into the file and save it. NOTE: I altered the code snippet since last night to fix a different bug, so be sure to copy it again.
- Close the vscode window
- Open the
vitest-ext-basic-example
folder with vscode - Confirm that a Vitest statusbar button is now shown
- Click the Vitest statusbar button and confirm that it activates. It should say "1/1 passed (100%, 0 skipped)". It should NOT say "Vitest running..." with a spinner forever.
- Open up
add.test.ts
- Click the Test inspector button on the left side of vscode and click the test buttons.
- Tweak the test to make it fail, pass, whatever. Everything should work as expected.
I see that you're using @vitest/ui
. That should be working fine, too. Steps:
pnpm add -D @vitest/ui
pnpm vitest --ui
- Confirm that it loads up
add.test.ts
in your browser. - Tweak the test. Confirm that the results are updated in realtime in the browser and in the terminal window.
All of that is working fine for me here on my Windows 11 system. If it's not working for you, then I'm not sure what to tell you. If it is, then that should be a good baseline for you to debug the issue with your larger project.
I just submitted a pull request to migrate this extension to Vite 3.0.
If you prefer to fix/modify your extension rather than using the vitest wrapper script above, follow these steps:
git clone https://github.com/falynx/vscode
yarn install
(might need topnpm add -g yarn
first)yarn vscode:prepublish
- Overwrite
%USERPROFILE%\.vscode\extensions\zixuanchen.vitest-explorer-0.2.29\dist\extension.js
withdist/extension.js
- Restart vscode (make sure you removed any
commandLine
settings, wrapper scripts, etc.)
Only tested on Windows 11.
For me it's working out of the box now.
- Is your
vitest.commandLine
set to anything? If so, try clearing it. - Does your
vite.config
set any api related settings? if so try removing those. - Is Vite version 3.1.x?
- Is vitest version 0.24.x?
If this doesn't help, what OS are you on?