How to get started with Jenkins and GitLab on Windows
If you are really new in this, like me before, I think this guide could help you.
I assume if you are looking for Jenkins, you already know what is Continuous Integration, Continuous Delivery and Continuous Deployment.
But if you don't know yet, don't worry. Here are the definitions:
Continuous Integration. The practice of merging the development work with the main branch constantly so that the code has been tested as often as possible to catch issues early.
The ideal task size is not bigger than a day's work. This way a developer will naturally have at least one integration per day.
Continuous Delivery. Continuous delivery of code to an environment once the code is ready to ship. This could be staging or production. The idea is the product is delivered to a user base, which can be QA's or customers for review and inspection.
Unit test during the Continuous Integration phase can not catch all the bugs and business logic, particularly design issues that is why we need QA, or staging environment for testing.
Continuous Deployment: The deployment or release of code as soon as it's ready. Continuous Deployment requires Continuous Integration and Continuous Delivery otherwise the code quality won't be guarantee in a release.
So, let's move on to the next point.
What is Jenkins? What relationship does Jenkins with the concepts explained lines above?
Jenkins is a Continuous Integration server. Can be used as a simple CI server or turned into the continuous delivery hub for any project. Jenkins helps to automate the non-human part of the software development process, with continuous integration and facilitating technical aspects of continuous delivery.
Enough with the theory.
Let's move on to practice.
1.
Install Jenkins on your machine. (as a service)
Use the official link:
https://jenkins.io/download/
Choose LTS, and Download for Windows.
2. Install the
default plugins (includes Git Plugin). Also, install the
GitLab Plugin
3. Create a SSH Key pair in GitLab. If you already have one, skip this step. If not yet, use the Generate a new ssh key pair guide from GitLab (User Settings > SSH Keys) This put the keys in C:\Users\MY_USER\.ssh\ (id_rsa for the private key and id_rsa.pub for the public key). You must add the public key as a deploy key to your GitLab project and then add the private key as a Jenkins Credential. This is the next step.
4. Create a
credential in Jenkins.
Credentials > System > Add Credentials
Kind: SSH Username with private key
Scope: Global (Jenkins, nodes, items, all child items, etc)
Username: (whatever you want to. Suggest: git)
Private Key: From a file on Jenkins master
File: c:\User\YOUR-USER\ssh\id_rsa
Description: (It is optional)
With this, we are allowing Jenkins to connect to the git host over ssh.
5. Now, we need to setup API Access for Jenkins to get metadata from GitLab.
In GitLab, User Settings > Access Tokens > Add a personal access token.
Copy and save the token because you won't be accessible again.
6. Go Jenkins.
Credentials > System > Add Credentials
Kind: GitLab API token
Scope: Global (Jenkins, ndoes, items, all child items, etc)
API token: (paste here the token)
ID: whatever you want to.
Description: It is optional.
Once the API Access has been setup, we can configure the connection between Jenkins and GitLab. This happens in the Manage Jenkins -> Configure System menu.
In Gitlab section:
Connection name: enter a name.
Gitlab host URL: enter your host.
Credentials: choose the one you just have created
Test Connection, if everything is good, it will show you a Success message.
Now that our connection between Jenkins and GitLab is setup, we need to create a job. You can choose between freestyle jobs or pipeline.
In this guide, we will use a
Multibranch Pipeline. (in my case, it works for me because I use develope, master and stable as branches)
In Jenkins, go
New Item > Enter an item name, then select Multibranch Pipeline. Click OK.
Branch Sources section.
Git
Project Repository: copy and paste the URL from GitLab (SSH)
Credentials: Choose the first one we have created.
Click Save.
It is importart your project has the Jenkinsfile in the root. Configure the Jenkinsfile is another topic. But, just for testing, you can have this:
(make sure to change the yarn comand if your project is not using yarn, it could be npm)
The last step is testing.
Go Jenkins, click the job we have created, then click the branch, click Build with Parameters, click Build and wait for building... you can have two output: failure or success.
That's it!