Dalla v28 alla v29
Questa pagina è stata tradotta da PageTurner AI (beta). Non ufficialmente approvata dal progetto. Hai trovato un errore? Segnala problema →
Stai aggiornando Jest dalla v28 alla v29? Questa guida ti aiuterà a rifattorizzare la tua configurazione e i test.
Consulta il changelog per l'elenco completo delle modifiche.
Stai aggiornando da una versione precedente? Puoi consultare la guida per l'aggiornamento dalla v27 alla v28 qui.
Compatibilità
Le versioni di Node supportate sono 14.15, 16.10, 18.0 e superiori.
Formato degli snapshot
Come annunciato nel blog post di Jest 28, Jest 29 ha modificato il formato predefinito degli snapshot impostandolo su {escapeString: false, printBasicPrototype: false}.
Per mantenere il comportamento precedente, imposta la proprietà snapshotFormat su:
+ snapshotFormat: {
+ escapeString: true,
+ printBasicPrototype: true
+ }
Aggiornamento di JSDOM
jest-environment-jsdom ha aggiornato jsdom dalla v19 alla v20.
Se utilizzi jest-environment-jsdom, la versione minima di TypeScript è impostata a 4.5.
Da notare che jsdom@20 include il supporto per crypto.getRandomValues(), il che significa che pacchetti come uuid e nanoid, che non funzionavano correttamente in Jest@28, possono ora funzionare senza polyfill aggiuntivi.
pretty-format
Il plugin ConvertAnsi è stato rimosso dal pacchetto pretty-format a favore di jest-serializer-ansi-escapes.
jest-mock
Le esportazioni dei tipi utility Mocked* dal pacchetto jest-mock sono cambiate. MaybeMockedDeep e MaybeMocked sono ora esportati rispettivamente come Mocked e MockedShallow; sono esposte solo le varianti deep mocked di MockedClass, MockedFunction e MockedObject.
TypeScript
Questa pagina è stata tradotta da PageTurner AI (beta). Non ufficialmente approvata dal progetto. Hai trovato un errore? Segnala problema →
Gli esempi TypeScript in questa pagina funzioneranno come documentato solo se importi esplicitamente le API di Jest:
import {expect, jest, test} from '@jest/globals';
Consulta la guida Per iniziare per i dettagli su come configurare Jest con TypeScript.
jest.mocked()
Il metodo helper jest.mocked() ora avvolge i tipi dei membri profondi dell'oggetto passato per impostazione predefinita. Se hai utilizzato il metodo con true come secondo argomento, rimuovilo per evitare errori di tipo:
- const mockedObject = jest.mocked(someObject, true);
+ const mockedObject = jest.mocked(someObject);
Per ottenere il vecchio comportamento di shallow mocked, passa {shallow: true} come secondo argomento:
- const mockedObject = jest.mocked(someObject);
+ const mockedObject = jest.mocked(someObject, {shallow: true});