Skip to content

This project aims to automatically upgrade the release version based on git tags and commit messages.

License

Notifications You must be signed in to change notification settings

NeowayLabs/semantic-release

Repository files navigation

semantic-release

This project aims to automatically upgrade the release version based on git tags and commit messages.

semantic

Why

It is a way of programming complexity abstraction. So the programmers do not have to update the release versions manually on CHANGELOG.md, setup.py files, generate and push git tags. This project does this work automatically.

How

Clone this project, generate and push its image:

Generating the image.

make image

Before pushing it to your registry, you must login to the docker registry. Note: Replace [] with the correct credentials and registry DNS.

docker login -u [username] -p [password] [registry.server.com]

Push the image to the registry.

docker push neowaylabs/semantic-release:[version]

Now, you can use it in your CI files.

The semantic release Docker image can be called within a .gitlab-ci.yml file, git hub action, or travis ci Continuous Integration (CI) stage as follows.

stages:
  - semantic-release

semantic-release:
    stage: semantic-release
    variables:
        SEMANTIC_RELEASE_VERSION: latest
    dependencies: []
    except:
        - master
    before_script:
        - docker pull registry.com/dataplatform/semantic-release:$SEMANTIC_RELEASE_VERSION
    script:
        - docker run registry.com/dataplatform/semantic-release:$SEMANTIC_RELEASE_VERSION up -git-host ${CI_SERVER_HOST} -git-group ${CI_PROJECT_NAMESPACE} -git-project ${CI_PROJECT_NAME} -username ${PPD2_USERNAME} -password ${PPD2_ACCESS_TOKEN}

If your project is a Python project you can add the flag -setup-py true to update the release version in this file too.

Note: The version must be placed in a variable called __version__ as follows:

from setuptools import setup, find_packages

__version__ = "1.0.0"
with open("README.md") as description_file:
    readme = description_file.read()

with open("requirements.txt") as requirements_file:
    requirements = [line for line in requirements_file]

setup(
    name="helloworld",
    version=__version__,
    author="dataplatform",
    python_requires=">=3.8.5",
    description="A sample project to test semantic-release automations.",
    long_description=readme,
    url="https://gitlab.com.br/group/py_project",
    install_requires=requirements,
    packages=find_packages(),
)

Adding pre-commit message CLI

The pre-commit will validate your commit messages before the commit being accepted. That will prevent you from having to rebase your commit history to adapt your commit messages to semantic-release standards.

Requirements

Clone pre-commit project and install it in you SO.

git clone git@github.com:NeowayLabs/pre-commit.git
make install

How to use it?

After adding new changes with the git add command, you can run commit . on any git project root path and follow CLI steps.

commit .

How to use rebase to rename commit message?

If the commit lint ci step fail, you can rebase you commit history and fix the wrong commit messages.

With your local repository up to date with your remote branch, run the following command. Note: N is the number of commits you pushed to your branch.

git rebase -i HEAD~N

Edit the document and replace the first word pick to r or reword. Save it with ctrl+o and close it with ctrl+x;

Force push it with -f tag as follows:

git push -f origin my-branch-name

How to add commit lint stage to Gitlab?

You must add a new stage to gitlab-ci.yml file adding two new arguments to semantic-release script.

  • -commit-lint=true to run commit-lint logic;
  • -branch-name=${CI_COMMIT_REF_NAME} so that semantic-release can validate only the commits of the referenced branch.
stages:
  - commit-lint

commit-lint:
    stage: commit-int
    variables:
        SEMANTIC_RELEASE_VERSION: latest
    dependencies: []
    before_script:
        - docker pull registry.com/dataplatform/semantic-release:$SEMANTIC_RELEASE_VERSION
    script:
        - docker run registry.com/dataplatform/semantic-release:$SEMANTIC_RELEASE_VERSION up -commit-lint=true -branch-name=${CI_COMMIT_REF_NAME} -git-host ${CI_SERVER_HOST} -git-group ${CI_PROJECT_NAMESPACE} -git-project ${CI_PROJECT_NAME} -username ${PPD2_USERNAME} -password ${PPD2_ACCESS_TOKEN}

If you need more information about the semantic release CLI usage you can run the following command.

docker run registry.com/group/semantic-release help

If you want to check the commit tags you can use in your commit message run the following command.

docker run registry.com/group/semantic-release help-cmt

So the semantic release can find out the commit type to define the upgrade type (MAJOR, MINOR or PATCH), and the message to write to CHANGELOG.md file, one must follow the commit message pattern bellow:

type(scope?): Commit message here.

I.e.

feat(fibonacci): Added new function to print the Fibonacci sequece.

The scope is optional, so you can also use the fllowing message standard.

type: Commit message here.

I.e.

feat: Added new function to print the Fibonacci sequece.

If you want to complete a Merge Request without triggering the versioning process then you can use the skip type tags as follows.

  • skip

Adding new tests

Add new integration tests if you make a change that needs to interact with a repository. Here are the steps you need to follow to add further integration tests:

  1. Run:
make env

This will run a container with a full GitLab. Wait for GitLab to be accessible through the browser. It can take up to 5 minutes.

Address: https://localhost:443

  1. Run:
make gitlab-restore

This will restore all GitLab repos. After GitLab is accessible again, log in and create the new test scenario.

user: root password: password

  1. Run:
make gitlab-backup

This will create a new backup with all the changes you implemented. A new file will be added to srv/gitlab/backups. Remember to add this new file in a commit and in the MR to able versioning.

Testing

Run:

make check

Open generated coverage on a browser:

make coverage

To perform static analysis:

make static-analysis

Integration Tests

Run the integration tests as soon as the gitlab container is available:

make check-integration

You can manually remove the gitlab container running the following command:

make env-stop

Local Running

You can also run the application locally by running the following commands:

Create a go binary file and run it:

make run-local

Releasing

Run:

make release version=<version>

It will create a git tag with the provided and build and publish a docker image.

Git Hooks

To install the project githooks run:

make githooks

About

This project aims to automatically upgrade the release version based on git tags and commit messages.

Resources

License

Stars

Watchers

Forks

Packages

No packages published