975fb1f466
Fixes differences in tests to handle windows now that we've fixed them not being run. x-ref: https://github.com/vercel/next.js/pull/53408/checks?check_run_id=15501915673
56 lines
1.7 KiB
TypeScript
56 lines
1.7 KiB
TypeScript
/* eslint-env jest */
|
|
import fs from 'fs-extra'
|
|
import { recursiveDelete } from 'next/dist/lib/recursive-delete'
|
|
import { recursiveReadDir } from 'next/dist/lib/recursive-readdir'
|
|
import { recursiveCopy } from 'next/dist/lib/recursive-copy'
|
|
import { join } from 'path'
|
|
|
|
const resolveDataDir = join(__dirname, 'isolated', '_resolvedata')
|
|
const testResolveDataDir = join(__dirname, 'isolated', 'test_resolvedata')
|
|
const testpreservefileDir = join(__dirname, 'isolated', 'preservefiles')
|
|
|
|
describe('recursiveDelete', () => {
|
|
if (process.platform === 'win32') {
|
|
it('should skip on windows to avoid symlink issues', () => {})
|
|
return
|
|
}
|
|
|
|
it('should work', async () => {
|
|
expect.assertions(1)
|
|
try {
|
|
await recursiveCopy(resolveDataDir, testResolveDataDir)
|
|
await fs.symlink('./aa', join(testResolveDataDir, 'symlink'))
|
|
await recursiveDelete(testResolveDataDir)
|
|
const result = await recursiveReadDir(testResolveDataDir, (f) =>
|
|
/.*/.test(f)
|
|
)
|
|
expect(result.length).toBe(0)
|
|
} finally {
|
|
await recursiveDelete(testResolveDataDir)
|
|
}
|
|
})
|
|
|
|
it('should exclude', async () => {
|
|
expect.assertions(2)
|
|
try {
|
|
await recursiveCopy(resolveDataDir, testpreservefileDir, {
|
|
overwrite: true,
|
|
})
|
|
// preserve cache dir
|
|
await recursiveDelete(testpreservefileDir, /^cache/)
|
|
|
|
const result = await recursiveReadDir(testpreservefileDir, (f) =>
|
|
/.*/.test(f)
|
|
)
|
|
expect(result.length).toBe(1)
|
|
} finally {
|
|
// Ensure test cleanup
|
|
await recursiveDelete(testpreservefileDir)
|
|
|
|
const cleanupResult = await recursiveReadDir(testpreservefileDir, (f) =>
|
|
/.*/.test(f)
|
|
)
|
|
expect(cleanupResult.length).toBe(0)
|
|
}
|
|
})
|
|
})
|