# Continuous Delivery: the strategy to overcome challenges in the Government IT ## Abstract For many software development teams, the first things that come to mind regarding Continuous Delivery (CD) are its operational aspects and competitive benefits. For us, it was much more: it was a survival technique. This article presents our experience applying CD in a Brazilian Government project for the development of a Collaborative Development Environment (CDE), sharing its unconventional challenges and the strategies used to overcome them. This report from the trenches of the Brazilian Federal Government can help practitioners to understand how important CD adoption can be to their projects. ## Introduction and Context We worked on a three-year-long Brazilian government project to evolve an existing platform that had technical issues and lacked political support. The evolution project started in a presidential election year and everyone involved were under pressure to show results. Even with the re-election of the Brazilian President in 2014, leaderships in governmental agencies ended up changing. Each one of them had different political agendas which affected the project's requirements previously approved. Despite this scenario of instability, we managed to avoid delays in the delivery schedule and to prevent the project's cancellation. Our team from the University of Brasília (UnB) and the University of São Paulo (USP) developed the new platform for the Brazilian Public Software (SPB, Portuguese acronym) Portal (www.softwarepublico.gov.br) from 2014 to 2016. The SPB Portal evolved to a Collaborative Development Environment [1] and this evolution brought about important benefits not just to the Brazilian government, but also to society as a whole. For the government, the bureaucracy on using the same software across governmental agencies, duplicate works, and costs all were reduced. The society gained a transparency and collaboration mechanism, since anyone can check the government expenses on software and contribute to the software communities. To achieve these goals, rather than writing everything from scratch, we decided to integrate several free software tools such as Gitlab (www.gitlab.com), Mailman (www.gnu.org/software/mailman), Noosfero (www.noosfero.org), and Colab (www.github.com/colab). During the entire SPB Portal evolution project, we had to handle three distinct issues, usual in a software engineering scenario: achieving the goals which have guided the platform development, managing the diversity of team project members, and communicating effectively with clients (in this case, government agents). Handling the interaction of these elements was not easy and the unstable Brazilian political scenario only made things worse. To achieve the SPB project goals, we had to overcome strong political bias tied with complicated technical issues and relatively low budget. Because it is open to the public, the government representatives saw the platform as a marketing opportunity and sometimes ignored technical advice in favor of political decisions. Furthermore, integrating a number of distinct systems to work seamlessly was not an easy job. We had to learn how each system worked and to come up with ideas of how to integrate them as fast as possible, with a team of mostly inexperienced developers. We also had to manage the diversity of the SPB team members. This team was composed of approximately 50 undergraduate students (not all simultaneously) together with professors, masters students, professional designers and senior developers from the Brazilian free software community. Undergraduate students received a scholarship and, for most of them, this R&D project was their first professional experience. Seniors developers and masters students had two important contributions to the project: transfer knowledge to undergraduate students and address hard tasks. Finally, professors were responsible for interacting with the Brazilian government and controlling the political pressures applied to the project. The third point to be handled was the communication with two independent groups of government representatives: requirements analysts and deployment technicians. Requirements analysts were the real representatives of the Brazilian government in the project and their role was to test new features, to provide feedback to the development team, and to report for the government leaders. Deployment technicians were in charge of administering the host machines wherein SPB platform was running. They were, theoretically, responsible for deploying the project. However, the new SPB Portal was composed of more than ten different software projects, generating a complex deployment process, for instance, working on seven servers. To handle the interaction between these three elements, we realised we needed to take control over the deployment process. We used CD as a mean to fulfill the government expectations and to provide quick response to their requests, which were influenced most of the time by the uncertainties of the project's continuity. We believed we would keep the project alive, even in a politically unstable and technically complex scenario. For this reason, we worked hard to automate the deploy process; for instance, one of our senior developers created a Chef-Server (www.chef.io/chef) front-end tool called Chake (www.gitlab.com/terceiro/chake) to help us to manage the multiple hosts needed for the project. We also formed a specific team dedicated to the deployment process. This team was responsible for maturing our CD pipeline, giving us confidence and agility to comply with government requirements. In this report, we describe our CD pipeline and how it improved our delivery performance. The CD made us adaptable for all requested changes and helped us mitigate those aforementioned political challenges, besides the technical issues. Among CD’s known benefits [2], we also explain those which were the most important in the project scenario for us: improving customer satisfaction and making reliable releases. Both kept the project alive for more two years during the worst political crisis after the re-democratization in Brazil. ## Our Continuous Delivery Pipeline ![Deployment Pipeline](figures/pipeCD.png) The Figure 1 represents our CD pipeline. The pipeline started when new code arrived. As it went through each step, it was tested and improved until it finally reached the production environment. At this point we got back to the first stage to release more new code. ### Automated tests Each one of the Portal's software components had their own test suite. The development teams were required to maintain and expand them if possible. The communication of all these software was based on a plugin architecture. Testing the plugins were our integration tests. Finally, all tests ran in each component continuous integration environment. This two-level testing provided us with the necessary speed and trust that guaranteed both component and platform stability. If any error was found, the pipeline stopped and the developers were notified. Only after all tests passed we moved to preparing the release. ### Preparing a new release Our release process was divided in two perspectives in terms of Git tags: the application and the SPB Portal. The application tag referred to the specific feature or bug fix and was a monotonically increasing. A new tag on any system yielded a new SPB Portal tag. When all tests passed for a given component, we manually created a new application tag for it. As a consequence, that automatically created a new tag for the SPB Portal. Notice that we forked the original software projects and, as consequence, we had different tag values. ### Packaging The platform is running on the CentOS 7 GNU/Linux distribution. Basically, packaging a software for that distribution has three steps: write the script for the specific environment (RPM), build the package, and upload it to a package repository. We chose to create our own packages for each software component for several reasons: * Not all software was packaged by the community and those that existed were outdated; * Packaging makes it easy to manage the software on a given distribution; * It simplifies the deployment; * Packaging follows the distribution's best practices and, * Allows configurations and permissions control. After creating a new tag for one component, the DevOps team was notified and the packaging process began. The three packaging steps aforementioned were fully automated by a set of scripts. With all these scripts running successfully, the new packages would be ready to be used by our subsequent deployment scripts. ### Validation Environment Deployment The Validation Environment (VE) is a replica of the Production Environment (PE), with two exceptions: only the government officers and us had access to it and all the data is anonymised. To configure the environment, we used our configuration management tool: Chake (serverless configuration with Chef). That maintained environment consistency simplifying the deployment process. Additionally, the packages we built on the last step were readily available to be used by the management tool. The VE was used by the government agents to validate new features and required changes. Also, the VE was useful to verify the integrity of the entire portal as part of the next step in the pipeline. ### Acceptance Tests After we deployed a new SPB Portal version in the VE, the government agents are responsible for checking features and bug fixes required by them. If the requirement analysts identified a problem, they notified the developers via comments on the SPB Portal's issue tracker. The problems were fixed and the pipeline restarted from scratch. If everything was validated, we moved forward. ### Production Environment Deployment After the government finished the VE check and it was cleared for deployment, we could finally begin the deployment to Production Environment (PE). For this we also used our configuration management tool, the same scripts and package versions as in the VE. After the deploy was completed, both VE and PE were running identical software. This was the point where new features and bug fixes were finally available to the end users. ## Benefits Research points out many advantages of CD usage in industry, such as: accelerated time to market, building the right product, productivity and efficiency improvements, reliable releases and better customer satisfaction. Working with the government, we noticed the following additional benefits. ### Response to mistrust The direct benefit from the CD pipeline was the fast response to changes required by the government. That was vital for the project's renewal over the years. We could manage the tension between the government and the development team better. Every meeting with the government leader was delicate and resulted on many new requirements, most of them motivated by political needs. For example, once it was demanded a completely layout change because another government leader suddenly decided to make a marketing campaign about the new SPB portal. They would use undelivered requirements as a means to justify the lack of financial resource already planned. We believed that if we took too long to attend their demands, the project would end. CD helped us to move fast on deploying to production, even of smaller parts of the requirements. That way, we always had something to show on the meetings, reducing their eagerness to end the project. For our team, it made the developers more confident the project would last a little longer and they would not go looking for another jobs. ### Build client’s trust After we established the CD, the government agents started to be more confident in our work. First, because they noticed that each new deploy made by us in the VE was stable and reliable. Second, they could see new features fast since we constantly updated the VE based on their feedback. This made our relation strong and in moments that needed quick action they would rather give us access to production. ### Shared responsibility Before the adoption of the CD, the developers team could not track what happened to the code after its delivery, since government technicians were the only responsibles for deploying the project. The implementation of the referred approach influenced developers on taking ownership of the project because it made them feel equally responsible for what was getting into production. Interestingly, the CD pipeline had the same effect on the team of requirements analysts. They were an active part of the pipeline and became more engaged on the whole process. After the incorporation of the pipeline into the work process, analysts became more active in opening and discussing issues during the platform evolution. Additionally, developers worked to improve the CD pipeline in order to speed up the process of making available, in the production environment, new features for the platform. ### Synchronicity between government and development Despite the positive impacts that the CD pipeline brought to the project, its implementation was not easy at first. The good performance of the CD pipeline depended on the synchronicity between the teams of developers and government analysts, so that the work of one could be initiated immediately after the delivery of the work by the other. Initially this concern was not contemplated in the agenda of the governmental team, which generated delays in the validation of the new features of the release. This situation combined with governmental bureaucracy (up to 3 days) to release access to the production environment resulted in additional delays for the deployment step to begin. This problem was softened when the analysts realized the impact of these delays on the final product and decided to allocate the revisions in its scale of work and to request the access to production in time. ### Strengthening trust in our work relation with the government Continuous delivery was also a tool that helped to strengthen trust in the relationship between developers and government analysts, as well as between the latter group and its superiors. Before using CD, analysts had access to the features developed only at the end of the release, usually every 4 months. However, this periodicity did not meet the requirements of their leaders, who demanded monthly reports on the progress of the project. With the implementation of the CD, intermediate versions became available, allowing analysts to perform small validations over time. The constant monitoring of the development work brought greater security to the governmental nucleus and improved the interactions of these with the team of developers. ## Challenges We successfully built a CD pipeline. In the end, we took over the deployment process from the government. That allowed us to survive into an unstable political scenario. However, we recognize that many challenges still need to be addressed by the industry and academia together. ### Build CD from scratch Taking on CD responsibilities had a significant impact on the team. We did not have the know-how and had little time to come up with a working pipeline. The senior developers were crucial at this point. They came up with an initial solution to get us started. That already enabled us to automatize the deploy, even though the process was still rudimentary. We had to evolve our solution on-the-fly. We dedicated a few developers to this task. Building a CD pipeline was hard in the beginning. We believe that more tools that provide out-of-the-box standardized CD pipelines would be of great help for inexperienced teams. Tools that track each step of the pipeline and organize logs in a human-manageable way are necessary too. ### Handling inexperienced teams After the developers learned how CD worked, it was difficult to pass the knowledge along to other teammates. We tried to mitigate this by encouraging a member's migration to the DevOps team. Further research on how to effectively spread knowledge across inexperienced developers in a high turnover scenario are needed. ### Overcoming mistrust In the project's first half we struggled with deploy related problems in the government structure. We were in a paradoxical situation. The government demanded speedy deliveries but would not give access to their production infrastructure. After some interactions with government agents, they created the VE as an isolated replica of the PE in their own infrastructure. The government agents then realised that it could be beneficial for the project if they granted us access to part of the structure. We believe it is required more research on development protocols and policies to improve the relation between industry and government, specially regarding CD. ## References 1. G. Booch, A. W. Brown, "Collaborative Development Environments", in Advances in Computers, vol. 59, 2003, pp. 1–27. 1. L. Chen, "Continuous Delivery: Huge Benefits, but Challenges Too", in IEEE Software, vol. 32, no. 2, 2015, pp. 50-54.