Skip to content

Commit

Permalink
#1888: adding stubbing for keep-alive
Browse files Browse the repository at this point in the history
  • Loading branch information
laddi-netapp committed Nov 28, 2022
1 parent 5f71b61 commit c71a748
Show file tree
Hide file tree
Showing 3 changed files with 70 additions and 7 deletions.
14 changes: 13 additions & 1 deletion src/vnodeTransformers/stubComponentsTransformer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import {
TransitionGroup,
BaseTransition,
Teleport,
KeepAlive,
h,
defineComponent,
VNodeTypes,
Expand Down Expand Up @@ -31,7 +32,7 @@ export type CustomCreateStub = (params: {

interface StubOptions {
name: string
type?: VNodeTypes | typeof Teleport
type?: VNodeTypes | typeof Teleport | typeof KeepAlive
renderStubDefaultSlot?: boolean
}

Expand Down Expand Up @@ -124,6 +125,17 @@ export function createStubComponentsTransformer({
})
}

// stub keep-alive by default via config.global.stubs
if ((type as any) === KeepAlive && 'keep-alive' in stubs) {
if (stubs['keep-alive'] === false) return type

return createStub({
name: 'keep-alive',
type,
renderStubDefaultSlot: true
})
}

// stub transition by default via config.global.stubs
if (
(type === Transition || (type as any) === BaseTransition) &&
Expand Down
13 changes: 7 additions & 6 deletions src/vnodeTransformers/util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ export type VTUVNodeTypeTransformer = (
) => VNodeTransformerInputComponentType

const isTeleport = (type: any): boolean => type.__isTeleport
const isKeepAlive = (type: any): boolean => type.__isKeepAlive

export const createVNodeTransformer = ({
transformers
Expand All @@ -41,9 +42,9 @@ export const createVNodeTransformer = ({

const cachedTransformation = transformationCache.get(originalType)
if (cachedTransformation) {
// https://github.com/vuejs/test-utils/issues/1829
// Teleport should return child nodes as a function
if (isTeleport(originalType)) {
// https://github.com/vuejs/test-utils/issues/1829 & https://github.com/vuejs/test-utils/issues/1888
// Teleport/KeepAlive should return child nodes as a function
if (isTeleport(originalType) || isKeepAlive(originalType)) {
return [cachedTransformation, props, () => children, ...restVNodeArgs]
}
return [cachedTransformation, props, children, ...restVNodeArgs]
Expand All @@ -60,9 +61,9 @@ export const createVNodeTransformer = ({
transformationCache.set(originalType, transformedType)

registerStub({ source: originalType, stub: transformedType })
// https://github.com/vuejs/test-utils/issues/1829
// Teleport should return child nodes as a function
if (isTeleport(originalType)) {
// https://github.com/vuejs/test-utils/issues/1829 & https://github.com/vuejs/test-utils/issues/1888
// Teleport/KeepAlive should return child nodes as a function
if (isTeleport(originalType) || isKeepAlive(originalType)) {
return [transformedType, props, () => children, ...restVNodeArgs]
}
}
Expand Down
50 changes: 50 additions & 0 deletions tests/mountingOptions/global.stubs.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -553,6 +553,56 @@ describe('mounting options: stubs', () => {
})
})

describe('keep-alive', () => {
it('will omit the keep-alive tag by default', () => {
const Comp = {
template: `<keep-alive><div id="content" /></keep-alive>`
}
const wrapper = mount(Comp)

expect(wrapper.html()).toBe('<div id="content"></div>')
})

it('opts in to stubbing keep-alive ', () => {
const spy = vi.spyOn(console, 'warn')
const Comp = {
template: `<keep-alive><div id="content" /></keep-alive>`
}
const wrapper = mount(Comp, {
global: {
stubs: {
'keep-alive': true
}
}
})

expect(wrapper.html()).toBe(
'<keep-alive-stub>\n' +
' <div id="content"></div>\n' +
'</keep-alive-stub>'
)
// Make sure that we don't have a warning when stubbing keep-alive
// https://github.com/vuejs/test-utils/issues/1888
expect(spy).not.toHaveBeenCalled()
})

it('does not stub keep-alive with shallow', () => {
const Comp = {
template: `<keep-alive><div id="content" /></keep-alive>`
}
const wrapper = mount(Comp, {
shallow: true,
global: {
stubs: {
'keep-alive': false
}
}
})

expect(wrapper.html()).toBe('<div id="content"></div>')
})
})

it('stubs component by key prior before name', () => {
const MyComponent = defineComponent({
name: 'MyComponent',
Expand Down

0 comments on commit c71a748

Please sign in to comment.