Some checks failed
Test examples / Test Examples (20) (push) Has been cancelled
Test examples / Test Examples (22) (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Trigger Release / start (push) Has been cancelled
Stale issue handler / stale (push) Has been cancelled
Update Font Data / create-pull-request (push) Has been cancelled
build-and-deploy / deploy-target (push) Has been cancelled
build-and-deploy / build (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / build-wasm (nodejs) (push) Has been cancelled
build-and-deploy / build-wasm (web) (push) Has been cancelled
build-and-deploy / Deploy preview tarball (push) Has been cancelled
build-and-deploy / Potentially publish release (push) Has been cancelled
build-and-deploy / publish-turbopack-npm-packages (push) Has been cancelled
build-and-deploy / Deploy examples (push) Has been cancelled
build-and-deploy / thank you, build (push) Has been cancelled
build-and-deploy / Upload Turbopack Bytesize metrics to Datadog (push) Has been cancelled
Rspack Next.js development integration tests / Rspack integration tests (push) Has been cancelled
Rspack Next.js production integration tests / Rspack integration tests (push) Has been cancelled
Turbopack Next.js development integration tests / Next.js integration tests (push) Has been cancelled
Turbopack Next.js production integration tests / Next.js integration tests (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack development test manifest (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack production test manifest (push) Has been cancelled
Upload bundler test manifests to areweturboyet.com / Upload test results (push) Has been cancelled
Update React / create-pull-request (push) Has been cancelled
test-e2e-project-reset-cron / reset-test-project (push) Has been cancelled
Notify about the top 15 issues/PRs/feature requests (most reacted) in the last 90 days / run (push) Has been cancelled
102 lines
3.3 KiB
TypeScript
102 lines
3.3 KiB
TypeScript
import { nextTestSetup } from 'e2e-utils'
|
|
import { retry } from 'next-test-utils'
|
|
|
|
describe('custom-cache-handler-image', () => {
|
|
const { next, skipped } = nextTestSetup({
|
|
files: __dirname,
|
|
skipDeployment: true,
|
|
env: {
|
|
// Set max cache entries to 2 to easily test eviction
|
|
MAX_IMAGE_CACHE_ENTRIES: '2',
|
|
},
|
|
})
|
|
|
|
if (skipped) {
|
|
return
|
|
}
|
|
|
|
it('should use custom cache handler for image optimization', async () => {
|
|
// First, render the page to get the image URLs
|
|
const $ = await next.render$('/')
|
|
expect($('p').text()).toBe('hello world')
|
|
|
|
const smallImgSrc = $('#image-small').attr('src')
|
|
expect(smallImgSrc).toContain('/_next/image')
|
|
|
|
// Fetch the optimized image to trigger cache handler
|
|
const imageRes = await next.fetch(smallImgSrc)
|
|
expect(imageRes.status).toBe(200)
|
|
|
|
// Verify cache handler was called for the image
|
|
await retry(() => {
|
|
expect(next.cliOutput).toContain('initialized custom cache-handler')
|
|
expect(next.cliOutput).toContain('cache-handler set')
|
|
expect(next.cliOutput).toMatch(/kind:.*IMAGE/)
|
|
})
|
|
})
|
|
|
|
it('should evict oldest entries when cache exceeds max size', async () => {
|
|
const $ = await next.render$('/')
|
|
|
|
const smallImgSrc = $('#image-small').attr('src')
|
|
const mediumImgSrc = $('#image-medium').attr('src')
|
|
const largeImgSrc = $('#image-large').attr('src')
|
|
|
|
// Request all three images sequentially
|
|
// With MAX_IMAGE_CACHE_ENTRIES=2, the first image should be evicted
|
|
// when the third one is added
|
|
|
|
// Request image 1 (small)
|
|
await next.fetch(smallImgSrc)
|
|
await retry(() => {
|
|
expect(next.cliOutput).toContain('cache-handler image cache size: 1')
|
|
})
|
|
|
|
// Request image 2 (medium)
|
|
await next.fetch(mediumImgSrc)
|
|
await retry(() => {
|
|
expect(next.cliOutput).toContain('cache-handler image cache size: 2')
|
|
})
|
|
|
|
// Request image 3 (large) - this should trigger eviction of image 1
|
|
await next.fetch(largeImgSrc)
|
|
await retry(() => {
|
|
expect(next.cliOutput).toContain('cache-handler evicting')
|
|
// Cache size should still be 2 after eviction
|
|
const sizeMatches = next.cliOutput.match(
|
|
/cache-handler image cache size: (\d+)/g
|
|
)
|
|
const lastSize = sizeMatches?.[sizeMatches.length - 1]
|
|
expect(lastSize).toContain('size: 2')
|
|
})
|
|
})
|
|
|
|
it('should miss cache for evicted entries', async () => {
|
|
const $ = await next.render$('/')
|
|
|
|
const smallImgSrc = $('#image-small').attr('src')
|
|
const mediumImgSrc = $('#image-medium').attr('src')
|
|
const largeImgSrc = $('#image-large').attr('src')
|
|
|
|
// Fill the cache and cause eviction
|
|
await next.fetch(smallImgSrc) // Entry 1
|
|
await next.fetch(mediumImgSrc) // Entry 2
|
|
await next.fetch(largeImgSrc) // Entry 3, evicts entry 1
|
|
|
|
// Clear output to make assertions cleaner
|
|
const outputBefore = next.cliOutput
|
|
|
|
// Request the evicted image again - should be a cache miss
|
|
await next.fetch(smallImgSrc)
|
|
|
|
await retry(() => {
|
|
// Get output after the last request
|
|
const newOutput = next.cliOutput.slice(outputBefore.length)
|
|
// Should have a cache miss for the small image (it was evicted)
|
|
expect(newOutput).toContain('cache-handler miss')
|
|
// Should set it again
|
|
expect(newOutput).toContain('cache-handler set')
|
|
})
|
|
})
|
|
})
|