Eng Intelligence
Eng Intelligence provides users with key metrics and high-level data to gain insights into services, bottlenecks in the pull request lifecycle, incident response, and more. These metrics can indicate areas that need deeper investigation, allowing you to quickly remediate and improve productivity across your teams.
Eng intelligence reports on metrics for deploys, git (Azure DevOps, GitHub, and GitLab), issue tracking (Jira), and incident management (PagerDuty). See the available metrics under the Metrics header below.
Users with the View Eng Intelligence
permission can access Eng Intelligence. Users with the Configure Eng Intelligence
permission can configure Eng Intelligence settings.
Accessing Eng Intelligence
To view, click Eng Intelligence in the main nav:
If you do not see Eng Intelligence, please contact your Cortex Customer Success Manager.
Using Eng Intelligence
Eng Intelligence aggregates data from your connected entities to calculate critical metrics based on your organization's priorities. The data is presented by team, group, or individual, and can be filtered by time range. Cortex provides a set of default metrics, but you can also create custom metrics to track here.
These values are recalculated every hour. For count metrics, like "PRs opened," you’ll see a "0" if there are no data available. For average metrics, like "Avg PR open to close time," you’ll see "N/A" if no data are available to calculate averages.
Apply time range and team filters
To filter by time range:
In the upper right corner of Eng Intelligence, click the Time range dropdown then select a time range for your metrics display:
To filter by team, group, or owner:
- Click Filter by in the upper right corner.
- Select a team, group, and/or owner.
- Click Save filters.
Group by team hierarchy
By default, each Team entity in Cortex is displayed in its own dedicated row. To group by the team hierarchies you've created, click View as hierarchy.
Group by entity type
Click the Group by dropdown to select and view the metrics for each entity type: team, group, user, service, owner, domain.
Group by user label
After you have set up user labels, you can group by labels in Eng Intelligence.
Click the Group by dropdown and select a label you want to group by. The grouping will be added as a row to the metrics table, along with separate rows for each member of the grouping.
View more details for an entity
To better understand the data behind a trend you see in Eng Intelligence, click an entity to open a side panel with more information. In the panel, see the available metrics a historical performance graph for each.
You can adjust the time range for the graphs to be anywhere between 7 days and 6 months. This will update the graph view and maps to the table, so all metrics will reflect the new timeframe.
Show Scorecard view
The Show Scorecard view overlays Eng Intelligence with Scorecard performance by level when grouped by team or service. This view is not available when grouping by group, user, or owner.
When you select a Scorecard from the Show Scorecard dropdown, the icon representing the level achieved by each entity will appear next to its name.
Metrics
Users with the Configure custom metrics
permission can create custom metrics for Eng Intelligence, or you can use the built-in metrics listed below.
Eng intelligence reports on metrics for deploys, git (Azure DevOps, GitHub, and GitLab), Jira, and PagerDuty.
Deploy metrics
Avg deploys/week
- Calculates the average number of deploys per week over the selected time range.
- Pulls deploy data added via the Cortex deploys API.
Deploy change failure rate
- Displays the number of rollbacks divided by number of deploys in a given time range.
- Pulls deploy data added via the Cortex deploys API.
Git metrics
Avg PR open to close time
- Calculates the average time to close pull requests for each PR opened and merged during the selected time range.
- Pulls data from Azure DevOps, GitHub, and GitLab.
This metric provides insight into how long it takes to merge something, such as build time, reviews, conversations, fixing linter issues, etc.
If your Average PR open to close time is high, it’s worth investigating to identify the part of the development cycle that contribute the most to this time.
Average PR open to close time is related to other metrics, such as time to review and bottlenecks in average PRs reviewed each week. The key here is to examine the time and quantity of a particular activity.
Note that if some teams are using draft pull requests, their numbers may be higher.
Avg time to first review
- Determines average time from first open to first review of a pull request for any PR that has been opened during the selected time range.
- Pulls data from Azure DevOps, GitHub, and GitLab.
For a subset of pull requests, this metric can provide insight into potential inefficiencies. For high figures, investigate whether this is due to the software process or roadblocks faced by team members.
Note that if some teams are using draft pull requests, their numbers may be higher.
Avg time to approval
- Displays average time from when a pull request was first opened to when it was first approved for any PR opened during the selected time range.
- Pulls data from Azure DevOps, GitHub, and GitLab.
Average time to approval can capture review-related bottlenecks in the PR cycle. When this figure is high, there may be opportunities to improve processes and PR sizes.
Note that if some teams are using draft pull requests, their numbers may be higher.
PRs opened
- Displays a count of pull requests opened during the selected time range.
- Pulls data from Azure DevOps, GitHub, and GitLab.
Pull requests opened is particularly useful as a throughput metric. When reviewing this data, consider the expected minimum activity for a developer.
On an individual level, evaluate how much time a team member spends building features versus supporting others. You can also assess how much time a team is spending shipping code versus other teams.
Note that while this metric provides useful insight, weekly PRs merged may be a more meaningful figure.
Weekly PRs merged
- Calculates how many pull requests were opened each week, averaged across the weeks in the selected time range, to determine how many PRs were opened and merged each week.
- Pulls data from Azure DevOps, GitHub, and GitLab.
This throughput metric provides insight into how many things make it to the default branch and are closed out.
In theory, this figure should match the trend for Average PR open to close time, since you don’t want too many pull requests kept open.
Average PRs reviewed/week
- Calculates the number of pull requests that were reviewed each week, averaged across the selected time frame.
- Pulls data from Azure DevOps, GitHub, and GitLab.
This metric helps users understand bottlenecks in the review stage due to load balancing work, education gaps, onboarding, career progression, and domain mastery.
Note that this figure has been deduplicated on a per user basis, so if a user reviews a pull request multiple times, it will only display once within Eng Intelligence.
You may be spending too much time in the review stage if this figure is high, but you have a low number of commits and a low number of merged pull requests. If this is the case, other parts of the PR lifecycle may be at risk.
Average commits per PR
- Displays the number of commits required from PR open to close, and averaged across all PRs, for any PR opened and merged during the selected time range.
- Pulls data from Azure DevOps, GitHub, and GitLab.
This metric provides insight into activity trends by team members, as greater activity indicates more engagement.
Average commits per PR can be helpful during the onboarding process, so you can gauge how long it takes for a developer to reach the team’s baseline for activity.
Note that if some teams are using draft pull requests, their numbers may be higher.
Avg LOC changed per PR
- Displays the average number of lines added plus lines deleted for pull requests that were opened/merged during the selected timeframe.
- Pulls data from GitHub and GitLab. This metric is not supported for Azure DevOps.
This metric can provide information about pull request size. Ideally, developers should open consumable PRs that are easy to review, and thus are easy to push into production.
This figure can impact other metrics related to the PR cycle.
Jira metrics
For information on using Jira metrics in Eng Intelligence, see Jira metrics.
PagerDuty metrics
Mean time to resolve incidents
- Calculates average amount of time from incident open to resolution in the selected time range.
- Pulls data from PagerDuty.
Incidents opened
- Displays sum of incidents opened for that time range; based on the most recently assigned user/team for each incident.
- Pulls data from PagerDuty.
Incidents opened/week
- Displays sum of of incidents opened, divided by the number of weeks in the selected time range; based on the most recently assigned user/team for each incident.
- Pulls data from PagerDuty.
Eng Intelligence settings
Change Eng Intelligence appearance
From the Eng Intelligence tab of Appearance settings, users with the Configure Eng Intelligence
permission can also choose which columns to display and adjust the order of columns.
Set filtering for metric calculation
In the Filters tab on Settings > Eng Intelligence, users with the Configure Eng Intelligence
permission can set filters for some pre-defined metrics:
- Under Deploys, select the deploy environments you want to include in the calculation of deploy frequency and deploy failure rate.
- If none are selected, all deploys will be included.
- Under Pull requests, select the authors you want to exclude from the calculation of PR-related metrics.
- If none are selected, PRs from all authors will be included.
- By default, Cortex filters out pull requests opened by bots in GitHub but does not do this automatically for GitLab.
Create and manage user labels for grouping
User labels in Eng Intelligence allow you to group users into cohorts to analyze metrics based on different factors. This can be useful for benchmarking one engineer’s metrics against the average within a cohort, comparing metrics between engineers who use different tools to complete their work, and understanding metrics by different variables: location (e.g., in office or remote), engineer level (staff vs. lead engineer), tech stack (frontend vs. backend), and more.
Users who have the Configure user labels
permission can create and apply labels.
The instructions below describe how to use this feature in the Cortex UI. See the Cortex API documentation for instructions on creating and managing user labels programmatically.
Create a user label
- In Cortex, navigate to the Eng Intelligence settings.
- Click your avatar in the lower left then click Settings.
- Under “User management,” click Eng Intelligence.
- Click the Label management tab, then click Create label.
- Fill out the “Create label” form:
- Name: Enter a descriptive name, e.g.,
Location
. - Values: Enter possible values for the label, e.g.,
New York
,California
,Remote
. - Description: Optionally enter a description, such as "This label helps us understand metrics by location."
- Name: Enter a descriptive name, e.g.,
- Click Save label.
After saving, the label will appear under the Label management tab in the Eng Intelligence settings page.
View applied user labels
In the Eng Intelligence settings page under the User labeling tab, you can view a list of users and their applied labels. Note that these labels are only displayed in Eng Intelligence, and not in other pages within Cortex.
Assign a user label to a user
- In Cortex, navigate to the Eng Intelligence settings.
- Click your avatar in the lower left then click Settings.
- Under “User management,” click Eng Intelligence.
- Click the User labeling tab.
- Locate the user you want to add a label to. Next to that users name, under the “Labels” column, click the dropdown and select a label.
Assign user labels in bulk
- In Cortex, navigate to the Eng Intelligence settings.
- Click your avatar in the lower left then click Settings.
- Under “User management,” click Eng Intelligence.
- Click the User labeling tab.
- Check the boxes next to the users you want to edit, then in the upper right, click Bulk edit.
- In the bulk edit modal, enter the labels you want to add to the users, then click Confirm changes.
After applying labels to users, you can group by user label while viewing Eng Intelligence metrics.