Skip to content

adaptivelab/jenkins-build

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Jenkins job builder

Some templates for creating jenkins jobs via puppet jobs builder

Install the actual jenkins-job-builder command itself with:

pip install jenkins-job-builder

jenkins-jobs-builder expects a config file to provide the user credentials; the jenkins servers don't actually use auth at this point but the file needs to exist anyway and so we use jenkins_jobs.ini with dummy values.

To convert a template file into the xml format as expected by the jenkins api:

jenkins-jobs --conf jenkins_jobs.ini test -o jenkouts .

To create/update a job on jenkins:

jenkins-jobs --conf jenkins_jobs.ini update template.yaml

For jenkins to be able to fetch the code from github, you will also need to ensure the repo in question is added to the adaptivelab-jenkins team: https://github.com/organizations/adaptivelab/teams/295580

jenkins-job-builder creates a cache of jobs it has seen in order to prevent needless api requests but the caching key only takes into consideration the content of the template file and not what server the job was built on. This means that when a new jenkins server is built any previosly run and cached jobs will not be executed again. The simple fix is to simply remove the cache file:

rm ~/.jenkins_jobs_cache.yml

Publishing to a git repo

If you want one of your jobs to publish to heroku (for example), you will need to add the git publisher manually, until someone writes a git publisher handler for the Jenkins job builder. Here's how:

  1. Set up the extra git repos by adding them to the yaml template as normal.
  2. Update the jenkins job(s)
  3. Log in to Jenkins and configure your project. Add a Git Publisher to the Post Build actions and configure according to your needs.

Building a project

The jenkins templates are written to expect a jenkins.sh file in the root of the workspace that will be used to execute the build commands. An example can be seen in gepetto or caiman.

Configuring a Project

To add new python jobs you can simply add a new project section to template.yaml and update the name and giturl fields to appropriate values. Adding jobs for other languages/platforms for where the pep8 and pylint plugins are not applicable would require some investigation.

Puppetmaster

Building a jenkins server consists of three parts, this jenkins job builder for managing jobs, gepetto for spinning up the ci servers and adaptivelab/puppet for provisioning the puppet servers.

To go from 0 to running ci server:

pip install git+https://github.com/adaptivelab/gepetto@develop
python -m gepetto.up

Gepetto will have created a new instance with puppet installed that will perform some bootstrapping and attempt to connect to the puppetmaster. The puppetmaster is no more however and so we need to create one. For now we can create a puppetmaster on the same ci server:

# somehow ascertain the address of the newly created gepetto server
git clone https://github.com/adaptivelab/puppet
scp -r puppet ubuntu@gepettoserver:~/
ssh ubuntu@gepettoserver
cd puppet

# apply the puppetmaster config. this creates a puppetmaster that accepts
# and signs all requests so it's important that random servers are not
# allowed to connect
sudo puppet apply --modulepath=modules -e "include puppetmaster"

# if you're interested in the output you can stop the previously installed
# puppet agent and run it in the foreground to see what happens. This will
# setup the current instance with the requirements to run as our ci
# server.
#
# Left to its own devices the agent should connect to the master but this
# is untested and relies on correctly setup hostnames (gepetto's bootstrap
# *did* correctly set the hosts at one point but the network architecture
# has changed now) so manual running might be best for now
sudo service puppet stop
sudo puppet agent --verbose  --logdest console --no-daemonize --server=$(hostname)
sudo service puppet start

The unscriptable part:

sudo su jenkins
ssh-keygen

Copy the contents of /var/lib/jenkins/.ssh/id_rsa.pub and add a new ssh key for the admin+githubjenkins user on github

You can now see jenkins running on port 8080 in your browser but there are no jobs. Update jenkins_jobs.ini with the new url, delete ~/.jenkins_jobs_cache.yml if it exists and run the commands from above to create some new jobs

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •