| 
									
										
										
										
											2025-01-23 13:24:04 +00:00
										 |  |  | import { expect, jest, test, } from '@jest/globals'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { login } from '../src/docker'; | 
					
						
							|  |  |  | import { Docker } from '@docker/actions-toolkit/lib/docker/docker'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | test('login retries success function', async () => { | 
					
						
							| 
									
										
										
										
											2025-01-23 14:44:53 +00:00
										 |  |  |   let stderr_strings: string[] = [] | 
					
						
							| 
									
										
										
										
											2025-01-23 13:24:04 +00:00
										 |  |  |   let call_count: number = -1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Docker.getExecOutput = jest.fn(async () => { | 
					
						
							|  |  |  |     call_count++ | 
					
						
							|  |  |  |     console.log(`Mock: ${call_count}, ${stderr_strings}`) | 
					
						
							|  |  |  |     if (call_count >= stderr_strings.length) { | 
					
						
							|  |  |  |       return { | 
					
						
							|  |  |  |         exitCode: 0, | 
					
						
							|  |  |  |         stdout: 'Mock success', | 
					
						
							|  |  |  |         stderr: '' | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       exitCode: 1, | 
					
						
							|  |  |  |       stdout: '', | 
					
						
							|  |  |  |       stderr: stderr_strings[(call_count) % stderr_strings.length] | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const username = 'dbowie'; | 
					
						
							|  |  |  |   const password = 'groundcontrol'; | 
					
						
							|  |  |  |   const registry = 'https://ghcr.io'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-23 14:44:53 +00:00
										 |  |  |   stderr_strings = [] | 
					
						
							| 
									
										
										
										
											2025-01-23 13:24:04 +00:00
										 |  |  |   call_count = -1 | 
					
						
							| 
									
										
										
										
											2025-01-23 14:44:53 +00:00
										 |  |  |   await login(registry, username, password, 'false', ['408', '502', '400'], 5, 0.1); | 
					
						
							| 
									
										
										
										
											2025-01-23 13:24:04 +00:00
										 |  |  |   expect(Docker.getExecOutput).toHaveBeenCalledTimes(1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   stderr_strings = [ | 
					
						
							|  |  |  |     'mock error, failed with status: 408 Request Timeout', | 
					
						
							|  |  |  |     'mock error, failed with status: 502 Request Timeout', | 
					
						
							|  |  |  |     'mock error, failed with status: 400 Request Timeout', | 
					
						
							|  |  |  |   ] | 
					
						
							|  |  |  |   call_count = -1 | 
					
						
							| 
									
										
										
										
											2025-01-23 14:44:53 +00:00
										 |  |  |   await login(registry, username, password, 'false', ['408', '502', '400'], 5, 0.1); | 
					
						
							|  |  |  |   expect(Docker.getExecOutput).toHaveBeenCalledTimes(1 + 4); | 
					
						
							| 
									
										
										
										
											2025-01-23 13:24:04 +00:00
										 |  |  | }); |