Building with GNU Make inside container.
See native repository for more examples.
Make your own fork of this project for you to develop on.
make clean
make all
make test
Add a Post Build Action
to your job to publish the junit test result.
Add a Post Build Action
to your job to publish the binary.
Now you have made a really nice pipeline in Jenkins just using the normal jobs. Now we want it as code!
First off, we need a new Pipeline
job.
- Click on
New Item
, choosePipeline
type, and give it a name. - Head down to the
Pipeline
section of the job, and click on the "try sample pipeline" and chooseHello world
- Save and Build it.
The result should very well be that you have a blue (successful) build, and in the main view a text saying the following will appear:
This Pipeline has run successfully, but does not define any stages. Please use the stage step to define some stages in this Pipeline.
We have to look into that now, don't we?
In pipeline, we like stages
as they give us the ability to see where in the process things are going wrong.
So take a look at your old build script and transfer the things you did there to the jenkins script.
If you cant remember the syntax for creating stages, then here is the hello world example of it:
pipeline {
agent any
stage ('Hello'){
echo 'Hello World'
}
}
Make three stages that does the following:
Preparation
: Clone the repository from git.Build
: Executesmake all
Test
: Executesmake test
Results
: Make display the results ofout/bin/results_junit.xml
, and archive the generated exe file in theout/bin
folder
Run this to see that it's working. The archiving part can be verified by looking for a small blue arrow next to the build number in the overview. Make sure you get your exe file with you there.
Create a file in your repository called Jenkinsfile
and copy your pipeline script in it.
Change your jenkins job to use the Jenkinsfile insead of the code manually entered in the configuration page. You will need to select Pipeline Script from SCM
in the Definition dropdown menu.
Congratulations, now you have a version controlled pipeline!
Convert your pipeline to Multibranch
Use the native make docker image to build in a docker container. Follow the documentation to run your pipeline in a container.
https://jenkins.io/doc/book/pipeline/docker/#using-multiple-containers
Make your own image for build, share it on docker hub, and use that in your build.
There are gradle build files to package your application. Take a look at build.gradle
and build.properties
. We are using the VersionedBinaryArtifacts plugin to build a versioned zip file of the binary we produce.
If you have docker running locally, you can try running the build like this:
docker run --rm -it -v ~/.m2:/root/.m2 -v $(pwd):/code -w /code praqma/native-gradle ./gradlew publishToMavenLocal
To build with gradle in your fork:
- Change your Jenkinsfile to use the
praqma/native-gradle
docker image in the build. - Change your
artifact
in thebuild.properties
to create a more personal artifact name. - Delete the 'Test' stage of the pipeline. We will now run the tests during build.
- Replace
make all
withgradlew publishToMavenLocal
- Capture the artifact
build/distributions/*.zip
Extra Credit:
- Change the source code to include
version.h
and get the application to report it's version when run.
We have set up a artifactory server on port 8081. Mike will give you a username/password.
To publish the artifact we need to do two steps:
-
Get some publishing secrets in our docker build environment a file
~/.gradle/gradle.properties
docker { image 'praqma/native-gradle' args '-v $HOME/.m2:/home/jenkins/.m2' args '-v $HOME/.gradle:/home/jenkins/.gradle' }
-
Change our gradle task from
publishToMavenLocal
topublish
-
Push these changes and do a build...you should now be able to see your artifact in artifactory.
Try to publish the artifact a second time. It should fail with a message like this:
Execution failed for task ':publishDefaultPubPublicationToMavenRepository'.
> Failed to publish publication 'defaultPub' to repository 'maven'
> Could not write to resource 'http://embedded.praqma.com:8081/artifactory/libs-release-local/net/praqma/embedded-project/1.0.5/embedded-project-1.0.5.zip'.
> Could not PUT 'http://embedded.praqma.com:8081/artifactory/libs-release-local/net/praqma/embedded-project/1.0.5/embedded-project-1.0.5.zip'. Received status code 403 from server: Forbidden
- Add the Version Increment plugin to the
build.gradle
. - Add a stage to bump the version number as a pre-build step. You can get some inspiration from the example repo
Split out the library libmathy
build to it's own pipeline. Consume that in the application build.
- Follow the instructions to set up the git extention here: https://github.com/Praqma/git-phlow
- Set up the issue labels in github using the ghi tool as described here: https://www.praqma.com/stories/a-pragmatic-workflow/
- Run container:
./docker-run.sh
- Build example (inside container):
make all
- Test example (inside container):
make test