...
MettleCI Compliance Rules are delivered as a zip file containing a ready-to-use Local Git repository. This means you can install and run Compliance Rules simply by unzipping the file to your DataStage Engine’s file system, without necessarily requiring a Git server to host a Remote repository. This is a good way to get started quickly with executing Compliance from within the MettleCI Workbench, allowing to you move towards using a Remote repository when you’re ready. In the meantime, the use of a Local repository imposes some limitations:
You shouldn’t use the use the Local repository as a source of Compliance Rules outside of the MettleCI Workbench context. In particular, you shouldn’t attempt to reference a Local repository in your build (CI/CD) pipeline (it’ll work, but it’s not good practice).
The use of a Local Compliance repository does not easily support the collaborative development or maintenance of Compliance rules. For that purpose it is recommended to host your Compliance repository as a Remote Git repository served by a Git server.
For these reasons we recommended you always use Remote Git repositories for managing your Compliance rules.
Creating your Local Repository
You can configure your local repository from your O/S command line. The example below is for
Status | ||||
---|---|---|---|---|
|
Code Block | ||
---|---|---|
| ||
[user@engine mci]$ # Start in your MettleCI home directory (default: /opt/dm/mci/) [user@engine mci]$$> pwd /opt/dm/mci [user@engine mci]$ # SCP/FTP the compliance zip file youfrom downloadedyour from software.mettleci.iodownload media to this directory [user@engine mci]$ ll$> ls -l dm-compliance-rules-59.zip -rw-r--r-- 1 root root 38578 Jan 13 11:41 dm-compliance-rules-59.zip [user@engine mci]$ # Unzip it. This will create a subdirectory /opt/dm/mci/compliance. [user@engine mci]$$> unzip dm-compliance-rules-59.zip Archive: dm-compliance-rules-59.zip creating: compliance/ inflating: compliance/One Dataflow.sjb.grm inflating: compliance/rules.cfg inflating: compliance/Link Sort.pjb.grm inflating: compliance/Range Lookup.pjb.grm creating: compliance/.git/ <SNIP># etc. [user@engine mci]$$> llls total 52648 drwxrwxr-x 6 mciworkb dstage 163 Jan 13 11:05 cli drwxrwxr-x 3 ec2-user dstage 4096 Jan 8 15:59 compliance -rwxrwxrwx 1 mciworkb dstage 282 Jan 10 12:31 datastage-users.yaml <SNIP> [user@engine mci]$ ll-l compliance/ total 128 -rw-rw-r-- 1 ec2-user dstage 1478 Jan 8 15:59 Adjacent Transformers.pjb.grm -rw-rw-r-- 1 ec2-user dstage 3246 Jan 8 15:59 CCMigrateTool Stages.pjb.grm -rw-rw-r-- 1 ec2-user dstage 2227 Jan 8 15:59 CCMigrateTool Stages.sjb.grm <SNIP> [user@engine mci]$# etc. # The compliance directory is a local Git repository of default Compliance Rules [user@engine mci]$> cd compliance [user@engine compliance]$$> git status # On branch master # # Initial commit # # Untracked files: # (use "git add <file>..." to include in what will be committed) # # Adjacent Transformers.pjb.grm # CCMigrateTool Stages.pjb.grm # CCMigrateTool Stages.sjb.grm <SNIP> [user@engine mci]# etc. # You're ready to go! |
Using a Local Repository
...
Next steps are:
# 1. Configure your MettleCI Workbench project(s) to use your Local Repository
# 2. Begin modifying your Compliance repository to meet your team's needs. |
Configuring MettleCI Workbench to use your Local Repository
To set MettleCI to use a local Compliance repository for your DataStage project you just need to point Workbench to the appropriate repository directory. Under your user icon (top right) in Workbench select Manage Projects , edit the settings of the relevant project and for Compliance Repository set the URL field to an appropriate value following the examples below:
file://C:\MettleCI\compliance\.git
Status | ||||
---|---|---|---|---|
|
file:///opt/dm/mci/compliance/.git
Status | ||||
---|---|---|---|---|
|
Note |
---|
Note the three forward slashes after |
In all cases leave the Branch field blank (uses default branch, master
) and the Path field empty.
...
...
See also
When you’re ready to collaborate on Compliance Rule development, or just what to have better governance over your Compliance Rules, you may migrate your Local Git repository to a shared Remote Git repository.