Testa una Cloud Function prima del deployment

Questa guida illustra come testare una Cloud Function nella console Google Cloud prima di eseguirne il deployment. Questa funzionalità è disponibile per le funzioni Node.js e Python.

Prepara una funzione per i test

Per preparare una funzione per il test:

  1. Apri la pagina Panoramica delle funzioni nella console Google Cloud:

    Vai alla pagina Panoramica di Cloud Functions

    Assicurati che il progetto per il quale hai abilitato Cloud Functions sia selezionato.

  2. Fai clic su Crea funzione per creare una nuova funzione Node.js o Python, oppure seleziona una funzione Node.js o Python esistente e fai clic su Modifica per modificarla.

  3. Fai clic su Avanti per passare alla pagina di modifica del codice:

    Screenshot che mostra il riquadro di test di pre-deployment della funzione

  4. Fai clic su Testa funzione per avviare il processo di test.

  5. Quando richiesto, fai clic su Inizia il test per autorizzare l'utilizzo del terminale Cloud Shell.

Esegui il test

Una volta completati i passaggi precedenti, il riquadro dell'evento di attivazione si apre a destra, a conferma che la funzione è pronta per essere testata. Fai clic su Esegui test:

Screenshot che mostra il riquadro di test di pre-deployment della funzione

Questa fase del processo di test include i seguenti componenti:

  • Riquadro dell'evento di attivazione: Il riquadro dell'evento di trigger è precompilato con un payload corrispondente all'attivatore di evento specificato nella pagina di configurazione. Questo è l'input della funzione.
  • Finestra di output di Cloud Shell. La finestra di output di Cloud Shell mostra il codice di stato HTTP e l'eventuale risposta restituita al chiamante.
  • Esegui test consente di eseguire il test.

Puoi osservare l'output del test nella finestra di Cloud Shell:

Screenshot che mostra la finestra di output di Cloud Shell

Terminale Cloud Shell

Puoi visualizzare l'output di logging dalla tua funzione nel terminale Cloud Shell nella parte inferiore dello schermo. Ad esempio, vedrai il codice sorgente che pacchettizza l'output quando apri il riquadro di test. Quando esegui un test, vedrai le modifiche al codice sorgente e l'output del livello di esecuzione, inclusi console.log ed errori.

Se il test ha esito negativo, il terminale Cloud Shell visualizza un messaggio di errore per aiutarti a individuare la causa esatta, ad esempio:

[11:31:47 AM] - Provided module can't be loaded.
Is there a syntax error in your code?
Detailed stack trace: /workspace/index.js:11
    : 'World';
    ^

SyntaxError: Unexpected token ':'
    at Object.compileFunction (node:vm:360:18)
    at wrapSafe (node:internal/modules/cjs/loader:1048:15)
    at Module._compile (node:internal/modules/cjs/loader:1083:27)
    at Module._extensions..js (node:internal/modules/cjs/loader:1173:10)
    at Module.load (node:internal/modules/cjs/loader:997:32)
    at Module._load (node:internal/modules/cjs/loader:838:12)
    at Module.require (node:internal/modules/cjs/loader:1021:19)
    at require (node:internal/modules/cjs/helpers:103:18)
    at getUserFunction (/workspace/node_modules/@google-cloud/functions-framework/build/src/loader.js:98:30)
    at async main (/workspace/node_modules/@google-cloud/functions-framework/build/src/main.js:35:32)

[11:31:47 AM] - Could not load the function, shutting down.

Esegui il deployment

Al termine del test, puoi eseguire il deployment della funzione nel modo abituale facendo clic su Esegui il deployment.