Skip to main content
Blog
Home/

Engineering fundamentals: Why you need a build pipeline

Author Nima Poulad
Nima PouladSenior Developer Advocate
Summary4 min read

Get insights on how to implement build pipelines on your project repos from Nima Poulad.

          • Additional resources

          Table of contents

          Engineering fundamentals are proven methods that lead to better code. Some of these methods are known more than others. When talking about engineering fundamentals, the first concepts that come to mind are unit tests, code coverage, linting, and CI. However, little is spoken about a build pipeline and what are some of the requirements that make a build pipeline more effective.

          Here at Docusign, we have a long list of public Git repositories where we keep our code samples, SDKs, and our open source libraries. We rely on these engineering fundamentals to make sure our code remains high-quality as new contributions to our repositories come in. The concept of having good build pipelines is of utmost importance to us.

          Let’s take a step back and understand what we mean by a build pipeline. A typical testing and delivery pipeline is composed of the following three pipelines:

          • Build: The build pipeline is responsible for testing any new changes that are introduced. Every time a new Pull Request is created against the develop branch, the pipeline is triggered on that change and runs tests. This build does not retain any of the build artifacts.

          • Continuous Integration (CI): This pipeline runs on master every time a new change is merged to master. The goal of the pipelines is to create artifacts for every new change on master and create the snapshots. It will also run tests (integration and E2E testing) to ensure the new change hasn’t caused a regression.

          • Continuous Delivery (CD): This pipeline is responsible for deploying the artifacts created at the CI stage to testing and integration and production environments.

          But not all build pipelines are created equal, and in this article, I am going to call out a few practices that will make your pipeline more effective at its job.

          • Treat warnings as errors in the dependency install stage: You may have seen the following dreaded security message in your repositories in the past. It occurs when one of the dependencies you’re referencing has a known security issue in it. It may happen weeks after you’re done writing the code. Always create your build pipelines to treat warnings as errors at the install stage and have your build pipeline run on a daily schedule in addition to new PRs to catch this class of issues.

          GitHub security vulnerability warning
          •  Don’t allow merging on failed builds: This one is obvious. However, what qualifies as a failed build is the topic of discussion here. Many assume a failed build just means a compilation error; however, here I am going to argue it should be way more. The build should fail if:

            • Any of the unit tests fail. This is rather obvious.

            • The linter finds any violation in coding style or static analysis stage

            • The introduced change reduces the code coverage below a certain percentage. It’s important to set a code coverage goal for a project. We all know that having even 100% code coverage doesn’t mean tested code, however having a 10% code coverage should raise some flags. The best way to prevent ending with a low code coverage in your project is to enforce it every time a new change is introduced. A build pipeline is the perfect place for this enforcement. If the change drops the targeted code coverage by a large margin, the build pipeline should fail and thereafter prevent the poorly tested code from getting through to master.

            • Require multiple sign-offs on every PR. The more developers who review the code, the better it is. Not only are more issues found, it also helps with cross-pollination and ensuring everyone remains up to speed with new changes introduced. One way to ensure multiple code reviewers look at every PR is to set it in the pipeline policy.

          In this blog, I’ve focused on the concepts instead of a specific tool or product to make it applicable to everyone. Most major DevOps tools (Azure DevOps, Jenkins, and more) support all the concepts that I’ve called out here.

          What are some of the other policies in a build pipeline that you’ve found useful? We would love to hear your thoughts and comments.

          Additional resources

          Author Nima Poulad
          Nima PouladSenior Developer Advocate

          Nima Poulad is a Senior Developer Advocate at Docusign. He has years of experience in the industry as a software developer and as an advocate. He enjoys meeting the members of developer community and passionate about sharing what he knows with others.

          Find him on Twitter: @NimaPoulad or LinkedIn.

          More posts from this author

          Related posts

          • Docusign for Developers Public Roadmap: A commitment to innovation and trust
            Developers

            Docusign for Developers Public Roadmap: A commitment to innovation and trust

            Author Julian Macagno
            Julian Macagno
          • LaborEdge Streamlines Healthcare Compliance with a Healthy Dose of Docusign

            LaborEdge Streamlines Healthcare Compliance with a Healthy Dose of Docusign

            Author Karissa Jacobsen
            Karissa Jacobsen
          • Ontology vs Taxonomy vs Data Model

            Ontology vs Taxonomy vs Data Model

            Author Dan Selman
            Dan Selman
          Docusign for Developers Public Roadmap: A commitment to innovation and trust

          Docusign for Developers Public Roadmap: A commitment to innovation and trust

          Author Julian Macagno
          Julian Macagno
          LaborEdge Streamlines Healthcare Compliance with a Healthy Dose of Docusign

          LaborEdge Streamlines Healthcare Compliance with a Healthy Dose of Docusign

          Author Karissa Jacobsen
          Karissa Jacobsen
          Ontology vs Taxonomy vs Data Model

          Ontology vs Taxonomy vs Data Model

          Author Dan Selman
          Dan Selman

          Discover what's new with Docusign IAM or start with eSignature for free

          Explore Docusign IAMTry eSignature for Free
          Person smiling while presenting