Drone is a useful Open Source CI Server. You can host the private and dedicate CI environement.
Once you delete or modify the webhooks on the github (enterprise), never reset the setting from Web UI. NOT YET IMPLEMENTED.
But, we have APIs.
First of all, get the api key from https://your.ci.server/account/profile
$ curl -X POST https://your.ci.server/api/repos/github.com/ashphy/baku?access_token=<INSERT YOUR API KEY>
API Reference: http://readme.drone.io/api/repos/post/
Deactivate is also available.
Have you tried open source edition of drone.io?
You can get your own private CI server through the use of the open source edition. It’s really awesome.
Drone provides a lot of docker images
# these two are base images. all Drone images are built on top of these # these are BIG (~3GB) so make sure you have a FAST internet connection docker pull bradrydzewski/ubuntu docker pull bradrydzewski/base # clojure images docker pull bradrydzewski/lein # image: lein ** snip ** # ruby images docker pull bradrydzewski/ruby:2.0.0 # image: ruby2.0.0 docker pull bradrydzewski/ruby:1.9.3 # image: ruby1.9.3 # scala images docker pull bradrydzewski/scala:2.10.3 # image: scala2.10.3 docker pull bradrydzewski/scala:2.9.3 # image: scala2.9.3
However, there are many variations of image, drone supports a custom image.
For example, you can create the custom images what have any distribution, any language, any version, any databases, and any libraries you want to link. It also saves the test time, because drone doesn’t cache the test environment (except cache section on .drone.yml), build all from the scratch each test phase.
This article describe how to create a docker image for drone.
Setup Development Environment
$ git clone https://github.com/drone/drone.git $ cd drone $ vagrant up default $ vagrant ssh default
Take a coffee break to wait for building.
$ vagrant ssh default vagrant@precise64: $ make run
Go http://localhost:8080/install If you see the installation page, drone works fine.
Building custom image from Dockerfile
Put a Dockerfile which is instructions to build an image like this.
This is an exmaple of ruby on CentOS 6
FROM centos:centos6 MAINTAINER Kazuki Hamasaki <firstname.lastname@example.org> WORKDIR /root USER root # packages RUN yum groupinstall -y "Development Tools" RUN yum -y install openssl openssl-devel readline-devel readline libxml2-devel libxslt-devel libyaml-devel zlib zlib-devel git --enablerepo=centosplus # rbenv RUN git clone https://github.com/sstephenson/rbenv.git /usr/local/rbenv RUN git clone https://github.com/sstephenson/ruby-build.git /usr/local/rbenv/plugins/ruby-build ADD rbenv.sh /etc/drone.d/ # ruby install RUN bash -lc 'rbenv install 2.1.2' # bundler RUN bash -lc 'rbenv global 2.1.2; gem install rbenv-rehash' RUN bash -lc 'rbenv global 2.1.2; gem install bundler' RUN bash -lc 'rbenv rehash'
Be aware of the difference of the image conditions between official and unofficial image.
the default user for all official Drone image is the “ubuntu” user, since all build images inherit from the ubuntu cloud ISO
All other images are assumed to use the root user.
You can use the bradrydzewski/base for your base image, but it doesn’t work by this handling of unofficial images.
If you want to run the script before a test, put the script to /etc/drone.d
The drone will kick this. Drone’s shell doesn’t load /etc/profile, .bash_profile, and .bashrc.
I recommend setting the repository name with ‘-t’ option for easy reference.
$ sudo docker build --rm -t ashphy/centos6-ruby:2.1.2 . Sending build context to Docker daemon 75.26 kB Sending build context to Docker daemon Step 0 : FROM ashphy/centos6-ruby:base ---> d793989a9b8a Step 1 : MAINTAINER Kazuki Hamasaki <email@example.com> ---> Using cache ---> 30578dc14bd9 ** snip ** Step 8 : RUN bash -lc 'rbenv rehash' ---> Using cache ---> 491d71171a33 Successfully built 491d71171a33 build success
Got a special image for you.
Testing your image on the drone
Now let’s check your image if it works well on the drone.
Prepare the test repository, you want to test. Set the image name you build at the image section on .drone.yml file like below.
image: ashphy/centos6-ruby:2.1.2 script: - bundle install - rspec
Test on the drone with following command.
$ /opt/go/src/github.com/drone/drone/bin/drone build .
Uploading your image to the docker hub
If the image specified by .drone.yml is missing, drone will do ‘docker pull’, This means that the image will be downloaded from docker hub.
So that your private image that cannot be upload to public is needed to build on the drone server.
Please register in advance at https://registry.hub.docker.com/.
$ sudo docker publish ashphy/centos6-ruby
CentOS6 + ruby image
I hope you find it informative.
I modified pubsubhubbub implementation. No longer original impl does not work, because it has no update from 2011.
My forked impl will works fine with Python 2.7 and Google App Engine for Python 1.8.9.
I’m unfamiliar with Python and GAE. Any improvements are welcome.
How to Run the servers
$ git clone https://code.google.com/p/pubsubhubbub/
$ dev_appserver.py hub
$ dev_appserver.py --port=8081 --admin_port=8001 publisher
$ dev_appserver.py --port=8082 --admin_port=8002 subscriber
I’ve tried to create a mail handler for GAE/J using java.util.logging in order to receive the notification of system error via email.
See the code: https://gist.github.com/ashphy/6977360
I encountered some problems, for example, custom handler could not be instantiated from properties file.
Are there any good ideas for implementation?
If you see error like this on Vagrant 1.2.2 and VirtualBox 4.2.14, when you do ‘vagrant up’
C:\Users\kazuki-h>vagrant up Bringing machine 'default' up with 'virtualbox' provider... [default] Importing base box 'hogehoge'... There was an error while executing `VBoxManage`, a CLI used by Vagrant for controlling VirtualBox. The command and stderr is shown below. Command: ["import", "C:/Users/kazuki-h/.vagrant.d/boxes/hogehoge/virtualbox/box.ovf"] Stderr: 0%...10%...20%...30%...40%...50%...60%...70%...80%...90%...100% Interpreting C:\Users\kazuki-h\.vagrant.d\boxes\hogehoge\virtualbox\box.ovf... OK. 0%... Progress object failure: RPC_S_SERVER_UNAVAILABLE 0x800706BA
This problem has been fixed in the version 4.2.16.