Skip to content

Commit

Permalink
fix: Fetch handler hacks for Mirage (release) (#9204)
Browse files Browse the repository at this point in the history
* Port 4.12 fetch updates to release

* Force build
  • Loading branch information
gitKrystan authored Jan 23, 2024
1 parent 039bc01 commit 36a5a15
Showing 1 changed file with 19 additions and 5 deletions.
24 changes: 19 additions & 5 deletions packages/request/src/fetch.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,14 +11,16 @@
* @module @ember-data/request/fetch
* @main @ember-data/request/fetch
*/
import { getOwnConfig, macroCondition } from '@embroider/macros';

import { cloneResponseProperties, type Context } from './-private/context';

// Lazily close over fetch to avoid breaking Mirage
const _fetch: typeof fetch =
typeof fetch !== 'undefined'
? fetch
? (...args) => fetch(...args)
: typeof FastBoot !== 'undefined'
? (FastBoot.require('node-fetch') as typeof fetch)
? (...args) => (FastBoot.require('node-fetch') as typeof fetch)(...args)
: ((() => {
throw new Error('No Fetch Implementation Found');
}) as typeof fetch);
Expand All @@ -30,6 +32,12 @@ function cloneResponse(response: Response, overrides: Partial<Response>) {
return new Response(response.body, Object.assign(props, overrides));
}

let IS_MAYBE_MIRAGE = () => false;
if (macroCondition(getOwnConfig<{ env: { TESTING: boolean } }>().env.TESTING)) {
IS_MAYBE_MIRAGE = () =>
Boolean(typeof window !== 'undefined' && (window as { server?: { pretender: unknown } }).server?.pretender);
}

const MUTATION_OPS = new Set(['updateRecord', 'createRecord', 'deleteRecord']);

/**
Expand All @@ -54,9 +62,15 @@ const Fetch = {
const isMutationOp = Boolean(op && MUTATION_OPS.has(op));

if (!isError && !isMutationOp && response.status !== 204 && !response.headers.has('date')) {
const headers = new Headers(response.headers);
headers.set('date', new Date().toUTCString());
response = cloneResponse(response, { headers });
if (IS_MAYBE_MIRAGE()) {
response.headers.set('date', new Date().toUTCString());
} else {
const headers = new Headers(response.headers);
headers.set('date', new Date().toUTCString());
response = cloneResponse(response, {
headers,
});
}
}

context.setResponse(response);
Expand Down

0 comments on commit 36a5a15

Please sign in to comment.