Continuous Integration with Openshift Pipelines
30 MINUTE EXERCISE
In this lab you will learn about deployment pipelines and you will create a pipeline to automate the build of the Inventory service.
Create a Git Repository for Inventory Code
The first step is to create a Git repository to store your source code. You can use any Git server (e.g. GitHub, BitBucket, etc). For this lab we will use a Gitea git server.
Click on the 'Developer Repository' button below
Then, click on 'Sign In' and login via OpenShift as user%USER_ID%/%OPENSHIFT_PASSWORD%
data:image/s3,"s3://crabby-images/bf03c/bf03cc87d15b41331a9d57cb6a95e8c5597dea29" alt="Sign Up Gitea"
Create a new repository called 'inventory-quarkus'.
Click on the '+' icon → '+ New Repository'
as below and enter the following values:
data:image/s3,"s3://crabby-images/b74e1/b74e1f77b99c69fc18a76aaf837622d0207ccd31" alt="Create New Repository"
Parameter | Value |
---|---|
Repository Name* |
inventory-quarkus |
Click on 'Create Repository' button
.
The Git repository is created now.
Push Inventory Code to the Git Repository
Now that you have a Git repository for the Inventory service, you should push your local source code into this Git repository.
Click on 'Terminal' → 'Run Task…' → 'Inventory - Commit'
data:image/s3,"s3://crabby-images/fe302/fe3024bad4deec01a7c6a6c7e9b7d57ce774d7cd" alt="Che - RunTask"
Execute the following commands in the '>_ workshop_tools' terminal window
cd /projects/workshop/labs/inventory-quarkus
git init
git remote add origin http://gitea-server.gitea.svc:3000/user%USER_ID%/inventory-quarkus.git
git add *
git commit -m "Initial"
git push http://user%USER_ID%:openshift@gitea-server.gitea.svc:3000/user%USER_ID%/inventory-quarkus.git
To open a '>_ workshop_tools' terminal window, click on 'Terminal' → 'Open Terminal in specific container' → 'workshop-tools'
|
The output should be as follows:
Initialized empty Git repository in /projects/workshop/labs/inventory-quarkus/.git/
[master (root-commit) f7b9db7] Initial
12 files changed, 831 insertions(+)
[...]
Enumerating objects: 29, done.
Counting objects: 100% (29/29), done.
Delta compression using up to 16 threads.
Compressing objects: 100% (20/20), done.
Writing objects: 100% (29/29), 10.76 KiB | 3.59 MiB/s, done.
Total 29 (delta 1), reused 0 (delta 0)
remote: . Processing 1 references
remote: Processed 1 references in total
To http://gitea-server.gitea.svc:3000/user%USER_ID%/inventory-quarkus.git
* [new branch] master -> master
Once done, in your Git Repository, refresh the page of your 'inventory-quarkus' repository
. You should
see the project files in the repository.
data:image/s3,"s3://crabby-images/ab12a/ab12ac6bf96d64b608129686be78b1cf1b41dcb6" alt="Inventory Repository"
Switch to the Staging Environment
First, let’s switch your OpenShift Console to your Staging Environement i.e 'cn-project%USER_ID%'.
In the OpenShift Web Console, from the Developer view,
click on 'Topology' then select your 'cn-project%USER_ID%'
.
data:image/s3,"s3://crabby-images/06673/06673853d285d372352f1bf1ff3c6aecd3b7ac81" alt="OpenShift - Staging Project"
Create a Pipeline
A Pipeline defines a number of Task that should be executed and how they interact with each other via Workspace. Let’s define and configure these different components.
In the OpenShift Web Console, from the Developer view,
click on 'Pipelines' → 'Create Pipeline'
.
data:image/s3,"s3://crabby-images/593ac/593acf637cf0809cc8296bb9205e12b31a90abf3" alt="OpenShift - Create Pipeline"
In the "Pipeline Builder" page, specify 'inventory-pipeline' as Name
data:image/s3,"s3://crabby-images/76fae/76fae147a5f24af685d0ee89272113b22f31a3d3" alt="OpenShift - Pipeline Name"
Scroll down to the 'Workspaces' section and define a Workspace called 'shared-workspace'
data:image/s3,"s3://crabby-images/ea66a/ea66a2d8392d8464052e1d9b9abc019db5d7454d" alt="OpenShift - Pipeline Workspace"
Scroll up to the 'Tasks' section then click Add task.
data:image/s3,"s3://crabby-images/5f3a3/5f3a3892838d49e32af0b59ee8d58a132e8afbe1" alt="OpenShift - Add task"
Start typing 'git-' next to the (+) and select 'git-clone'
.
There are several options to choose from, look out for the Red Hat one. Then hit Add.
data:image/s3,"s3://crabby-images/2a418/2a41813ffd6093189d9a877415648a7f79d7fc96" alt="OpenShift - Add Git Clone Task"
Click on the newly created 'git-clone' task and enter the following configuration
:
Parameter | Value |
---|---|
Display Name |
git-clone |
url |
http://gitea-server.gitea.svc:3000/user%USER_ID%/inventory-quarkus.git |
Workspaces output |
shared-workspace |
Once done, let’s add another task. Click on the blue plus icon at the right hand side of the 'git-clone' task
data:image/s3,"s3://crabby-images/42d3d/42d3dae59e4d142733fa9ab520d06f3cd61879af" alt="OpenShift - Add task"
Then click on 'Add task'
and as before next to the (+) type 's2i-java'
When you see the Red Hat one select and add the 's2i-java' task
Click on the newly created 's2i-java' task and enter the following configuration
:
Parameter | Value |
---|---|
Display Name |
s2i-java |
TLSVERIFY |
false |
MAVEN_MIRROR_URL |
http://nexus.opentlc-shared.svc:8081/repository/maven-all-public |
Image* |
image-registry.openshift-image-registry.svc:5000/cn-project%USER_ID%/inventory-coolstore |
Workspaces source |
shared-workspace |
Once done, click on 'Create'
. Your simple Pipeline is now created.
data:image/s3,"s3://crabby-images/46ba1/46ba18af4c91974a90980fb6e72adaeb8d1118d5" alt="OpenShift - CI Pipeline"
Run the Pipeline
Now that your pipeline is created and configured, let’s run it.
In the OpenShift Web Console, from the Developer view,
click on 'Pipelines' → 'PL inventory-pipeline' → 'Actions' → 'Start'
data:image/s3,"s3://crabby-images/fc397/fc3970d0970017a16f406a2c9d25954f9cac90e1" alt="OpenShift Start Inventory Pipeline"
Enter the following parameters then click on 'Start'
Name | Value |
---|---|
shared-workspace |
VolumeClaimTemplate |
data:image/s3,"s3://crabby-images/bac23/bac236e8e5f420e3a76dc0200ee5351883cf2543" alt="OpenShift Inventory Pipeline Parameters"
Congratulations!! You have created and run your first CI Pipeline on OpenShift!!
data:image/s3,"s3://crabby-images/4c3d7/4c3d7ebc6b8878eb3c36efabac5aad8a4a3f37f3" alt="OpenShift Inventory Pipeline Run"
Well done! You are ready for the next lab.