@@ -163,6 +163,60 @@ describe("generateImageTool", () => {
163163 expect ( mockGenerateImage ) . toHaveBeenCalled ( )
164164 expect ( mockPushToolResult ) . toHaveBeenCalled ( )
165165 } )
166+
167+ it ( "should add cache-busting parameter to image URI" , async ( ) => {
168+ const completeBlock : ToolUse = {
169+ type : "tool_use" ,
170+ name : "generate_image" ,
171+ params : {
172+ prompt : "Generate a test image" ,
173+ path : "test-image.png" ,
174+ } ,
175+ partial : false ,
176+ }
177+
178+ // Mock convertToWebviewUri to return a test URI
179+ const mockWebviewUri = "https://file+.vscode-resource.vscode-cdn.net/test/workspace/test-image.png"
180+ mockCline . providerRef . deref ( ) . convertToWebviewUri = vi . fn ( ) . mockReturnValue ( mockWebviewUri )
181+
182+ // Mock the OpenRouterHandler generateImage method
183+ const mockGenerateImage = vi . fn ( ) . mockResolvedValue ( {
184+ success : true ,
185+ imageData : "" ,
186+ } )
187+
188+ vi . mocked ( OpenRouterHandler ) . mockImplementation (
189+ ( ) =>
190+ ( {
191+ generateImage : mockGenerateImage ,
192+ } ) as any ,
193+ )
194+
195+ await generateImageTool (
196+ mockCline as Task ,
197+ completeBlock ,
198+ mockAskApproval ,
199+ mockHandleError ,
200+ mockPushToolResult ,
201+ mockRemoveClosingTag ,
202+ )
203+
204+ // Check that cline.say was called with image data containing cache-busting parameter
205+ expect ( mockCline . say ) . toHaveBeenCalledWith ( "image" , expect . stringMatching ( / " i m a g e U r i " : " [ ^ " ] + \? t = \d + " / ) )
206+
207+ // Verify the imageUri contains the cache-busting parameter
208+ const sayCall = mockCline . say . mock . calls . find ( ( call : any [ ] ) => call [ 0 ] === "image" )
209+ if ( sayCall ) {
210+ const imageData = JSON . parse ( sayCall [ 1 ] )
211+ expect ( imageData . imageUri ) . toMatch ( / \? t = \d + $ / )
212+ // Handle both Unix and Windows path separators
213+ const expectedPath =
214+ process . platform === "win32"
215+ ? "\\test\\workspace\\test-image.png"
216+ : "/test/workspace/test-image.png"
217+ expect ( imageData . imagePath ) . toBe ( expectedPath )
218+ }
219+ } )
166220 } )
167221
168222 describe ( "missing parameters" , ( ) => {
0 commit comments