import ts from 'typescript'
import { parseJsx } from '../__tests__/utils'
import { printAst } from '../utils'
import { transformSpinnerIconToLoadingSpinner } from './transformSpinnerIconToLoadingSpinner'
export const mockedTransformer =
(alias?: string) =>
(context: ts.TransformationContext) =>
(rootNode: ts.Node): ts.Node => {
const visit = (node: ts.Node): ts.Node => {
if (ts.isJsxOpeningElement(node) || ts.isJsxSelfClosingElement(node)) {
return transformSpinnerIconToLoadingSpinner(node, alias)
}
return ts.visitEachChild(node, visit, context)
}
return ts.visitNode(rootNode, visit)
}
const transformInput = (sourceFile: ts.SourceFile, alias?: string): string => {
const result = ts.transform(sourceFile, [mockedTransformer(alias)])
const transformedSource = result.transformed[0] as ts.SourceFile
return printAst(transformedSource)
}
describe('transformSpinnerIconToLoadingSpinner()', () => {
it('replaces SpinnerIcon with LoadingSpinner and adds size and accessibilityLabel', () => {
const inputAst = parseJsx('')
const outputAst = parseJsx('')
expect(transformInput(inputAst)).toEqual(printAst(outputAst))
})
it('uses alias if it is defined', () => {
const inputAst = parseJsx('')
const outputAst = parseJsx('')
expect(transformInput(inputAst, 'KzLoadingSpinner')).toEqual(printAst(outputAst))
})
describe('transform existing props', () => {
it('removes role and changes aria-label to accessibilityLabel or fallback', () => {
const inputAst = parseJsx(`
export const TestComponent = () => (
<>
>
)
`)
const outputAst = parseJsx(`
export const TestComponent = () => (
<>
>
)
`)
expect(transformInput(inputAst)).toEqual(printAst(outputAst))
})
it('leaves classNameOverride as is', () => {
const inputAst = parseJsx('')
const outputAst = parseJsx(
'',
)
expect(transformInput(inputAst)).toEqual(printAst(outputAst))
})
it('removes viewBox', () => {
const inputAst = parseJsx('')
const outputAst = parseJsx('')
expect(transformInput(inputAst)).toEqual(printAst(outputAst))
})
})
})