Problem
disableCache() currently has an imprecise contract in practice. Tool integrations can call it while configuring a server because the configuration may later lead to an uncacheable operation. That is too early.
The observed failure mode is Vite/Vitest: a task can create a Vite server for transforms or test execution without actually listening on a port or watching the filesystem. If disableCache() fires during server/config setup, cacheable tasks such as vitest run are reported as Not cached: the task opted out of caching even though no uncacheable operation happened.
Principle
disableCache() should be called immediately before the concrete operation that makes the task uncacheable, not when reading configuration that might eventually lead to such an operation.
Concrete examples:
- Listening on a port should disable caching immediately before the listen/bind operation.
- Observing the filesystem should disable caching immediately before the watcher starts observing paths.
- Creating/configuring an object that might later listen or watch should not disable caching by itself.
Temporary workaround
PR #481 makes vite_task_client::Client::disable_cache() a no-op so false opt-outs stop affecting downstream task caching while the real fix is designed and shipped.
Real solution
Move the Vite/Vitest integration points to operation boundaries:
- In Vite, call
disableCache() from the HTTP server start/listen path immediately before binding a port.
- In Vite, call
disableCache() from the watcher start path immediately before filesystem observation begins.
- Do not call
disableCache() from generic server creation/config resolution paths.
- Verify Vitest
run without watch/API does not listen or watch and therefore remains cacheable.
- Verify Vitest API/server mode and watch mode still opt out because they perform uncacheable operations.
After those semantics are implemented and covered, revert the vite-task client no-op workaround and restore disableCache() as an effective client request.
Problem
disableCache()currently has an imprecise contract in practice. Tool integrations can call it while configuring a server because the configuration may later lead to an uncacheable operation. That is too early.The observed failure mode is Vite/Vitest: a task can create a Vite server for transforms or test execution without actually listening on a port or watching the filesystem. If
disableCache()fires during server/config setup, cacheable tasks such asvitest runare reported asNot cached: the task opted out of cachingeven though no uncacheable operation happened.Principle
disableCache()should be called immediately before the concrete operation that makes the task uncacheable, not when reading configuration that might eventually lead to such an operation.Concrete examples:
Temporary workaround
PR #481 makes
vite_task_client::Client::disable_cache()a no-op so false opt-outs stop affecting downstream task caching while the real fix is designed and shipped.Real solution
Move the Vite/Vitest integration points to operation boundaries:
disableCache()from the HTTP server start/listen path immediately before binding a port.disableCache()from the watcher start path immediately before filesystem observation begins.disableCache()from generic server creation/config resolution paths.runwithout watch/API does not listen or watch and therefore remains cacheable.After those semantics are implemented and covered, revert the vite-task client no-op workaround and restore
disableCache()as an effective client request.