CVE-2025-24964
Remote Code Execution when accessing a malicious website while Vitest API server is listening
In short
Vitest's API server is vulnerable to attacks from malicious websites when enabled, allowing hackers to execute arbitrary code on your computer by modifying test files and running them without your knowledge.
Technical detail
Vitest API server lacks Origin header validation and authorization mechanisms on its WebSocket endpoint, making it susceptible to Cross-site WebSocket hijacking (CSWSH). Attackers can exploit saveTestFile and rerun APIs to inject and execute arbitrary code in the test environment when a user visits a compromised website while the API server is active.
Summary generated and translated by AI from the official description.
Vitest is a testing framework powered by Vite. Affected versions are subject to arbitrary remote Code Execution when accessing a malicious website while Vitest API server is listening by Cross-site WebSocket hijacking (CSWSH) attacks. When `api` option is enabled (Vitest UI enables it), Vitest starts a WebSocket server. This WebSocket server did not check Origin header and did not have any authorization mechanism and was vulnerable to CSWSH attacks. This WebSocket server has `saveTestFile` API that can edit a test file and `rerun` API that can rerun the tests. An attacker can execute arbitrary code by injecting a code in a test file by the `saveTestFile` API and then running that file by calling the `rerun` API. This vulnerability can result in remote code execution for users that are using Vitest serve API. This issue has been patched in versions 1.6.1, 2.1.9 and 3.0.5. Users are advised to upgrade. There are no known workarounds for this vulnerability.
CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:H
Affected products
vitest-dev · vitestWant to know if your infrastructure is exposed to this?
Talk to TrueHacking →References
https://github.com/vitest-dev/vitest/blob/9a581e1c43e5c02b11e2a8026a55ce6a8cb35114/packages/vitest/src/api/setup.ts#L32-L46https://github.com/vitest-dev/vitest/blob/9a581e1c43e5c02b11e2a8026a55ce6a8cb35114/packages/vitest/src/api/setup.ts#L66-L76https://github.com/vitest-dev/vitest/security/advisories/GHSA-9crc-q9x8-hgqqhttps://vitest.dev/config/#api