- Internal Events Monitor
- Snowplow Micro
- Manual check in GDK
- Snowplow Analytics Debugger Chrome Extension
- Remote event collector
Local setup and debugging
Internal events are using a tool called Snowplow under the hood. To develop and test internal events, there are several tools to test frontend and backend events:
Testing Tool | Frontend Tracking | Backend Tracking | Local Development Environment | Production Environment | Shows individual events |
---|---|---|---|---|---|
Internal Events Monitor | Yes | Yes | Yes | Yes | Yes |
Snowplow Micro | Yes | Yes | Yes | No | Yes |
Manual check in GDK | Yes | Yes | Yes | Yes | No |
Snowplow Analytics Debugger Chrome Extension | Yes | No | Yes | Yes | Yes |
Remote event collector | Yes | No | Yes | No | Yes |
For local development we recommend using the internal events monitor when actively developing new events.
Internal Events Monitor
To understand how events are triggered and metrics are updated while you use the GitLab application locally or rails console
,
you can use the monitor.
Start the monitor and list one or more events that you would like to monitor. In this example we would like to monitor i_code_review_user_create_mr
.
rails runner scripts/internal_events/monitor.rb i_code_review_user_create_mr
The monitor can show two tables:
-
The
RELEVANT METRICS
table lists all the metrics that are defined on thei_code_review_user_create_mr
event. The second right-most column shows the value of each metric when the monitor was started and the right most column shows the current value of each metric. -
The
SNOWPLOW EVENTS
table lists a selection of properties from only Snowplow events fired after the monitor was started and those that match the event name. It is no longer a requirement to set up Snowplow Micro for this table to be visible.
If a new i_code_review_user_create_mr
event is fired, the metrics values get updated and a new event appears in the SNOWPLOW EVENTS
table.
The monitor looks like below.
Updated at 2023-10-11 10:17:59 UTC
Monitored events: i_code_review_user_create_mr
+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| RELEVANT METRICS |
+-----------------------------------------------------------------------------+------------------------------+-----------------------+---------------+---------------+
| Key Path | Monitored Events | Instrumentation Class | Initial Value | Current Value |
+-----------------------------------------------------------------------------+------------------------------+-----------------------+---------------+---------------+
| counts_monthly.aggregated_metrics.code_review_category_monthly_active_users | i_code_review_user_create_mr | RedisHLLMetric | 13 | 14 |
| counts_monthly.aggregated_metrics.code_review_group_monthly_active_users | i_code_review_user_create_mr | RedisHLLMetric | 13 | 14 |
| counts_weekly.aggregated_metrics.code_review_category_monthly_active_users | i_code_review_user_create_mr | RedisHLLMetric | 0 | 1 |
| counts_weekly.aggregated_metrics.code_review_group_monthly_active_users | i_code_review_user_create_mr | RedisHLLMetric | 0 | 1 |
| redis_hll_counters.code_review.i_code_review_user_create_mr_monthly | i_code_review_user_create_mr | RedisHLLMetric | 8 | 9 |
| redis_hll_counters.code_review.i_code_review_user_create_mr_weekly | i_code_review_user_create_mr | RedisHLLMetric | 0 | 1 |
+-----------------------------------------------------------------------------+------------------------------+-----------------------+---------------+---------------+
+---------------------------------------------------------------------------------------------------------+
| SNOWPLOW EVENTS |
+------------------------------+--------------------------+---------+--------------+------------+---------+
| Event Name | Collector Timestamp | user_id | namespace_id | project_id | plan |
+------------------------------+--------------------------+---------+--------------+------------+---------+
| i_code_review_user_create_mr | 2023-10-11T10:17:15.504Z | 29 | 93 | | default |
+------------------------------+--------------------------+---------+--------------+------------+---------+
The Monitor’s Keyboard commands:
- The
p
key acts as a toggle to pause and start the monitor. It makes it easier to select and copy the tables. - The
r
key resets the monitor to it’s internal state, and removes any previous event that had been fired from the display. - The
q
key quits the monitor.
Snowplow Micro
By default, self-managed instances do not collect event data through Snowplow. We can use Snowplow Micro, a Docker based Snowplow collector, to test events locally:
-
Ensure Docker is installed and working.
-
Enable Snowplow Micro:
gdk config set snowplow_micro.enabled true
-
Optional. Snowplow Micro runs on port
9091
by default, you can change to9092
by running:gdk config set snowplow_micro.port 9092
-
Regenerate your Procfile and YAML configuration by reconfiguring GDK:
gdk reconfigure
-
Restart the GDK:
gdk restart
-
You can now see all events being sent by your local instance in the Snowplow Micro UI and can filter for specific events.
Introduction to Snowplow Micro UI and API
Manual check in GDK
As a quick test of whether an event is getting triggered & metric is updated, you can check the latest values in the rails console. Make sure to load the helpers below so that the most recent events & records are included in the output.
To view the entire service ping payload:
require_relative 'spec/support/helpers/service_ping_helpers.rb'
ServicePingHelpers.get_current_service_ping_payload
To view the current value for a specific metric:
require_relative 'spec/support/helpers/service_ping_helpers.rb'
ServicePingHelpers.get_current_usage_metric_value(key_path)
Snowplow Analytics Debugger Chrome Extension
Snowplow Analytics Debugger is a browser extension for testing frontend events. It works in production, staging, and local development environments. It is especially suited to verifying correct events are getting sent in a deployed environment.
- Install the Snowplow Analytics Debugger Chrome browser extension.
- Open Chrome DevTools to the Snowplow Debugger tab.
- Any event triggered on a GitLab page should appear in the Snowplow Debugger tab.
Remote event collector
On GitLab.com events are sent to a collector configured by GitLab. By default, self-managed instances do not have a collector configured and do not collect data with Snowplow.
You can configure your instance to use a custom Snowplow collector.
- On the left sidebar, at the bottom, select Admin.
- Select Settings > General.
- Expand Snowplow.
-
Select Enable Snowplow tracking and enter your Snowplow configuration information. For example if your custom snowplow collector is available at
your-snowplow-collector.net
:Name Value Collector hostname your-snowplow-collector.net
App ID gitlab
Cookie domain .your-gitlab-instance.com
- Select Save changes.