Automatically reporting errors
You can emit an error from a function to Error Reporting as shown below:
Node.js
// These WILL be reported to Error Reporting
throw
new
Error
(
'I failed you'
);
// Will cause a cold start if not caught
Python
@functions_framework
.
http
def
hello_error_1
(
request
):
# This WILL be reported to Error Reporting,
# and WILL NOT show up in logs or
# terminate the function.
from
google.cloud
import
error_reporting
client
=
error_reporting
.
Client
()
try
:
raise
RuntimeError
(
"I failed you"
)
except
RuntimeError
:
client
.
report_exception
()
# This WILL be reported to Error Reporting,
# and WILL terminate the function
raise
RuntimeError
(
"I failed you"
)
@functions_framework
.
http
def
hello_error_2
(
request
):
# These errors WILL NOT be reported to Error
# Reporting, but will show up in logs.
import
logging
import
sys
print
(
RuntimeError
(
"I failed you (print to stdout)"
))
logging
.
warning
(
RuntimeError
(
"I failed you (logging.warning)"
))
logging
.
error
(
RuntimeError
(
"I failed you (logging.error)"
))
sys
.
stderr
.
write
(
"I failed you (sys.stderr.write)
\n
"
)
# This is considered a successful execution and WILL NOT be reported
# to Error Reporting, but the status code (500) WILL be logged.
from
flask
import
abort
return
abort
(
500
)
If you would like more fine-grained error reporting, you can use the Error Reporting client libraries .
You can view the reported errors in Error Reporting in the Google Cloud console. You can also see the errors reported from a particular function when you select it from the list of functions in the Google Cloud console.
Uncaught exceptions produced by your function will appear in Error Reporting. Note that some types of uncaught exceptions (such as those thrown asynchronously) will cause a cold start to occur upon a future function invocation. This increases the amount of time your function will take to run.
Manually reporting errors
Importing dependencies
To report an error to Error Reporting
from a function, import the error
function from the Cloud Functions logger
SDK:
//
All
available
logging
functions
const
{
log
,
info
,
debug
,
warn
,
error
,
write
,
}
=
require
(
"firebase-functions/logger"
);
Sending to Cloud Logging
The error
function from the Cloud Functions logger
SDK will report errors to both Cloud Logging
and Error Reporting
. To include more context from the error as structured data
, pass an error object as the second argument:
} catch (err) {
// Attach an error object as the second argument
error("Unable to read quote from Firestore, sending default instead",
err);

