From f085c7a448ab3bc15dfdda9046f5112da459437e Mon Sep 17 00:00:00 2001 From: eps1lon Date: Thu, 13 Jun 2024 13:49:28 +0200 Subject: [PATCH] Stop using `workerd` Vercel Edge Functions don't necessarily implement the same APIs as CF Workers. If a library supports both, the library has to provide entries for each in `exports`. --- .../next-swc/crates/next-core/src/util.rs | 2 +- .../src/build/webpack-config-rules/resolve.ts | 1 - .../import-conditions.test.ts | 40 +++++++++---------- 3 files changed, 21 insertions(+), 22 deletions(-) diff --git a/packages/next-swc/crates/next-core/src/util.rs b/packages/next-swc/crates/next-core/src/util.rs index 40841e28cf8fa..58bf8b5837d1b 100644 --- a/packages/next-swc/crates/next-core/src/util.rs +++ b/packages/next-swc/crates/next-core/src/util.rs @@ -150,7 +150,7 @@ impl NextRuntime { pub fn conditions(&self) -> &'static [&'static str] { match self { NextRuntime::NodeJs => &["node"], - NextRuntime::Edge => &["edge-light", "worker"], + NextRuntime::Edge => &["edge-light"], } } } diff --git a/packages/next/src/build/webpack-config-rules/resolve.ts b/packages/next/src/build/webpack-config-rules/resolve.ts index ba70766248d40..b9c546bc6ad78 100644 --- a/packages/next/src/build/webpack-config-rules/resolve.ts +++ b/packages/next/src/build/webpack-config-rules/resolve.ts @@ -6,7 +6,6 @@ import { // exports. export const edgeConditionNames = [ 'edge-light', - 'workerd', // inherits the default conditions '...', ] diff --git a/test/e2e/import-conditions/import-conditions.test.ts b/test/e2e/import-conditions/import-conditions.test.ts index a6dc66f27c7c3..53c44c9ada2c3 100644 --- a/test/e2e/import-conditions/import-conditions.test.ts +++ b/test/e2e/import-conditions/import-conditions.test.ts @@ -22,8 +22,8 @@ describe('react version', () => { } expect(middlewareHeaders).toEqual({ react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }) }) @@ -34,8 +34,8 @@ describe('react version', () => { expect(JSON.parse(json)).toEqual({ server: { react: 'default', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }, client: { react: 'default', @@ -59,8 +59,8 @@ describe('react version', () => { } expect(middlewareHeaders).toEqual({ react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }) }) @@ -96,8 +96,8 @@ describe('react version', () => { } expect(middlewareHeaders).toEqual({ react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }) }) @@ -111,8 +111,8 @@ describe('react version', () => { expect(JSON.parse(json)).toEqual({ server: { react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }, client: { react: 'default', @@ -121,8 +121,8 @@ describe('react version', () => { }, action: { react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }, }) }) @@ -141,8 +141,8 @@ describe('react version', () => { } expect(middlewareHeaders).toEqual({ react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }) }) @@ -188,8 +188,8 @@ describe('react version', () => { expect({ middlewareHeaders, data }).toEqual({ middlewareHeaders: { react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }, data: { react: 'react-server', @@ -215,13 +215,13 @@ describe('react version', () => { expect({ middlewareHeaders, data }).toEqual({ middlewareHeaders: { react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }, data: { react: 'react-server', - serverFavoringBrowser: 'worker', - serverFavoringEdge: 'worker', + serverFavoringBrowser: 'browser', + serverFavoringEdge: 'edge-light', }, }) })