| name | audit-lifecycle |
| description | Analyze shutdown, close, and GC-of-cache lifecycle correctness |
| context | fork |
| agent | auditor |
| disable-model-invocation | true |
Analyze the cache for defects during shutdown, close, and garbage collection
of the cache instance itself.
Assume at least one shutdown or lifecycle race exists. If your analysis yields
zero findings, re-examine scheduler/executor lifecycle and in-flight operations
during close — explain specifically why no race is possible.
-
Operations racing with close/cleanup: get/put/compute during cleanUp()
or GC? close() state transition? Operations after close()?
-
Scheduler lifecycle: Does the scheduled future prevent cache GC?
Can scheduler fire after cache is collected? Is the task cancelled on close?
-
Executor lifecycle: Reference cycle between cache and executor?
RejectedExecutionException handling when executor is shut down?
-
Removal listener drain on shutdown: Are pending notifications delivered
or dropped? Notifications lost if executor shuts down first?
-
In-flight operations during shutdown:
- CacheLoader.load() in progress when cache closes
- Refresh future's whenComplete callback after close
- CompletableFuture value pending when cache closes
-
Multiple close calls: Is close() idempotent? Concurrent close() corruption?
-
Finalizer / Cleaner interactions: Reference queues outliving the cache?
Reference queue processing accessing dead cache?
For each defect: state the lifecycle transition, provide a concrete scenario,
state the observable incorrect behavior.