Validate events

  • Use the Measurement Protocol validation server or the Google Analytics Event Builder to verify your events before production.

  • Events sent to the validation server do not appear in reports.

  • The validation server's URL includes "/debug" unlike the standard Measurement Protocol URL.

  • The validation server response provides detailed messages about any issues found, including field path, description, and a validation code.

  • The validation server does not validate api_secret or firebase_app_id, so carefully review these values.

Choose your platform:

The Google Analytics Measurement Protocol does not return HTTP error codes, even if an event is malformed or missing required parameters. To verify your events are valid, you should test them against the Measurement Protocol validation server before deploying them to production. After you have validated that your events are structured properly, you should verify your implementation to make sure you're using the correct keys.

You can either call the validation server directly, or use the Google Analytics Event Builder. The Google Analytics Event Builder lets you interactively construct events, and uses the Measurement Protocol validation server to validate them.

This guide describes how to send events to the Measurement Protocol for Google Analytics 4 validation server and interpret the response.

Send events for validation

The only difference in the request for events sent to the Measurement Protocol and the Measurement Protocol validation server is the URL.

Server URL
Measurement Protocol /mp/collect
Measurement Protocol validation server /debug/mp/collect

All other request fields are the same.

We recommend the following approach to validation:

  • Use strict validation checks during development using either of the following options:
    • Validate requests with the Event Builder.
    • Send requests to the validation server with validation_behavior set to ENFORCE_RECOMMENDATIONS.
  • In production, send requests without validation_behavior set to minimize the data rejected by the Measurement Protocol.

The following code shows an invalid event being sent to the Measurement Protocol validation server:

const firebaseAppId = "FIREBASE_APP_ID"; const apiSecret = "API_SECRET"; fetch(`https://www.google-analytics.com/debug/mp/collect?firebase_app_id=${firebaseAppId}&api_secret=${apiSecret}`, {  method: "POST",  body: JSON.stringify({  app_instance_id: "APP_INSTANCE_ID",  validation_behavior: "ENFORCE_RECOMMENDATIONS",  events: [{  // Event names must start with an alphabetic character.  name: "_badEventName",  params: {},  }]  }) }); 

Validation response

Here's the validation server's response to the previous event:

{  "validationMessages": [  {  "fieldPath": "events",  "description": "Event at index: [0] has invalid name [_badEventName]. Names must start with an alphabetic character.",  "validationCode": "NAME_INVALID"  }  ] } 

Here's the validation server's response to a request with no validation issues:

{  "validationMessages": [] } 

Response

Key Type Description
validationMessages Array<ValidationMessage> An array of validation messages.

ValidationMessage

Key Type Description
fieldPath string The path to the field that was invalid.
description string A description of the error.
validationCode ValidationCode A validation code that corresponds to the error.

ValidationCode

Value Description
VALUE_INVALID The value provided for a fieldPath was invalid. See limitations.
VALUE_REQUIRED A required value for a fieldPath was not provided.
NAME_INVALID The name provided was invalid. See limitations.
NAME_RESERVED The name provided was one of the reserved names. See reserved names.
VALUE_OUT_OF_BOUNDS The value provided was too large. See limitations.
EXCEEDED_MAX_ENTITIES There were too many parameters in the request. See limitations.
NAME_DUPLICATED The same name was provided more than once in the request.