Article

Here’s why you should be using bitbucket pipelines

BitBucketPipelinesHero

Commonly, developer workflows include pushing code to BitBucket. From there, you run processes like testing, updating a staging server, and generating documentation. All of these processes can become very repetitive. Thankfully, they can also be automated. That’s where Bitbucket Pipelines comes in.

It’s simple – you only have to create a set of scripts that run right after you make a push to Bitbucket.

How Does a BitBucket Pipeline Work?

Here’s a quick summary:

1) A Linux virtual machine is created with a Docker configuration

2) Your source code is copied to the virtual machine

3) Your scripts are run from a bitbucket-pipelines.yml file

Here is a very basic example of the bitbucket-pipelines.yml file located in the root of the repository:

Pipelines displays the result of running those scripts, which is particularly great because of how easy it is to monitor success.

Here is an example of a successful end-to-end test process:

And, here is a failure:

Easy-to-read visual displays help us make sure that our processes are on the right track. Delivery progress can be monitored at a glance, so that we can quickly address errors as they pop up.

Any Command Line Can Be Used in Pipelines

Here at Fresh, we use Pipelines to automate processes like:

  • Push build to Staging and Production Servers
  • Notify Slack or Email about test results

You can also run processes that require authentication against third-party services. For those cases, environmental variables are stored securely on BitBucket settings, keeping your repository free of hard-coded usernames and passwords.

Is it Worth the Effort?

Definitely!!!

Using Pipelines will save you hundreds of hours of time. It keeps developers synchronized about test results, documentation, and latest builds. Plus, you can integrate it with many other command line tools to improve productivity.

We highly recommend using BitBucket Pipelines in your workflow.

Xavier-Reyes-Default-BW-e1528872498681_optimize.jpg

Xavier Reyes

Sr. Full Stack Developer

Xavier is a Sr. Full Stack Developer I with full-stack and JavaScript skills. Born and raised in Ecuador, Xavier completed an environmental engineering program and previously worked as a Visual Data Specialist at Google Maps using code to manipulate geographic data.

Prior to joining Fresh, he freelanced for Killer Infographics and Enter the Studio where he built many interactive sites for clients like Nintendo, Starbucks, and Sesame Street.

Knowledgeable in responsive front-end, back-end, hybrid mobile, and desktop development, some of Xavier’s go-to tools are ES6, CSS3, HTML5, Sass, Node.js, Express, Gulp, Angular, React, MongoDB, D3, GSAP, Typescript, Photoshop, and Illustrator. He has worked directly with graphic designers and program managers in all stages of production, including brainstorming, prototyping, developing, and deploying fully functional websites and apps. He really enjoys learning, implementing new technologies, and completing projects while collaborating with talented people.