Using Continuous Delivery As A Code Implementation Method (original) (raw)

Oleh Svet, Chief Delivery Officer at Computools.

getty

What is continuous delivery?

Continuous delivery (CD) is a digital product development practice where code is automatically built, continuously delivered and deployed. All modifications are deployed in a testing or working environment. This practice allows programmers to permanently keep a finished copy available, having gone through standard procedures, reduce routine process expenses and deliver frequent and rapid updates to end users.

Continuous code delivery means regular code merging into the production environment. It’s fully automated and rhythmic. This method allows developers to avoid waiting for all features to be fully prepared and instead upload the currently ready code to the environment at regular intervals, e.g., every week or every two weeks.

Previously, developers used a release-based code-uploading system as an alternative. They would prepare a release, test it and then migrate it to the production environment. More often than not, they performed this process manually. As a result, new functionality was delivered slowly and lacked clear systematicity.

The practice of continuous delivery has become an integral part of contemporary software engineering.

From a developer’s perspective, successfully implementing continuous delivery requires some preparation. It involves a plan. The list of steps depends on the project and the team, but the main components are the following.

1. Automate all the procedures that need to be implemented in the delivery process. This step is helpful because it reduces costs and the number of human errors. The most important condition is that the entire automation must be tested and work like a Swiss Clock.

2. Adapt Git Flow to work with CD.

3. Make additional code validation and tests to ensure build quality.

4. Configure the CD tool as it is.

You can count on smooth continuous delivery by setting up all of these processes.

The Place Of Continuous Integration In The Continuous Delivery Process

Continuous delivery must address issues such as full system automation and quality code implementation. These two issues are interconnected in terms of continuous delivery—a process that automatically delivers quality code to developers so that they can work with it. The whole process is called continuous integration.

Continuous integration (CI) allows developers to check the source code step by step. They may use a static code analyzer for this purpose. For example, SonarQube is a platform for code review through statistical analysis for Java (and other languages). And for JavaScript, Linter—a program that checks code for compliance with standards and rules—is more suitable since it automatically corrects deviations.

After checking the code, they can perform tests written by developers, such as unit tests, integration tests or end-to-end tests. These can be incomplete integration tests and incomplete autotests; their primary purpose is to check how the system runs rather than how it functions.

For example, we use a specific Git Flow to ensure the system works properly. For this purpose, the new project feature is placed into a separate Git branch. At this point, the automatic testing of the code in the form of statistical analysis or other types of testing is performed. When the automated testing is complete, the team lead does a code review and submits it for manual QA testing. When this functionality is ready, the developer requests to merge the changes from this separate branch into the main branch of the source repository.

When dropping code on the server, it’s important to name the branch according to the release date. Then, if there are any issues, developers can go back to the version of the code uploaded to production.

The Importance Of Code Upload Frequency

A CD system is most effective if the code is regularly uploaded. Therefore, it’s essential to emphasize the stability and verifiability of the uploaded code. It can include at least minimal manual QA code review through the corresponding Git Flow and the development process in general.

The CI system should exclude manual work entirely because it can become a source of errors. The infrastructure must be fully implemented as code for the system to be maintainable and scalable.

Another vital aspect to consider is potential crashes—when the system stops responding when it’s re-uploaded. Developers should avoid this if possible, for example, by using blue-green deployment. In simple words, uploading to the new server happens while the current version runs. When the upload completes, the servers are swapped through DNS or load balancers.

The CD system cannot cancel the API versions, especially if there are mobile and desktop clients.

Effective CI/CD Highlights

No points can be omitted or disregarded in the practice of continuous integration. Always consider the following when implementing this methodology.

1. The uploaded code.

2. The code testing.

3. The transparent and automated frequency of code uploading.

4. The ready infrastructure for CD, excluding manual work.

5. The infrastructure maximum implemented in code.

6. The client versions.

7. The uptime issues.

The purpose of the continuous delivery process is successful, timely product updates that allow companies to increase product quality for end-user satisfaction.


Forbes Technology Council is an invitation-only community for world-class CIOs, CTOs and technology executives. Do I qualify?