Learn how to configure DevOps Intelligence to collect data acquired by GitHub, extending the single pane of glass DevOps Intelligence affords in your hybrid IT estate.
GitHub provides version control through an open-source distributed version control system, which enables your entire codebase and history to be available to every developer and allows for easy branching and merging.
DevOps Intelligence supports your use of GitHub and GitHub Enterprise. This topic describes the configuration requirements for both tools. For DevOps Intelligence to pull data from GitHub, you must configure a GitHub account.
GitHub
The Application requires the following information for GitHub:
Name:
Local account name. It could be any string and is used only for reference.
User:
Username for GitHub. Generally, the e-mail ID with which the user logged in to GitHub.
Token:
Personal access token. The personal access token requires permissions within the following recommended scopes:
The application also requires to set up permissions:
On GitHub, navigate to the main page of the repository.
Under your repository name, select
Settings
.
In the
Security
section of the sidebar, select
Code security and analysis.
Under
Access to alerts
, in the search field, start typing the name of the person or team you'd like to find, then select a name in the list of matches.
Select
Save
changes.
GitHub Enterprise
The Application requires the following information for GitHub Enterprise:
Name:
Local account name. It could be any string and is used only for reference.
The connection will look similar to the following image:
Secure alert synchronization
Pre-requisites
GitHub personal access token.
Token user needs to have secure alert access enabled.
For DevOps Intelligence to pull data from GitHub and GitHub enterprise, you must provide the following permissions:
Repository permissions:
On GitHub, navigate to the main page of the repository.
Under your repository name, select Settings.
In the "Security" section of the sidebar, select Code security and analysis.
Under "Access to alerts", in the search field, start typing the name of the person or team you'd like to find, then select a name in the list of matches.
Select Save changes.
Only one user credential can be used to pull information at a single time for a specific application. This avoids reaching the IP rate limit.
For more information regarding DevOps Intelligence Secure alerts see: Secure alerts dashboard.
For the GitHub Enterprise account: If the administrator has set a limit on API calls, DevOps Intelligence optimizes its process of fetching data and will take around 1000 calls each hour. This is to make sure no other tasks using the credentials are hampered. Once the limit is exceeded we see a message depicting the same on
sync
page of GitHub.
Repository level tracking
For this type of tracking, some selections have to be made in the system, as described in the following list:
Account:
Refers to the account through which the tracking is to be done.
Select Tracking Type:
User must select
Repository
for Repo level tracking.
Search Organization:
By selecting here, a list of all organizations for the selected account but not tracked by the Application. Select any organization to be tracked and click
Configure
. Select any organization you want to track and click
Configure
.
Search Repository:
By selecting here, a list will be displayed with all the repositories that are part of the selected organization but not tracked. Select any repository you want to track and click
Configure
.
In the case of GitHub Enterprise accounts - If the administrator has set a limit on API calls, DevOps Intelligence optimizes its process of fetching data and will take around 1000 calls each hour. This is to make sure no other tasks using the credentials are hampered. Once the limit is exceeded we see a message depicting the same on the sync page of GitHub.
Sync
The Sync feature scans current data for visibility after configuring credentials and provides a time estimation of the sync, delete, and pulled intervals. The sync is performed based on the current environment priority. For more details, see your Delivery representative.
Sync Status
The Sync Status section will display the status of the data retrieved after SonarQube is configured.
Connection: Displays the local connected tool name for the sync.
Active sync: Shows the active status of a sync.
Records Processed: Displays the number of records processed
Duration: Shows the amount of time taken to perform a sync.
Last Run: Displays the last Sync run.
Status: Current sync status information.
Sync Details
The Sync Details section displays the record details of each account selected.
Record name: Displays the name of the record selected
Active sync: Shows the active status of a sync.
Records Processed: Displays the number of records processed
Duration: Shows the amount of time taken to perform a sync.
Last Run: Displays the last Sync run.
Status: Current sync status information.
For more details, see your Delivery representative.
Repository level trackingFor this type of tracking, certain selections have to be made in the system, as follows:
Account: Refers to the account through which the tracking will be done.
Select Workspace for Bitbucket cloud: By clicking here, a list will display showing all the workspaces that the account above selected is a part of. Select any workspace to get the list of projects and repos in it.
Select Tracking Type: Select
Repository
for Repo level tracking.
Search Project: By clicking here, a list will display with all the projects the account selected is a part of, yet DevOps Intelligence still does not track it. Select a project whose repo is to be tracked.
Search Repository: By clicking here, a list will display all the repos that are part of the selected project and are still not tracked. Then, select any repo that needs to be tracked and select
Configure
.
If the configuration is successful, then the application presents a window containing a table of configuration details.
The Sync Feature scans current data for visibility after configuring credentials periodically. The intervals are set as follows:
The account Sync Interval is set to 5 minutes: Refresh current data.
The account Delete Interval is set to 7 minutes: All deleted accounts updated.
The history pulled Interval is set to 180 days: Data history.
For more details, see your Delivery representative.
Release terminology in service configuration
This section outlines the terminology and format used for managing releases and severity levels in service configurations. It details the structure of release names, patterns for identifying releases, and categorizing severity levels. The content also includes examples and summary tables for quick reference.
Release Format
prefix
signifies the starting sequence of characters for releases, with the default value being
release-
.
variable
signifies the starting sequence of characters for releases, with the default value being empty.
By default, the release format is all starting with the
release-
.
When
syncAll
enables, or in older service configurations, the system uses the default release format.
The release format is applicable to identify the release names in issues and the release branches.
Examples of the patterns identified with the given prefix and variable
Using the specified prefix and variable, the system can match various release patterns. For instance:
For
User Story
fixed release is in which the User Story is done.
For
Bug
fixed release is in which the Bug is Fixed and can be multiple since fixes can be cherrypicked.
By default For Azure Boards, fixed release is identified from the
Iteration Path
which follows just the release format.
Found Releases
For
Bug
found release is in which the Bug is Found, and can be multiple since bugs can be found in old releases.
By default Azure Boards found release is identified from the
Tags
which follows the
found_
+ release formatSummary Table For Default Releases
Severity terminology in service configuration
The severity data from the source is mapped to the specific categories as