This is the first of a sponsored two part series on Codeship, the secure, cloud-based continuous integration and delivery service.
What's Codeship?
Codeship is a hosted continuous delivery service that focuses on speed, reliability and simplicity. You configure Codeship to build and deploy your application from GitHub to the staging or the production platform of your choice.
The service offers a variety of powerful setup options. Currently, Codeship is integrated with popular source code managers GitHub and Bitbucket. It supports a variety of programming languages (Ruby on Rails, Node.js, PHP, Java, Go, Dart, etc.) and deployment platforms (Amazon Web Services, Heroku, Google App Engine, etc.)
The practice of continuous integration involves repeated automated testing and code merging with notifications to alert developers to problems in their code in real time. Codeship combines this with the practice of continuous delivery, which provides for regular code deployment once changes have passed automated tests.
Essentially, when you push your code to GitHub (or Bitbucket), Codeship rebuilds your application on its secure servers and runs your automated tests. If the tests fail, it notifies your development team via email or integration with popular services such as Slack, HipChat, etc. If your tests pass, Codeship follows your defined pipeline to move code to staging or production servers as specified.
data:image/s3,"s3://crabby-images/184b6/184b607968c2ce54d70afdd86e2a0a4a27e70f58" alt="Codeship From Your Developers to Your Customers"
Working with a service like Codeship can minimize fallout from bugs, speed their detection, and make your team more comfortable and proficient in releasing regular incremental improvements to your platform—hopefully improving your responsiveness to your customers and your market.
Codeship helps your team write and deploy their code with increased confidence. And, the Codeship Blog helps you come up to speed and keep up with best practices. The team has also published a piece on continuous integration essentials which you can read on their site, as well.
In this tutorial, I'll walk you through the Codeship product, detailing how to get started. In the next episode, I'm going to detail Codeship's deployment capabilities and their newly released feature ParallelCI, which lets you speed your test suites by running them in parallel.
data:image/s3,"s3://crabby-images/d3497/d3497a7a8d57ed901889fb67e3765d0225aab230" alt="Codeship Arto Vuori Usetrace Testimonial"
Just as a reminder, I do participate in the discussions below. If you have a question or topic suggestion, please post a comment below. You can also reach me on Twitter @reifman or email me directly.
Codeship Pricing
Codeship's free plan allows 100 builds per month and five private projects. Unlimited builds and projects begin at $49 per month. Yearly plans give you two months free.
data:image/s3,"s3://crabby-images/fd03c/fd03c8bdace157f533fc427994174c7ef35d50d4" alt="Codeship Pricing"
Nicely, educational projects receive a 50% discount, and open source projects can use Codeship for free.
If you scroll down to the very bottom of the pricing page, you can click Codeship's hilarious "outrageously huge call to action button" to sign up:
data:image/s3,"s3://crabby-images/105cd/105cd26be78c5904658aece9609653bf521ed564" alt="Codeship Sign Up with Outrageously Huge Action Button"
It's nice that they have a good sense of humor.
Learning More About Codeship's Continuous Delivery
When you sign up, you can add yourself to Codeship's five-day email-based crash course which introduces you to the basic concepts of continuous integration and delivery:
data:image/s3,"s3://crabby-images/1e81e/1e81e1779bca1c6bf0272a8b8b1e471dcded78a2" alt="Codeship Continuous Delivery Email Course"
Here's an example of the first email lesson:
data:image/s3,"s3://crabby-images/f2ec3/f2ec32c43b3dbc2ecaaa2dc0ff606cee7cb5eb6f" alt="Codeship Continuous Delivery Email Course Part One"
You can also sign up for their excellent eBook: Efficiency in Development Workflows. Be sure also to follow the Codeship Blog.
Securing Your Code
Codeship takes security seriously. For every project you add to Codeship, they create a unique SSH Key that is itself encrypted strongly and only decrypted shortly before being used in the build virtual machine. For every build, they start a new and clean virtual machine. All the changes you make (including file system changes) are stored in a ramdisk which is removed as soon as your build finishes (tests and deployment). None of your data is ever stored on any hard drive on their build servers.
All communication between your browser and the Codeship website is SSL encrypted, as is all communication to their openredis queue. All communication to the build virtual machines is done over SSH.
Codeship will never read your code if not explicitly requested by you. This might happen in the case of a support request or if you want something debugged by their engineers. In no other case will they look at what belongs to you—your code. Only full-time Codeship employees ever participate in this support activity—it's never outsourced.
You can read more about their security processes on their website.
Getting Started With Codeship
Registration and Authentication
You can sign up with Codeship using email or your GitHub or Bitbucket account via OAuth:
data:image/s3,"s3://crabby-images/14dc3/14dc3a0c360b3d1c4d9ebc0e38b792ceb723c6c4" alt="Codeship Sign Up"
If you use GitHub or Bitbucket, you'll be asked to verify access to your account:
data:image/s3,"s3://crabby-images/9f7dc/9f7dc7d4772da61fa9809331f1bc632a097eaabc" alt="Codeship Authorize with Github"
Once authorized, you'll return to the Codeship dashboard and projects page. It's time to add our first project:
data:image/s3,"s3://crabby-images/8e9c8/8e9c8d91b2a1aaf1d7767c0d8d8ee377492fa2a3" alt="Codeship Dashboard and Project Listing"
Create Your First Project
To run your automated tests, Codeship needs to check out your code from your source code provider. Currently they support GitHub and Bitbucket, and others are planned.
Anytime you need, you can revoke permission in your source code provider's Settings, and can remove Codeship's deploy keys and service hooks from your projects' configuration pages.
The idea behind Codeship is to take code from your developers' commits to your source code manager and run your automated tests in the secure Codeship cloud. If your tests pass, Codeship continues with your deployment instructions. If they fail, notifications are sent to your team via email or communication services such as Slack and HipChat.
data:image/s3,"s3://crabby-images/bbfee/bbfee2339ce7ed1f286b23f9378acb21ea442ce4" alt="Codeship Example Codeship pipeline"
Connect Your Source Code Manager
data:image/s3,"s3://crabby-images/a17cb/a17cbe4a343e604983237e1ebf1804380cd4f3d0" alt="Codeship Connect Your Source Code Manager"
For this tutorial, I've forked the Yii2 Framework codebase for PHP, which includes a variety of automated tests. Codeship supports a variety of programming languages, e.g. Ruby on Rails, Node.js, PHP, Java, Go, Dart, etc.
Codeship loads my repositories from GitHub and I just select Yii2:
data:image/s3,"s3://crabby-images/e0750/e07508e3a373776c7dccc436bc7b9f1bcc633f60" alt="Codeship Choose A Repository"
Then it will ask me to choose my platform technology and set up test commands.
data:image/s3,"s3://crabby-images/a0f97/a0f97aa268c83b1b4f4426bc0fe31cfae2aaba50" alt="Codeship Select Your Technology"
You can configure Codeship at a very deep level, from simple needs to sophisticated enterprise level build processes:
data:image/s3,"s3://crabby-images/cac47/cac479f683741938197a306afd4f2032ce4dcb58" alt="Codeship Setup Your Build Commands"
For demonstration purposes, I'll add phpunit tests for Yii2's base functionality:
data:image/s3,"s3://crabby-images/2272a/2272af8acd8e7a7cd8f2599f3947f384636cb37a" alt="Codeship Adding My Unit Testing"
In other words, whenever I push updates to my GitHub (or Bitbucket) repository, Codeship will run phpunit tests for me.
data:image/s3,"s3://crabby-images/3a981/3a9815d68bca41ab8437b82d2b32d3a4c852e606" alt="Codeship Treehouse Customer Testimonial"
Here's what the Codeship project page looks like once this has been configured:
data:image/s3,"s3://crabby-images/5b76c/5b76c055ad795b11cf1452e58b3746cc7ea1ff9a" alt="Codeship Push Your Repository to Trigger Your First Build"
Next, I'll trigger a build by pushing a small update to my repository. Watch as Codeship begins to build my code...
data:image/s3,"s3://crabby-images/389e7/389e7e56695d1a5bc639a8da42ef1dca170fe9d0" alt="Codeship Build in progress"
... and then proceeds to run my unit tests:
data:image/s3,"s3://crabby-images/9f513/9f513fa02d0c9a649a622a6bd98f3a9f86531015" alt="Codeship Automated tests in progress"
When it's done, you can see a complete report of all the steps and whether the tests passed or failed.
data:image/s3,"s3://crabby-images/46667/4666734b9802d2e9cf5accf644d707f0e9eab462" alt="Codeship Build complete and successful"
Codeship maintains a complete build log for every project:
data:image/s3,"s3://crabby-images/c16ca/c16ca6e2486d86e30a40b3667764a404e957992a" alt="Codeship Build Log"
Deployment Pipelines
You can choose what Codeship does with your code after your tests pass. For example, perhaps you update your staging server for further tests, or perhaps you roll everything out to your production servers. Codeship allows you to define sophisticated pipelines for testing and deployment.
data:image/s3,"s3://crabby-images/2fa22/2fa22c93d41ac968336ab2a71fae54f3550a0c7f" alt="Codeship Example of Deployment Pipelines"
Here's a detailed view of the Project Settings menu:
data:image/s3,"s3://crabby-images/b88cd/b88cdc9e387affa3580005656bf7fa9a8e0628b0" alt="Codeship Project Settings Menu"
Here's a look at the General settings for your project UUID, and the SSH public key for automated deployments:
data:image/s3,"s3://crabby-images/053a1/053a1c76d9499179400a5137d464b6c0d39c2f9f" alt="Codeship General Project Settings"
Notifications
You can configure notifications for Codeship activities, e.g. build errors. These can go through APIs or a variety of third party services, e.g. Slack, Campfire, HipChat, etc.:
data:image/s3,"s3://crabby-images/4f5e7/4f5e7702e8c979eb1ab4d811599776082e6f6cfc" alt="Codeship Collaborators for Notifications"
There is also a free Chrome extension for Codeship build notifications called Shipscope.
And you can add a Codeship Badge to your repository readme to show the stability of specific commits, so that your GitHub (or Bitbucket) and website visitors can see in real time whether a specific release has passed its automated tests.
data:image/s3,"s3://crabby-images/01834/01834bde7273c0e143000b042239f08118a754e2" alt="Codeship Add a Build Status Badge to Your Repository"
Codeship makes it easy to add your team to your projects.
data:image/s3,"s3://crabby-images/48b4e/48b4e52605b1b36782844f96ad600c68611712bb" alt="Codeship Collaborate with your developers"
Configure Your Deployments
Codeship provides ready-built deployment integration with many popular hosting solutions including Google AppEngine, Amazon Web Services Code Deploy, Heroku, Engine Yard, Nodejitsu and more.
data:image/s3,"s3://crabby-images/e1fc6/e1fc6ef0f4a44c3cf0a59e781a105a2c35e87b94" alt="Codeship Configure Your Deployments"
I'm going to delve into more detail of the deployment process in the next episode. For now, you can review Codeship's tutorials for various platforms.
They have a wide range of documentation for Continuous Deployment options:
data:image/s3,"s3://crabby-images/674a8/674a87200b60a83d8eeeba79849ff4f48ac0019c" alt="Codeship Continuous Deployment Documentation"
Here's a short guide on how to deploy a Ruby on Rails app from GitHub to Heroku, and the video is below. Codeship offers a number of video guides on their Vimeo channel.
What's Next?
In the next tutorial, I'll delve more into deploying with Codeship and its new ParallelCI feature, which lets you speed your test suites by running them in parallel.
data:image/s3,"s3://crabby-images/173f8/173f8d93ac46bb9256a1dc88529822d401534219" alt="Codeship Customer testimonial preview of ParallelCI - Bannerman"
Please feel free to post your questions and comments below. You can also reach me on Twitter @reifman or email me directly. You can also browse my Tuts+ instructor page to see other tutorials I've written.
Comments