Sitemap Event Validation
A Sitemap sends events to Personalization based on the actions of the website visitors (users). There are several ways to validate whether the Sitemap configuration correctly recognizes the targeted user actions and sends the corresponding events.
Sitemap events are HTTP requests sent to Personalization's Event API endpoint that describes the page's context, or a specific action a user performed on the site. Examples of Sitemap events include:
- Visiting a page
- Viewing a catalog item
- Submitting a form
- Adding an item to a shopping cart
- Purchasing an item
- Clicking a designated page area
You can validate Sitemap events using the following tools and methods.
The remainder of this article provides guidance for using each of these tools to validate a Sitemap.
As you develop a Sitemap, you can use the Sitemap Editor as described in the following sections to confirm that the JavaScript describing your events is valid and configured correctly.
While the Sitemap Editor is vitally useful for the development process, it’s essential to test your sitemap code using the other methods outlined in this document. The Sitemap Editor initializes the sitemap code after the website it’s running on is fully loaded. Therefore, you can’t use the Sitemap Editor to test the real-world timing of initializing the sitemap while the page is still loading. Be sure to test the real-world timing on sitemap initialization outside the Sitemap Editor by monitoring the events sent by your sitemap as you browse the website naturally using the following event validation techniques outlined in this document.
- Event Validation Using the Event Stream Report
- Event Validation Using Chrome Browser Developer Tools
The Sitemap JS tab where you enter your Sitemap JavaScript has a built-in code validator that flags the presence of JavaScript syntax errors, as highlighted in the following figure.
The Logs tab provides messages related to the JavaScript code errors flagged by the Sitemap JS code editor. However, it’s advisable to use a more robust JavaScript validation tool to investigate JavaScript syntax issues and code execution errors flagged in the Sitemap JS code editor.
The following image shows the Current Page tab of the Sitemap Editor.
The Current Page tab displays all Sitemap objects configured and executed on the current page shown in the browser, including:
- Page Type: Name of the configured page type of the currently displayed page
- User Data: The ID of the current user browsing the page and any user-triggered events that are configured on the page. The user ID can be the user ID that is randomly generated for anonymous site visitors, or a named user ID.
- Catalog Data: Names of Catalog objects configured on the current page.
- Content Zones: Names of Content Zone objects configured on the current page.
- DOM Listeners: Names of JavaScript DOM listeners configured on the current page.
The following figure shows an example of how Sitemap objects display in the Current Page tab with key functional areas indicated by numbers.
The following table lists the areas numbered on the figure and describes the purpose and function of each area.
Number | Area | Description |
---|---|---|
1 | Current Page (Site Home Page) | This area displays the current page of the target site that the Sitemap editor is targeting. The objects displayed in the Current Page tab are configured for the page type displayed here. In the preceding example, the browser used by the Sitemap editor is on the Home page of the target site and has a pageTypes object called home configured in the Sitemap (9). |
2 | Execute (button) | Clicking the Execute button runs and validates the JavaScript entered in the Sitemap JS editor. Sitemap objects that resolve with the current page type or global configuration are displayed in the Current Page tab. Objects with invalid JavaScript don’t appear in the Current Page tab. |
3 | Page Type | This area displays the page type that matches the results of the isMatch function configured for the currently displayed page type. In the preceding example, the site Home page type (1) is matched by the isMatch function configured for the page type named home in the Sitemap (9). |
4 | User Data | This area displays the user ID of the user visiting the current page and any user-triggered events configured in the Sitemap. The preceding example shows an anonymous user ID. |
5 | Catalog Data | This area displays any catalog objects configured in the Sitemap JS for the currently displayed page. In the preceding Home page example, no catalog objects have been configured. |
6 | Content Zones - Global | The preceding example shows that this Sitemap has two global Content Zones that are properly configured to display in the Current Page tab. Global content zones are active in all configured page types. |
7 | DOM Listeners | The preceding example shows that this Sitemap has a listener in the global configuration that that is properly configured to display in the DOM Listeners section of the Current Page tab. This listener sends an event to Personalization when a user signs up for an email subscription. |
8 | Content Zones - Page Type | The preceding example shows that this Sitemap has three Content Zones that are properly configured to display in the Current Page tab when the Sitemap editor is on the home page type. |
9 | pageTypes: home | The preceding example shows that this Sitemap has a home page type configured to display in the Page Type section of the Current Page tab (3) when the Sitemap editor is on the home page type. |
The Page Matches tab displays the currently matched page type as well as all other page types configured in the Sitemap. The currently matched page displays with a "checkmark" icon, while the other configured page types display with a "backslash" icon to indicate they weren’t matched as the current page.
The following figure shows an example of the Page Matches tab where the home page is the currently matched page as well as several other pages that are configured in the Sitemap JS editor but aren’t matched as the current page.
The Personalization Event Stream report displays all events received by Personalization, including events sent from the Sitemap as well as from other sources.
To access the Event Stream report, do the following.
-
Log in to the Personalization UI.
-
On the Dashboard, use the dataset dropdown menu to select the dataset that contains the events you want to see.
-
Hover over Reports on the left menu to display the reports popup menu, and select Event Stream from the Activity section.
The Sitemap JavaScript is configured to send events to Personalization based on the actions by site visitors. This section presents an example based on an anonymous user who decides to sign up for emails from the company (thus becoming "known") and then browses the Men's section of the website.
The following is an example of a JavaScript listener configured to send an event when a user signs up for emails. Since the sign-up form appears on the bottom of every page on the site, ensure that you configure this listener as part of the global
configuration.
The following is an example of a site email sign-up form being completed by "Joe Customer". With the JavaScript listener configured as shown in the preceding section, an event is sent to Personalization and shows up in the Event Stream when a user provides their email address and clicks the submit button (->).
If the email signup listener is properly configured in the Sitemap, when "Joe Customer" provides his email and clicks Submit, the event shows up immediately in the Personalization Event Stream report. This report provides the following information and functionality.
- Event stream search
- Event stream table
- Event details for individual events
The following figure shows an example of the events sent to Personalization before and after Joe Customer submitted his email in the email sign-up form. The following sections describe the information and functionality provided by the Event Stream report.
For more information on the available functionality in the Event Stream report, see Events.
At this time, the Personalization Event Stream doesn't display price
for AddToCart
events.
Event Stream Search
In the Event Stream search area, you can search for and filter the Event Stream table to display only events that were generated by a specific user ID/user name or email address. To search through the Event Stream, do the following.
- In the keyword field, enter text that matches characters in the username or email address for the user whose events you want to see.
- As soon as you enter characters that match an existing username or email address, the matching username is displayed.
- Click the desired user. The Event Stream table now displays only the events for that user.
- If you want to see only events of a specific type, click the Event Type dropdown menu and select the desired type.
Event Stream Table
The Event Stream table lists event data for all events triggered by the Sitemap and other event sources from other systems in the Personalization integration. The data in the Event Stream table is refreshed every 15 seconds and includes the following.
- Timestamp: Time or date that the event occurred. Events triggered on the current day have a timestamp of how many minutes/hours ago the event was triggered. Events triggered the day before the current day have a timestamp of "yesterday". Earlier events have a timestamp of the date the event was triggered.
- User Name or Email: User name or email address of the user who triggered the event.
- Action or URL: Name of the action for which the event was triggered, or the URL of the page that the user visited that triggered the event.
Modifying the Event Stream Data View
The Event Stream table provides the following functionality to modify how the data in the table displays.
- Click a column heading in the Event Stream table to sort the table by the data in that field.
- Click the same column heading more than one time to toggle between an ascending/descending data sort.
- Click an individual event entry in the table to display the details for that event as described in the following section.
From Anonymous to Known User
The example shown in the following figure depicts what happens after "Joe Customer" submits his email address. Upon submission, the anonymous user 7ddc1195...
changes to the known user joe.customer@email.com
. This change happens anytime an anonymous user identifies themselves through an action like email submission or login. Personalization associates the anonymous ID with the known user and adds the browsing behavior of the anonymous ID to the Unified Customer Profile of the known user. A known user can have many associated anonymous IDs (and more than one known username) depending on their browsing habits on the site.
The preceding figure is for example purposes only. In large environments with hundreds or thousands of simultaneous visitors, it’s extremely difficult to visually associate the anonymous user ID with their known username.
Individual Event Details
When you click an individual event in the Event Stream table, the details for that event are displayed in the Event Detail area to the right of the Event Stream table.
As shown in the preceding figure, the details provided in the Event Detail area for the selected individual event include:
Field | Description |
---|---|
Timestamp | Date and time that the event was triggered. |
User ID | User name, email address, or anonymous user ID of the user who triggered the event. |
URL | URL returned from window.location.href on the page where the event is generated. |
Client IP | IP address of the user client that generated the event. |
User Agent | User Agent (UA) string sent in the HTTP header with browser requests that typically identifies the browser type, browser version, and browser host operating system. |
Beacon Version | Version of the JavaScript Beacon (Web SDK) that sent the event. |
pageType | The type of page that the user accessed. The preceding figure shows the event of a user accessing the "Men's" category page of a retailer. |
contentZones | Content Zones defined for the above pageType . Its value is a combination of contentZones defined for the PageConfig that was matched in the Sitemap and contentZones defined in the GlobalConfig . |
channel | The engagement channel that generated the event. For Web SDK-generated events, the channel is always Web . |
.scv | The Site Configuration Version (SCV) is incremented every time changes to the Sitemap are saved. This value is used internally by Personalization to prevent conflicts with events sent from earlier Sitemap versions. |
The Event Stream table also includes the following additional fields that provide more information about a specific event, Web SDK and web page performance, and help you identify the root cause of Web SDK errors.
Type | Field | Description |
---|---|---|
Error fields | .em | Error message describing the issue that occurred. For example, "Response was not OK." |
.es | Section where the error was thrown. For example, "Server Response". | |
.eu | URL of the resource in which the error was thrown. For example, if the error was thrown in the Personalization Web SDK, your JavaScript beacon URL is displayed here. | |
.ef | Function or method that threw the error. For example, createCustomError . | |
.el | Line number in the source code file where the error was thrown. | |
.ec | Column number in the source code file where the error was thrown. | |
Performance fields | .bt | Time taken for the Web SDK to load on the web page. |
.pt | Time taken for the Web SDK to parse and process data after it has loaded. | |
.btdns | Time taken for the Web SDK to resolve DNS requests. | |
.lt | Time taken for the web page to fully load, including all assets such as images, scripts, and stylesheets. | |
.dt | Time taken for the Document Object Model (DOM) to fully load. | |
.tt | Time taken for network requests to complete, including any latecny or server-side processing time. | |
.ttdns | Time taken for DNS requests to resolve when sending or tracking events. |
Sitemap developers can also validate Sitemap events using Google Chrome's built-in developer tools, as described in the following sections.
The simplest way to view events that are triggered by page load is to run the SalesforceInteractions.mcis.getSitemapResult().currentPage
command (or Evergage.getCurrentPage
in the Evergage
namespace) from the Chrome Console developer panel. However, this command will not display events that are triggered after page load. To run this command, do the following:
-
Exit the Personalization Sitemap Editor.
-
Navigate to the site page containing the events you want to validate.
-
Open Chrome Developer Tools and navigate to the Console panel.
-
Depending on the namespace being used, run the following command.
The following figure shows an example of the results of running the
SalesforceInteractions.getSitemapResult().currentPage
command.The following figure shows an example of the results of running the
Evergage.getCurrentPage
command.
In the Chrome Network developer panel, you can see all events generated on the current page, including those events generated after page load. To view all events generated on the current page, do the following.
-
Exit the Personalization Sitemap Editor.
-
Navigate to the site page containing the events you want to validate.
-
Perform an action on the page that you expect to generate an event.
-
Open the Chrome Developer Tools and navigate to the Network panel.
-
Find and select the event. The event contains the name of your dataset followed by a question mark (?) and the word "event".
-
Select the event and select the Headers panel to view the event. Events are sent from the Sitemap to Personalization as JSON GET requests. The events are converted to Base64 and appended to the request URL, as shown in the following figure.
-
Copy the event GET request starting immediately after
event=
to the end, as highlighted in the following figure. -
Navigate to the Chrome Console developer tool. Run the
atob
command to convert the event back to JavaScript objects. You can run theJSON.parse
command in combination with theatob
command to return the event JavaScript formatted. The syntax for running this command is as follows:The following figure shows an example of running the
atob
command in theSalesforceInteractions
namespace and the results returned.The following figure shows an example of running the
atob
command in theEvergage
namespace and the results returned. -
Review the event and confirm it contains the expected objects.