GitLab CI

To use GitVersion with GitLab CI, either use the MSBuild Task or put the GitVersion executable in your runner's PATH.

A working example of integrating GitVersion with GitLab is maintained in the project Utterly Automated Versioning

Here is a summary of what it demonstrated (many more details in the Readme)

  • Is a reusable working example known as a Guided Exploration (Guided Exploration Manifesto) - so job logs and package artifacts can be reviewed. The project can also be imported to your own GitLab group or instance as a starting point for your own work.
  • IMPORTANT: It demonstrates how to override GitLab CI's default cloning behavior so that GitVersion can do a dynamic copy. Selectively clones GitVersion.yml so that these settings take effect. This best practice demonstrates the best way to do this while avoiding a double-cloning of the project (once by GitLab Runner and once by GitVersion).
  • Implements GitVersion as a CI/CD Extension that can be reused across many projects using includes.
  • Implements GitVersion as a single job that runs the GitVersion container and passes the version number downstream into both pipeline and job level variables, which means...
  • It can be used with ANY coding language, framework or packaging engine.
  • Generates example packaged artifacts:
  • It creates a Sem Versioned GitLab Release and Git tag using the GitLab Release Cli and links the generic package as evidence.
GitHub