fixes
							parent
							
								
									412f3d5d04
								
							
						
					
					
						commit
						51e06fcca1
					
				|  | @ -3404,6 +3404,38 @@ KubernetesJobSpecFactory.MainContainerName = 'main'; | |||
| exports["default"] = KubernetesJobSpecFactory; | ||||
| 
 | ||||
| 
 | ||||
| /***/ }), | ||||
| 
 | ||||
| /***/ 90740: | ||||
| /***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| var __importDefault = (this && this.__importDefault) || function (mod) { | ||||
|     return (mod && mod.__esModule) ? mod : { "default": mod }; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", ({ value: true })); | ||||
| const cloud_runner_logger_1 = __importDefault(__nccwpck_require__(22855)); | ||||
| class KubernetesPods { | ||||
|     static async IsPodRunning(podName, namespace, kubeClient) { | ||||
|         const pods = (await kubeClient.listNamespacedPod(namespace)).body.items.filter((x) => podName === x.metadata?.name); | ||||
|         const running = pods.length > 0 && (pods[0].status?.phase === `Running` || pods[0].status?.phase === `Pending`); | ||||
|         const phase = pods[0]?.status?.phase || 'undefined status'; | ||||
|         cloud_runner_logger_1.default.log(`Getting pod status: ${phase}`); | ||||
|         if (phase === `Failed`) { | ||||
|             throw new Error(`K8s pod failed`); | ||||
|         } | ||||
|         return running; | ||||
|     } | ||||
|     static async GetPodStatus(podName, namespace, kubeClient) { | ||||
|         const pods = (await kubeClient.listNamespacedPod(namespace)).body.items.find((x) => podName === x.metadata?.name); | ||||
|         const phase = pods?.status?.phase || 'undefined status'; | ||||
|         return phase; | ||||
|     } | ||||
| } | ||||
| exports["default"] = KubernetesPods; | ||||
| 
 | ||||
| 
 | ||||
| /***/ }), | ||||
| 
 | ||||
| /***/ 95875: | ||||
|  | @ -3635,58 +3667,42 @@ exports["default"] = KubernetesStorage; | |||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||
|     if (k2 === undefined) k2 = k; | ||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); | ||||
| }) : (function(o, m, k, k2) { | ||||
|     if (k2 === undefined) k2 = k; | ||||
|     o[k2] = m[k]; | ||||
| })); | ||||
| var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { | ||||
|     Object.defineProperty(o, "default", { enumerable: true, value: v }); | ||||
| }) : function(o, v) { | ||||
|     o["default"] = v; | ||||
| }); | ||||
| var __importStar = (this && this.__importStar) || function (mod) { | ||||
|     if (mod && mod.__esModule) return mod; | ||||
|     var result = {}; | ||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||
|     __setModuleDefault(result, mod); | ||||
|     return result; | ||||
| }; | ||||
| var __importDefault = (this && this.__importDefault) || function (mod) { | ||||
|     return (mod && mod.__esModule) ? mod : { "default": mod }; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", ({ value: true })); | ||||
| const cloud_runner_logger_1 = __importDefault(__nccwpck_require__(22855)); | ||||
| const core = __importStar(__nccwpck_require__(42186)); | ||||
| const async_wait_until_1 = __importDefault(__nccwpck_require__(41299)); | ||||
| const follow_log_stream_service_1 = __nccwpck_require__(64121); | ||||
| const cloud_runner_system_1 = __nccwpck_require__(99393); | ||||
| const cloud_runner_1 = __importDefault(__nccwpck_require__(79144)); | ||||
| const kubernetes_pods_1 = __importDefault(__nccwpck_require__(90740)); | ||||
| class KubernetesTaskRunner { | ||||
|     static async runTask(kubeConfig, kubeClient, jobName, podName, containerName, namespace) { | ||||
|         let output = ''; | ||||
|         let shouldReadLogs = true; | ||||
|         let shouldCleanup = true; | ||||
|         let sinceTime = ``; | ||||
|         // eslint-disable-next-line no-constant-condition
 | ||||
|         while (true) { | ||||
|             const lastReceivedMessage = KubernetesTaskRunner.lastReceivedTimestamp > 0 | ||||
|                 ? `\nLast Log Message "${this.lastReceivedMessage}" ${this.lastReceivedTimestamp}` | ||||
|                 : ``; | ||||
|             cloud_runner_logger_1.default.log(`Streaming logs from pod: ${podName} container: ${containerName} namespace: ${namespace} ${cloud_runner_1.default.buildParameters.kubeVolumeSize}/${cloud_runner_1.default.buildParameters.containerCpu}/${cloud_runner_1.default.buildParameters.containerMemory}\n${lastReceivedMessage}`); | ||||
|         let output = ''; | ||||
|         let didStreamAnyLogs = false; | ||||
|         let shouldReadLogs = true; | ||||
|         let shouldCleanup = true; | ||||
|         // eslint-disable-next-line no-constant-condition
 | ||||
|         while (true) { | ||||
|             let sinceTime = ``; | ||||
|             if (KubernetesTaskRunner.lastReceivedTimestamp > 0) { | ||||
|                 const currentDate = new Date(KubernetesTaskRunner.lastReceivedTimestamp); | ||||
|                 const dateTimeIsoString = currentDate.toISOString(); | ||||
|                 sinceTime = ` --since-time="${dateTimeIsoString}"`; | ||||
|             } | ||||
|             let extraFlags = ``; | ||||
|             if (!(await kubernetes_pods_1.default.IsPodRunning(podName, namespace, kubeClient))) { | ||||
|                 extraFlags += ` -p`; | ||||
|             } | ||||
|             let lastMessageSeenIncludedInChunk = false; | ||||
|             let lastMessageSeen = false; | ||||
|             let logs; | ||||
|             try { | ||||
|                 logs = await cloud_runner_system_1.CloudRunnerSystem.Run(`kubectl logs ${podName} -f -c ${containerName} --timestamps${sinceTime}`, false, true); | ||||
|                 logs = await cloud_runner_system_1.CloudRunnerSystem.Run(`kubectl logs ${podName} -f -c${extraFlags} ${containerName} --timestamps${sinceTime}`, false, true); | ||||
|             } | ||||
|             catch (error) { | ||||
|                 cloud_runner_logger_1.default.log(`K8s logging error ${error}`); | ||||
|  | @ -3708,29 +3724,11 @@ class KubernetesTaskRunner { | |||
|                 if (lastMessageSeenIncludedInChunk && !lastMessageSeen) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 didStreamAnyLogs = true; | ||||
|                 const message = cloud_runner_1.default.buildParameters.cloudRunnerDebug ? chunk : chunk.split(`Z `)[1]; | ||||
|                 KubernetesTaskRunner.lastReceivedMessage = chunk; | ||||
|                 KubernetesTaskRunner.lastReceivedTimestamp = newDate; | ||||
|                 ({ shouldReadLogs, shouldCleanup, output } = follow_log_stream_service_1.FollowLogStreamService.handleIteration(message, shouldReadLogs, shouldCleanup, output)); | ||||
|             } | ||||
|             if (!didStreamAnyLogs) { | ||||
|                 core.error('Failed to stream any logs, listing namespace events, check for an error with the container'); | ||||
|                 core.error(JSON.stringify({ | ||||
|                     events: (await kubeClient.listNamespacedEvent(namespace)).body.items | ||||
|                         .filter((x) => { | ||||
|                         return x.involvedObject.name === podName || x.involvedObject.name === jobName; | ||||
|                     }) | ||||
|                         .map((x) => { | ||||
|                         return { | ||||
|                             type: x.involvedObject.kind, | ||||
|                             name: x.involvedObject.name, | ||||
|                             message: x.message, | ||||
|                         }; | ||||
|                     }), | ||||
|                 }, undefined, 4)); | ||||
|                 throw new Error(`No logs streamed from k8s`); | ||||
|             } | ||||
|             if (follow_log_stream_service_1.FollowLogStreamService.DidReceiveEndOfTransmission) { | ||||
|                 cloud_runner_logger_1.default.log('end of log stream'); | ||||
|                 break; | ||||
|  | @ -5112,12 +5110,6 @@ class FollowLogStreamService { | |||
|         else if (message.toLowerCase().includes('cannot be found')) { | ||||
|             FollowLogStreamService.errors += `\n${message}`; | ||||
|         } | ||||
|         else if (cloud_runner_1.default.buildParameters.cloudRunnerDebug && message.includes(': Listening for Jobs')) { | ||||
|             core.setOutput('cloud runner stop watching', 'true'); | ||||
|             shouldReadLogs = false; | ||||
|             shouldCleanup = false; | ||||
|             core.warning('cloud runner stop watching'); | ||||
|         } | ||||
|         if (cloud_runner_1.default.buildParameters.cloudRunnerDebug) { | ||||
|             output += `${message}\n`; | ||||
|         } | ||||
|  |  | |||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -1,10 +1,10 @@ | |||
| import { CoreV1Api, KubeConfig } from '@kubernetes/client-node'; | ||||
| import CloudRunnerLogger from '../../services/cloud-runner-logger'; | ||||
| import * as core from '@actions/core'; | ||||
| import waitUntil from 'async-wait-until'; | ||||
| import { FollowLogStreamService } from '../../services/follow-log-stream-service'; | ||||
| import { CloudRunnerSystem } from '../../services/cloud-runner-system'; | ||||
| import CloudRunner from '../../cloud-runner'; | ||||
| import KubernetesPods from './kubernetes-pods'; | ||||
| 
 | ||||
| class KubernetesTaskRunner { | ||||
|   static lastReceivedTimestamp: number = 0; | ||||
|  | @ -17,6 +17,12 @@ class KubernetesTaskRunner { | |||
|     containerName: string, | ||||
|     namespace: string, | ||||
|   ) { | ||||
|     let output = ''; | ||||
|     let shouldReadLogs = true; | ||||
|     let shouldCleanup = true; | ||||
|     let sinceTime = ``; | ||||
|     // eslint-disable-next-line no-constant-condition
 | ||||
|     while (true) { | ||||
|       const lastReceivedMessage = | ||||
|         KubernetesTaskRunner.lastReceivedTimestamp > 0 | ||||
|           ? `\nLast Log Message "${this.lastReceivedMessage}" ${this.lastReceivedTimestamp}` | ||||
|  | @ -24,19 +30,15 @@ class KubernetesTaskRunner { | |||
|       CloudRunnerLogger.log( | ||||
|         `Streaming logs from pod: ${podName} container: ${containerName} namespace: ${namespace} ${CloudRunner.buildParameters.kubeVolumeSize}/${CloudRunner.buildParameters.containerCpu}/${CloudRunner.buildParameters.containerMemory}\n${lastReceivedMessage}`, | ||||
|       ); | ||||
|     let output = ''; | ||||
|     let didStreamAnyLogs: boolean = false; | ||||
|     let shouldReadLogs = true; | ||||
|     let shouldCleanup = true; | ||||
| 
 | ||||
|     // eslint-disable-next-line no-constant-condition
 | ||||
|     while (true) { | ||||
|       let sinceTime = ``; | ||||
|       if (KubernetesTaskRunner.lastReceivedTimestamp > 0) { | ||||
|         const currentDate = new Date(KubernetesTaskRunner.lastReceivedTimestamp); | ||||
|         const dateTimeIsoString = currentDate.toISOString(); | ||||
|         sinceTime = ` --since-time="${dateTimeIsoString}"`; | ||||
|       } | ||||
|       let extraFlags = ``; | ||||
|       if (!(await KubernetesPods.IsPodRunning(podName, namespace, kubeClient))) { | ||||
|         extraFlags += ` -p`; | ||||
|       } | ||||
|       let lastMessageSeenIncludedInChunk = false; | ||||
|       let lastMessageSeen = false; | ||||
| 
 | ||||
|  | @ -44,7 +46,7 @@ class KubernetesTaskRunner { | |||
| 
 | ||||
|       try { | ||||
|         logs = await CloudRunnerSystem.Run( | ||||
|           `kubectl logs ${podName} -f -c ${containerName} --timestamps${sinceTime}`, | ||||
|           `kubectl logs ${podName} -f -c${extraFlags} ${containerName} --timestamps${sinceTime}`, | ||||
|           false, | ||||
|           true, | ||||
|         ); | ||||
|  | @ -70,7 +72,6 @@ class KubernetesTaskRunner { | |||
|         if (lastMessageSeenIncludedInChunk && !lastMessageSeen) { | ||||
|           continue; | ||||
|         } | ||||
|         didStreamAnyLogs = true; | ||||
|         const message = CloudRunner.buildParameters.cloudRunnerDebug ? chunk : chunk.split(`Z `)[1]; | ||||
|         KubernetesTaskRunner.lastReceivedMessage = chunk; | ||||
|         KubernetesTaskRunner.lastReceivedTimestamp = newDate; | ||||
|  | @ -81,30 +82,6 @@ class KubernetesTaskRunner { | |||
|           output, | ||||
|         )); | ||||
|       } | ||||
| 
 | ||||
|       if (!didStreamAnyLogs) { | ||||
|         core.error('Failed to stream any logs, listing namespace events, check for an error with the container'); | ||||
|         core.error( | ||||
|           JSON.stringify( | ||||
|             { | ||||
|               events: (await kubeClient.listNamespacedEvent(namespace)).body.items | ||||
|                 .filter((x) => { | ||||
|                   return x.involvedObject.name === podName || x.involvedObject.name === jobName; | ||||
|                 }) | ||||
|                 .map((x) => { | ||||
|                   return { | ||||
|                     type: x.involvedObject.kind, | ||||
|                     name: x.involvedObject.name, | ||||
|                     message: x.message, | ||||
|                   }; | ||||
|                 }), | ||||
|             }, | ||||
|             undefined, | ||||
|             4, | ||||
|           ), | ||||
|         ); | ||||
|         throw new Error(`No logs streamed from k8s`); | ||||
|       } | ||||
|       if (FollowLogStreamService.DidReceiveEndOfTransmission) { | ||||
|         CloudRunnerLogger.log('end of log stream'); | ||||
|         break; | ||||
|  |  | |||
|  | @ -46,11 +46,6 @@ export class FollowLogStreamService { | |||
|       FollowLogStreamService.errors += `\n${message}`; | ||||
|     } else if (message.toLowerCase().includes('cannot be found')) { | ||||
|       FollowLogStreamService.errors += `\n${message}`; | ||||
|     } else if (CloudRunner.buildParameters.cloudRunnerDebug && message.includes(': Listening for Jobs')) { | ||||
|       core.setOutput('cloud runner stop watching', 'true'); | ||||
|       shouldReadLogs = false; | ||||
|       shouldCleanup = false; | ||||
|       core.warning('cloud runner stop watching'); | ||||
|     } | ||||
|     if (CloudRunner.buildParameters.cloudRunnerDebug) { | ||||
|       output += `${message}\n`; | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue