| 
									
										
										
										
											2023-10-24 09:35:07 -07:00
										 |  |  | /* | 
					
						
							|  |  |  |   Copyright (c) Microsoft Corporation. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Licensed under the Apache License, Version 2.0 (the "License"); | 
					
						
							|  |  |  |   you may not use this file except in compliance with the License. | 
					
						
							|  |  |  |   You may obtain a copy of the License at | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  |   distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  |   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  |   See the License for the specific language governing permissions and | 
					
						
							|  |  |  |   limitations under the License. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-31 21:42:06 -07:00
										 |  |  | import { ansi2html } from '@web/ansi2html'; | 
					
						
							| 
									
										
										
										
											2023-10-24 09:35:07 -07:00
										 |  |  | import * as React from 'react'; | 
					
						
							|  |  |  | import './testErrorView.css'; | 
					
						
							| 
									
										
										
										
											2024-10-10 16:49:17 -07:00
										 |  |  | import type { ImageDiff } from '@web/shared/imageDiffView'; | 
					
						
							|  |  |  | import { ImageDiffView } from '@web/shared/imageDiffView'; | 
					
						
							| 
									
										
										
										
											2023-10-24 09:35:07 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | export const TestErrorView: React.FC<{ | 
					
						
							|  |  |  |   error: string; | 
					
						
							| 
									
										
										
										
											2024-10-17 08:33:15 -07:00
										 |  |  |   testId?: string; | 
					
						
							|  |  |  | }> = ({ error, testId }) => { | 
					
						
							| 
									
										
										
										
											2024-10-10 16:49:17 -07:00
										 |  |  |   const html = React.useMemo(() => ansiErrorToHtml(error), [error]); | 
					
						
							| 
									
										
										
										
											2024-11-15 22:25:26 +01:00
										 |  |  |   return <div className='test-error-view test-error-text' data-testid={testId} dangerouslySetInnerHTML={{ __html: html || '' }}></div>; | 
					
						
							| 
									
										
										
										
											2023-10-24 09:35:07 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-10 16:49:17 -07:00
										 |  |  | export const TestScreenshotErrorView: React.FC<{ | 
					
						
							|  |  |  |   errorPrefix?: string, | 
					
						
							|  |  |  |   diff: ImageDiff, | 
					
						
							|  |  |  |   errorSuffix?: string, | 
					
						
							|  |  |  | }> = ({ errorPrefix, diff, errorSuffix }) => { | 
					
						
							|  |  |  |   const prefixHtml = React.useMemo(() => ansiErrorToHtml(errorPrefix), [errorPrefix]); | 
					
						
							|  |  |  |   const suffixHtml = React.useMemo(() => ansiErrorToHtml(errorSuffix), [errorSuffix]); | 
					
						
							|  |  |  |   return <div data-testid='test-screenshot-error-view' className='test-error-view'> | 
					
						
							|  |  |  |     <div dangerouslySetInnerHTML={{ __html: prefixHtml || '' }} className='test-error-text' style={{ marginBottom: 20 }}></div> | 
					
						
							|  |  |  |     <ImageDiffView key='image-diff' diff={diff} hideDetails={true}></ImageDiffView> | 
					
						
							|  |  |  |     <div data-testid='error-suffix' dangerouslySetInnerHTML={{ __html: suffixHtml || '' }} className='test-error-text'></div> | 
					
						
							|  |  |  |   </div>; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function ansiErrorToHtml(text?: string): string { | 
					
						
							| 
									
										
										
										
											2024-10-31 21:42:06 -07:00
										 |  |  |   const defaultColors = { | 
					
						
							| 
									
										
										
										
											2024-10-10 16:49:17 -07:00
										 |  |  |     bg: 'var(--color-canvas-subtle)', | 
					
						
							|  |  |  |     fg: 'var(--color-fg-default)', | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2024-10-31 21:42:06 -07:00
										 |  |  |   return ansi2html(text || '', defaultColors); | 
					
						
							| 
									
										
										
										
											2023-10-24 09:35:07 -07:00
										 |  |  | } |