Source control integration in ServiceNow Studio
Summarize
Summary of Source Control Integration in ServiceNow Studio
The source control integration in ServiceNow Studio allows application developers to connect their applications to a Git repository, enabling version control and collaborative development for global or scoped applications in non-production instances. This integration facilitates the management of application versions and changes effectively.
Show less
Key Features
- Import Applications: Developers can import applications directly from a Git repository.
- Remote Changes: Pull and apply updates from a remote Git repository.
- Commit Changes: Save local modifications by committing them to the Git repository.
- Versioning: Create tags for specific application versions and branches for managing multiple versions.
- Studio Management: Utilize ServiceNow Studio to manage repository settings, edit credentials, and switch branches.
Integration Requirements
- Admin role is required for users linking applications to source control.
- Non-production instances need network access to the Git repository.
- Each application should have its own dedicated Git repository.
- Repository credentials must provide read and write access.
Key Outcomes
By integrating source control, developers can enhance collaboration and track changes efficiently. However, note that this feature is not available for production instances; alternative management methods include using the application repository, update sets, or ServiceNow Studio. Additionally, the integration includes a validation and sanitization process to ensure the integrity of application files during operations.
Enable application developers to integrate with a Git source control repository. Save and manage multiple versions of a global or scoped application from a non-production instance.
- Import applications from a Git repository.
- Pull and apply remote changes from a Git repository.
- Commit all local changes on the instance to a Git repository.
- Create tags to permanently link to a given version of an application.
- Create branches to maintain multiple versions of an application simultaneously.
Integration requirements
- The user must have the admin role.
- The non-production instance must have network access to the Git repository.
- Each application must be within its own Git repository.
- The repository user credentials must grant read and write access.
Options available from ServiceNow Studio
- Edit the application repository credentials.
- Commit all local changes on the instance.
- Apply remote changes from the repository.
- Create a branch.
- Switch branches.
- Import an application from a remote repository.
Source control integration does not support managing applications on a production instance. Instead, you can manage applications on a production instance using the application repository, an update set, or ServiceNow Studio. For more information about managing applications on a production instance, see Application sharing.
Options available from a Git repository
- Move application files to a different Git directory structure.
- Edit application files outside of ServiceNow Studio.
The system generates a properties text file called sn_source_control.properties at the root level of the repository. To move application files to a different Git directory structure, application developers can
set the path parameter to specify the subfolder path containing their application files. For example, if you moved your application to the src/app subfolder, set the
path to path=src/app.
- Creates upgrade log entries for each sanitization action taken.
- Removes unsupported folders and files from the repository.
- Aborts all source control operations when a system application file fails XML schema validation. For example, if a database dictionary record fails XML schema validation, the system aborts all operations.
- Skips the current source control operation when a non-system application file fails XML schema validation.
The Git integration sanitizes only content within the application path listed in the sn_source_control.properties file. Repository content outside the application path is ignored.
MID Server support
Use an existing MID Server to connect to a source control repository. Connecting an application through a MID Server enables access to repositories behind a firewall.
Source control role permissions
For more information on roles and collaborators, see Application collaboration.