Rethinking Release

Transcription

Rethinking Release
Master of IT – Software Engineering
Final Project
Rethinking Release – a case study
16th March 2015
Student: Kenn A. Thisted (kenn@itu.dk)
Supervisor: Dr. Yvonne Dittrich, Associate Professor
Contents
Abstract.................................................................................................................................................2
1. Introduction......................................................................................................................................3
2. Case background..............................................................................................................................3
2.1 Overview of IT at Topdanmark..................................................................................................4
2.2 Existing tools landscape.............................................................................................................4
2.3 Existing release process.............................................................................................................5
2.4 Recent initiatives........................................................................................................................7
2.4.1 Partial Branches.................................................................................................................7
2.4.2 Branch Automation Server.................................................................................................8
2.4.3 Build automation................................................................................................................9
3. Related work.....................................................................................................................................9
3.1 Continuous software engineering..............................................................................................9
3.1.1 Continuous Integration.....................................................................................................10
3.1.2 Continuous Delivery and Continuous Deployment.........................................................10
3.1.3 Maturity models...............................................................................................................11
3.2 Deployment pipeline................................................................................................................13
3.3 DevOps....................................................................................................................................14
3.4 Summary of related work........................................................................................................15
4. Method............................................................................................................................................16
4.1 Research approach...................................................................................................................16
4.2 Fieldwork and analysis methods..............................................................................................17
4.3 Reflection on the research process and fieldwork...................................................................18
4.4 Trustworthiness........................................................................................................................19
5. Case description..............................................................................................................................19
5.1 Case selection..........................................................................................................................20
5.2 Course of events.......................................................................................................................21
6. Analysis..........................................................................................................................................23
6.1 Tool design...............................................................................................................................24
6.1.1 Extension to user interface...............................................................................................25
6.1.2 Limitations.......................................................................................................................25
6.1.3 The extent of the change..................................................................................................26
6.2 Application impact...................................................................................................................28
6.3 Process impact.........................................................................................................................29
6.4 Learnings for the organisation.................................................................................................29
7. Discussion.......................................................................................................................................30
8. Conclusion......................................................................................................................................32
References..........................................................................................................................................34
Abstract
Context: For a number of years software in Topdanmark has been released on a monthly basis, and a demand
for more frequent releases is becoming a key issue. The existing process, tools and recent initiatives to renew
the infrastructure serve as stepping stones for rethinking the release process and tools. The subject of the
study is a targeted collaborative effort between an infrastructure tools team and a development team to
design and implement a concept and solution to this problem within certain time and scope constraints.
Thus a continuous delivery proof-of-concept was conducted over a period of 3 months between October 2014
and January 2015.
Objective: Answering the problem if and how a higher frequency of software releases could be achieved.
Method: A qualitative case study was designed and conducted to observe and reflect on the course of events
and result of the proof-of-concept effort.
Result: Fieldwork examples are included in the case description, and supported by design sketches and
implementation examples the analysis shows the result as effects on tool design, application impact, process
impact, and learnings. The main focus is on the small scale of the resulting design and implementation, but
also important are the effects on the application architecture and the immediate improvement on the process
of the development team. Discussion topics include the value of the collaborative effort, the small design and
automation effort needed compared to initial expectations, the dilemma of having to leave some software
behind, and requirements to application architecture in order to take advantage of the concept as
implemented in the proof-of-concept.
Conclusion: The study concludes by confirming how we were actually able to design and implement a
continuous delivery solution, and even though it supports only a narrow subset of applications, it provides a
starting point for the organization to gain experiences with releasing software more frequently.
Master i Software Engineering (Professional Master of IT)
Final Project: Rethinking Release – a case study
16th March 2015
Student:
Kenn A. Thisted (kenn@itu.dk)
Supervisor:
Dr. Yvonne Dittrich, Associate Professor
Rethinking Release – a case study
Kenn A. Thisted, 2015
2
1. Introduction
For a number of years software in Topdanmark*) has been released on a monthly basis. Excluding a release
every summer and winter this allows for about 10 planned ordinary releases a year. Each release involves a
comprehensive process of testing, build, release management, and deployment.
A demand for more frequent releases is materialising both from developers and from product owners
representing business needs. This is becoming a key issue in the near future which lead me to want to
investigate:
•
Can we achieve a significantly higher frequency of software releases at Topdanmark without compromising quality?
In order to support this main problem the study should also investigate the efforts towards achieving this
goal.
In the autumn of 2014, responding to the recognized business needs of increased frequency and flexibility in
releasing software, Topdanmark IT decided to conduct a continuous delivery proof-of-concept (PoC) in a
collaborate effort between a tools team and a development team. The effort was titled "HypR PoC"
abbreviating the Danish term for increased release frequency: Hyppigere Releases.
This report is a design case study documenting and analysing this collaborative effort and the resulting
product and impact. In the report I will strive for referring to the subject of the study as the proof-of-concept
(PoC) while the study itself is referred to as the project.
2. Case background
This chapter establishes background information about the current organisation, processes and tools relevant
to the following analysis of this case.
*) Topdanmark is the second-largest insurance company in Denmark.
Rethinking Release – a case study
Kenn A. Thisted, 2015
3
2.1 Overview of IT at Topdanmark
Topdanmark is an insurance company operating in Denmark. Spanning both property & casualty as well as
life insurance the company has approximately 2,700 employees. Topdanmark has it's own IT department
covering both development and operations. The IT department consists of about 400 employees of which
roughly 200 work in development.
Software development in Topdanmark IT is mainly organised in five departments each supporting separate
lines of business (see figure 2.1). Bridging these are IT Operations which is responsible for executing,
monitoring, and supporting running IT systems. In addition Architecture & Methods (A&M) provides
common architectural and infrastructure components shared across other departments.
Figure 2.1: IT departments supporting lines of business
In A&M the Agile Development & Testing team is responsible for the processes, tools, and infrastructure
supporting software development in Topdanmark.
2.2 Existing tools landscape
This section briefly introduces the primary tools and technologies used at Topdanmark relevant to this case
study.
The effort in this PoC focuses on applications written in Java and running on Microsoft Windows. Java is
coded using primarily Eclipse IDE, but others are allowed, and run on IBM WebSphere Application Servers
(WAS). The shared database is IBM DB2 on the mainframe. Database schemas are created and maintained
using CA ERwin Data Modelling.
Rethinking Release – a case study
Kenn A. Thisted, 2015
4
The main code repository is Serena Dimensions CM, and support for build and release processes are built
with and around this tool. Deployment and environment provisioning is a proprietary solution (written
mostly in PowerShell) based on BMC BladeLogic Server Automation.
Dimensions is a Centralized Version Control System (CVCS) in which all source code artefacts are stored.
The existing build and deployment pipeline triggered from this is a custom built workflow with a web client
user interface. The example below (figure 2.2) shows how build targets can be selected and subsequently
deployed to the desired environment. Other custom tools include a build & dependency fetcher plugin for
Eclipse.
Figure 2.2: Custom 'Build and Deploy' web interface
Additional tools and technologies are used for mainframe applications, building the public web site, as well
as a variety of supporting functions, but these are excluded from the current study.
2.3 Existing release process
The current release process in Topdanmark has been in operation for a number of years. Inspired by Unified
Process [Jacobsen et al. 1999] the TopUP (Topdanmark Unified Process) process was introduced to coordinate releases from several systems in and across departments, streamlining them into unified release trains
running approximately once a month (see figure 2.3).
Rethinking Release – a case study
Kenn A. Thisted, 2015
5
Figure 2.3: The monthly TopUP process release train
The internal introduction material to TopUP states these as primary objectives for the process: documenting
development initiatives, audit requirements for code in production, and at any given moment knowing who
did what to which code, and why. The process aims to be quite open and delegate responsibility to the
developer in stating two rules only: You may not deliver code that breaks other peoples code, and in order to
submit code you must state the reason why.
Figure 2.4: The existing branching model
In the current process code is produced at the developer's workstation and checked into a branch in
Dimensions. During development and testing code is built from a branch and deployed on one of an array of
Distributed Source Control Management (DSCM) environments/servers. Following successful testing
(automated and/or manual) code is pushed to Main branch. From there it is subsequently being built again
and tested in collaboration with code from other branches in what are called Integration and Release tests,
and upon verification allowed onto the Production environments (see figure 2.4). For the scope of this report
Rethinking Release – a case study
Kenn A. Thisted, 2015
6
it is not necessary to understand the branching strategy that the model represents in detail. It is sufficient to
recognize that there is some degree of complexity involved in handling multiple branches and understand
the flow of code that the direction of the arrows indicate.
DSCM environments are virtual servers, whereas Release, and Production are "physical" environments in
that they have dedicated servers. The physical environments are duplicated, and for every release code is
deployed on a non-production set. Pending verification production is simply switched to the new set.
2.4 Recent initiatives
Like most places the set of tools and technologies evolves over time – sometimes defensively to not run out
of support, but more interesting in this case also offensively to benefit from new features. The general level
of tools is kept reasonably updated, but of special interest to the release process a couple of recent initiatives
are significant.
2.4.1 Partial Branches
When TopUp was introduced all branches were fully populated (see branching model in figure 2.4 above) i.e.
they each contained the full set of items. In order to reduce time spent working with each branch (e.g. rebase
and deliver in figure 2.3), as well as reducing storage space needed, the concept of partial branches was
introduced and implemented in March 2013. This allows and encourages development teams to only keep
the necessary items – items that are actually being worked on – in their own branch.
Initially the concept was introduced for the server platform (Java and PHP code) where it maps well with
project directory structures. Starting October 2014 the concept was expanded to include the mainframe
platform (COBOL and PL/I code) based on a custom filtering by member (file) type and name.
The prevalence of the partial branches concept is communicated by publishing “Dimensions Partial
Population Statistics” comprised of a graph showing the average branch population for the latest 3 months
(see figure 2.5) supplemented by a list of population percentages for each branch. The list is omitted here
since I trust that the graph itself is sufficient to illustrate the concept.
Rethinking Release – a case study
Kenn A. Thisted, 2015
7
Figure 2.5: Branch population average (3 months)
The black line indicates the average population percentage across all branches (number of branches stated
for each date). The green line indicates the target potential based on items actually having been touched
within the latest year.
2.4.2 Branch Automation Server
A couple of years ago the concept of a Branch Automation Server (BAS) was introduced. This is a
Continuous Integration (CI) platform (see related work section 3.1.1), based on a set of common tools like
Jenkins (as the CI server) and SonarQube (for static code analysis), which allows the tools team to offer this
as standardized server instances to development teams. Using this common BAS concept development
teams can take advantage of a shared effort and avoid having to set up this infrastructure themselves. As the
name implies a BAS can be issued to each branch serving as an engine automatically running the team's unit
tests (e.g. in JUnit), acceptance tests (e.g. Robot Framework), or other kinds of automatable testing
technologies. In addition the BAS offers static code analysis initially supporting Java code, while support for
PHP code is planned for early 2015.
The purpose of this concept is to improve software quality by running tests and static analysis every time
code is checked into the branch. One important aim of CI is to prevent integration problems occurring when
merging developer copies of code. Performing this integration frequently using automation keeps the effort
and scope of problems small compared to more infrequent manual integrations that was commonplace
before.
Rethinking Release – a case study
Kenn A. Thisted, 2015
8
2.4.3 Build automation
The existing build process in TopUp consists of custom built tools around and integrating to Dimensions.
Since October 2014 this proprietary build infrastructure is supplemented by a parallel build process based on
Apache Maven (build automation server). Reasons for this include tool modernization and standardization.
By adopting a widely used modern build tool it is possible to take advantage of industry or community
support and mitigate the risk of critical knowledge being held by only a few key persons. The goal is to have
all builds transferred to Maven before end of June 2015 allowing the existing proprietary build tool to be
decommissioned.
3. Related work
This chapter will present selected research articles, books and book chapters, as well as other sources
relevant to continuous software engineering. Although terms and definitions presented have evolved from
earlier software engineering disciplines not much research exists on these contemporary conceptions.
Because of this most work presented is state of the art as in it represents the latest developments on the
subject.
3.1 Continuous software engineering
In software engineering the term "continuous" is used in various contexts. One example of its use in process
related contexts like lean and agile is continuous improvement which deals with the iterative effort of
incrementally improving practices. For the purpose of this report it is relevant however to introduce the
more technical practices of continuous integration, continuous delivery, and continuous deployment.
A common property for these concepts is automation. They all aim to automate steps of the software
development process in order to speed up these steps and consequently be able to get a quicker response of
success or failure of each step. This originates from a recognition that manually performing tasks like build,
test, and deployment is simply too slow and error prone to effectively achieve sufficiently fast feedback.
Hence automating these tasks is essential in supporting the overlying lean an agile processes' goal of being
able to efficiently adapt to changes.
Rethinking Release – a case study
Kenn A. Thisted, 2015
9
Another important effect of automation is quality. Automating tasks like build, test, and deployment allows
for a consistent quality of the processes in that potential manual errors performing the tasks are avoided.
This way automation helps produce more dependable results. Although automation in itself does not affect
the quality of the code, a general perception is that the increased frequency of dependable feedback
encourages smaller and more manageable changes which in turn leads to better software. A common rule of
these practices is that if anything breaks during these tasks, regaining a stable build immediately becomes
first priority. By not allowing an error state to exist for very long this also contributes to the overall software
quality.
The following sections will elaborate on continuous software engineering by presenting terms that provide
different perspectives on the subject including industry best practice and case studies.
3.1.1 Continuous Integration
Originating from eXtreme Programming (XP) [Beck 1999] Continuous Integration is a practice in software
development where developers in a team integrate their code frequently – usually at least once a day. This
process of build, test, and possibly static code analysis is automated yielding the above mentioned benefits
of fast feedback allowing for quick response by the team. Continuous integration is widely used supporting
agile methods in software engineering. Even though the concept can quite easily be explained like in the
often quoted article by Martin Fowler [Fowler 2006] and several aspects were covered in more detail in the
basic textbook on the subject [Duvall et al. 2007], it is still very loosely defined, and often both descriptions
and implementations vary as elaborated upon in Continuous Integration Flows [Ståhl and Bosch 2014]. For
the purpose of this report it is sufficient to recognize that continuous integration is a predecessor to
continuous delivery in two ways: the former concept was introduced a few years prior to the latter, and it is
also generally perceived as a prerequisite in automated implementations.
3.1.2 Continuous Delivery and Continuous Deployment
The concept of Continuous Delivery is inspired by the first of the twelve principles [Beck et al. 2001] behind
the Agile Manifesto:
"Our highest priority is to satisfy the customer
through early and continuous delivery of valuable software."
Rethinking Release – a case study
Kenn A. Thisted, 2015
10
The subtitle of the basic textbook [Humble and Farley 2011] summarizes the purpose of continuous delivery:
Reliable software releases through build, test, and deployment automation. As stated earlier quality, implicitly in
reliable, is a key objective, and automation represents the means to achieve this.
Like with with continuous integration various interpretations of continuous delivery exist. One important
distinction to make is about the extent of automation. When researching or discussing the subject one
sometimes encounters some ambiguity in perceptions of Continuous Delivery and the much related term
Continuous Deployment. This project and report mirrors the definition that seems to be consistent with key
influencers like ThoughtWorks and PuppetLabs and reflected in the recent book Lean Enterprise [Humble et
al. 2014]:
"Despite the name, continuous delivery is not about deploying to production
multiple times a day. The goal of continuous delivery is to make it safe and
economic to work in small batches. This in turn leads to shorter lead times,
higher quality, and lower costs."
The important distinction in this context is that with Continuous Delivery deployment to production is a
manual step in the process, while in Continuous Deployment this step is automated. In both cases all other
steps are automated. The purpose of both is of course to provide frameworks for speeding up software
development, but this difference represents a key distinction in whether changes (assuming passed tests and
possible other metrics) are pushed into production automatically or, as preferred in this case, they can be
pulled into production upon request.
3.1.3 Maturity models
Continuous delivery maturity models visualise actions in progress towards successful implementation as
well as allowing organizations and teams to assess their current state, the gap towards their desired target
state, and next steps in that direction.
The research based "Stairway to Heaven" conceptual model [Olsson et al. 2012; Olsson and Bosch 2014]
defines five consecutive ascending steps in the transition of moving from traditional software development
towards continuous deployment. From four case studies the model shows evolutionary steps through agile
and continuous integration. Especially relevant for this report step four states that " Continuous deployment
Rethinking Release – a case study
Kenn A. Thisted, 2015
11
implies that you continuously push out changes to the code instead of doing large builds and having planned releases of
large chunks of functionality", followed by emphasizing the importance of fast feedback. Although the article
talks about highly prioritized frequent delivery of software this is mentioned as an implicit part of step three:
continuous integration.
Figure 3.1: Olsson & Bosch's "Stairway to Heaven" evolution model
An observation to make regarding the book presenting this model [Bosch (Ed.) 2014] is that it contains
specific parts addressing steps two, three, and five. Regarding step four, however, it states: "The fourth step in
the stairway to heaven, continuous deployment, is not present explicitly in this book as it often evolves automatically as
a natural extension of continuous integration". Even though further investigation into this claim in relation to
others distinguishing between continuous integration, delivery, and deployment could prove interesting in
itself, it is out of scope for this report. For the purpose of this project and report the general steps and
evolutionary nature of the model are sufficient, as well as noting that even though not emphasized in this
model there is no immediate contradiction between the perceptions of delivery in this model and the
definition of continuous delivery in the section above.
A more elaborate maturity model was presented a couple of years earlier in the paper “The Agile Maturity
Model” [Humble and Russel 2009]. This model specifies important attributes towards continuous delivery,
presenting them in a matrix of themed groups (horizontal) and five ascending levels of maturity (vertical).
The same model, now with a “Configuration Management” theme appended, was presented a couple of years
later as “A Maturity Model for Configuration and Release Management” in the Continuous Delivery text book
[Humble and Farley 2011] (see figure 3.2).
Rethinking Release – a case study
Kenn A. Thisted, 2015
12
Figure 3.2: Maturity model [Humble and Farley 2011, p.419]
This matrix concept has been adopted in industry context and similar models have been published as
Continuous Delivery Maturity Models in the last few years. Examples of these include an article from InfoQ
[Rehn et al. 2013] – a well known knowledge base in software development, and a paper from Praqma
consultants [Praqma unknown]. Both models have emerged from the agile community and are vendor
independent. The most recent example is a Tech Tip article from IBM urban{code} [Minick 2014] showing
that the concept is entering the space of major vendors.
These industry spin-offs share the same common properties as the original model. The models are not
identical but themed groups shared across all models include important disciplines like building, deploying,
testing, and visibility. In addition the InfoQ model includes “Culture & Organization” as a separate theme,
which makes very much sense in that these are essential factors in successful implementation of a change
towards continuous delivery. IBM's model introduces indicators of the current industry norm level for each
theme as well as the desired target level. Both are interesting contributions adding to the original model.
3.2 Deployment pipeline
In continuous delivery the deployment pipeline is an automated process that software being developed must
pass through on its way from the developer to Release. The pipeline chains processing elements together so
that the successful output of one flows into the next. Process elements that fail immediately returns control
to the developer, which is key to the early response/fast feedback aspect of continuous delivery. The concept
of the deployment pipeline is well described in the Continuous Delivery text book [Humble and Farley 2011]
Rethinking Release – a case study
Kenn A. Thisted, 2015
13
in which the sequence diagram below (figure 3.3) visualizes how changes move through the pipeline.
Figure 3.3: Changes moving through the deployment pipeline [Humble and Farley 2011, p.109]
The deployment pipeline is also sometimes referred to as the software delivery pipeline or the build pipeline. In principle the pipeline could serve software changes at irregular intervals or even rare occasions, but
in the continual nature resulting from frequent changes it must be seen as an iterative process.
In a continuous delivery context it may be obvious to most that this pipeline refers to software development
in general. In model-driven development, however, a pipeline usually refers to a series of model transformations set up to efficiently support conformity between multiple uniform software deliveries. To briefly
address this ambiguity it should be pointed out that this latter definition is not what is referred to when
mentioning the pipeline in this project.
3.3 DevOps
DevOps and Continuous Delivery are not the same thing. More often than not one comes across resources
(texts, webcasts etc.) or discussions about software engineering in which these terms are used inter changeably. Since these are still emerging concepts, perhaps this is understandable, but in order to clarify the
perception of DevOps in this project, I will show some examples from a very recent, as in not yet published,
book on the subject [Bass et al. 2014]. The book has five parts: after introducing the subject, part two
specifically addresses the Deployment Pipeline (term known from Continuous Delivery above), and then
Rethinking Release – a case study
Kenn A. Thisted, 2015
14
moves on to elaborate on cross cutting concerns, presents three case studies, and speculates on the future of
DevOps.
DevOps is a hybrid of process, relation, and a (new) practice. DevOps brings software developers and other
IT professionals, in particular in IT operations, closer together. At its most basic DevOps is about seeing
operations personnel as first class stakeholders, working in close collaboration on what is involved in
releasing software rather than just throwing software “over the wall”. At its most extreme, DevOps practices
make developers responsible for running their own applications that is monitoring them, handling errors
during deployment and execution, and perhaps even act as first line support. In between are practices that
cover team interactions as well as build, testing, and deployment processes. The DevOps lifecycle processes
diagram (figure 3.4) shows how development gradually advances towards encompassing processes
traditionally handled by other IT professionals including tools specialists and operations.
Figure 3.4: DevOps lifecycle processes [Bass et al. 2014, ch.1 p.4]
Regarding the deployment pipeline DevOps achieves its goals partially by replacing explicit coordination
with implicit coordination e.g. minimizing manual interactions and removing surplus artefacts. The
deployment pipeline concept is described much like in the previous section, although emphasizing
production as the last step (as with continuous deployment).
3.4 Summary of related work
The literature presented in this chapter has helped defining concepts relevant to this case. It explained the
key term of continuous delivery both in itself by referencing important definitions and models, and by
supporting it with related terms like continuous integration and the delivery pipeline, as well as comparing
Rethinking Release – a case study
Kenn A. Thisted, 2015
15
it to DevOps which addresses many of the same elements from a different perspective. Presenting this also
supported the relevance and understanding of the existing tools and release process including the recent
initiatives presented as case background in the previous chapter.
4. Method
The research for this project was conducted as a case study. The research approach and fieldwork method is
explained in this chapter while the following chapters describe the actual case in more detail and present the
findings and result of the project in the analysis.
This chapter describes how information was gathered and processed as fieldwork for the case study as well
as reflects on the research artefacts produced and the how the process was appropriate for the purpose.
4.1 Research approach
The research presented in this report took place as part of a collaborative infrastructure effort involving a
tools team and a development team at Topdanmark. The subject of the research was designing and possibly
implementing a proof-of-concept for an improved release process. I investigated which design and scope
decisions the team made and how they worked towards this target.
The fieldwork included audio recordings of team meetings from which observations were noted, and
subsequent reflections made. Where relevant, recordings were supplemented with photos of whiteboard
notes and drawings from the meetings. My contribution to the project included defining the exterior
constraints of the project (like timebox and goal of the effort) in the role of Product Owner, and exploring
possible designs together with the team.
In my primary role as observer in this study I facilitated the audio recordings, collected them along with
other fieldwork items, e.g. design sketches, and subsequently processed these for the study. My intervention
in the project focussed on keeping progress towards the goal while mitigating threats to progress and
completion. In addition to that I assisted by clarifying questions along the way, especially regarding
constraints and whether some design ideas would be acceptable.
The research presented is based on qualitative observation only. Qualitative research targets understanding
Rethinking Release – a case study
Kenn A. Thisted, 2015
16
how people work things out and arrive at solutions rather than measuring their effort based on certain
criteria.
The research method put to use in this project can be described as Participatory Action Design Research. The
action research element [Robson 2002] focuses on exploring the influence of introducing continuous delivery
as a change to the existing development process. The design element refers to the main task of devising how
the tool should be built to support this, and the participatory aspect refers to the fact that the design arose
from a collaborative effort between two teams undertaking the principal roles of users and designers
[Simonsen and Robertson 2013].
The typical action research process addresses an experimental approach of a cyclic nature. The aim is to
repeatedly understand a situation, deliberating change, implementing selected change, and then observing
and reflecting upon the effect as a basis for a subsequent cycle. As a qualitative research method it
investigates the how and why of decision making rather than meticulous quantitative measures. Focus is on
information produced only in the particular case studied. More general conclusions would merely be
informed assertions or propositions.
4.2 Fieldwork and analysis methods
The bi-weekly meeting of the planned PoC (see figure 4.1) were audio-recorded from which observations
were logged (see template in table 4.1 below). Subsequently reflections were noted by the observer only in a
separate session.
Figure 4.1: Observations timeline template
Prior to recording participants had been informed about this study and assured anonymity in the report.
Any material significant to the meetings has been captured and stored. This includes photos of whiteboard
notes and drawings, as well as any literature presented.
Rethinking Release – a case study
Kenn A. Thisted, 2015
17
Time
hh:mm
Min.
Observationer (da)
mm:ss Transcription highlights
- in Danish, not anonymized
Reflections (en)
Post-observation reflections
- in English
Table 4.1 Template for collecting data
Following meetings, patterns in observations and reflections emerged by experimenting with grouping them
into categories (see table 4.2).
Pattern / Categories
Obs.
#
Relevant observations and reflections
First observation
Second observation
Third observation
Fourth observation
…
Cat. A
Cat. B
Cat. C
Cat. D
•
•
•
•
Table 4.2 Template for exploring observation patterns
Instantiation examples illustrating the use of these templates in the fieldwork are given in the case description below (chapter 5).
4.3 Reflection on the research process and fieldwork
When evaluating the implementation of the research process what comes to mind is the difference between
expectations at the outset and the actual course of the project. As it turned out observations along the
expected timeline nicely accommodated the expansion in time as well as the supplemental meetings. As such
the form and observations in the field work did not suffer from having to adapt to the reality of the HypR
PoC..
During the course of the project it was observable that key elements of the technical design were established
quite early and refined rather than redefined when revisited. On a couple of occasions what took focus was
challenges with progressing the project itself due to either problems with the subject application in relation
to the PoC scope or with resources being prioritized to other tasks than the PoC. Delays as a result of the
Rethinking Release – a case study
Kenn A. Thisted, 2015
18
latter also meant that the PoC scope and design had to be recalled a couple of times during the project, which
did of course not create much additional value to observations.
4.4 Trustworthiness
In assessing the trustworthiness of how this case study was conducted and the results it yielded I must of
course consider the impact of my own involvement. In a strict study context my presence as an observer,
especially due to meetings being recorded, was noticed by the team a few times, appx. once every meeting.
This was noted, however, merely in context of participants restricting language expressions or refraining
from explicitly naming a certain person. Also my research perspective while participating will have affected
my observations. I was more observant to details than I would be under normal circumstances, and at two or
three occasions during the study I specifically asked the team to elaborate on an element of the discussion in
order to clarify it for study purposes.
There can be no doubt that having the role of Product Owner in an agile context, and even a manager in
Topdanmark context, my presence in the collaborative effort cannot be completely neutral. It is my belief,
however, that besides explicitly having mitigated challenges with the subject application, and by
perseverance kept on encouraging the team when they doubted the value of continuing, my impact on the
actual rethinking, defining and implementing the new release process itself did not significantly influence
the result besides having formally accepted the solution as valid. Throughout the observations I find
evidence that the ideas and decisions that went into the solution were coined and made by the collaborative
team itself.
5. Case description
This chapter describes the collaborative effort of rethinking release, and designing and implementing a
solution. A brief overview of the HypR PoC course of events is be presented supported by example artefacts
from the fieldwork.
Referring to the text book maturity model (figure 3.2) the PoC addresses two main areas. Regarding build
and integration it targets bringing the level of practice from Level 0 – Repeatable through Level 1 – Consistent to
Level 2 – Managed in which builds are kept stable and gathered metrics visible. The current target level for
Rethinking Release – a case study
Kenn A. Thisted, 2015
19
testing would be Level 1 – Consistent in which (sufficient) automated tests are part of the development
process. By far most of the work to achieve this level lies within development itself to produce the actual
volume and quality of tests to be automated.
5.1 Case selection
In A&M the Agile Development & Testing team is responsible for the processes, tools, and infrastructure
supporting software development in Topdanmark. As illustrated below (figure 5.1), the HypR PoC was
conducted as a collaborative effort between this team from A&M and a development team in IT Claims. In
order to increase the probability of a success collaboration the development team was selected based on
interest, skills and having a good candidate application for continuous delivery. For simplicity the Agile
Development & Testing team from A&M will be referred to as the tools team in this report.
Figure 5.1 HypR PoC collaboration between A&M and IT Claims
The research project targeted the process and tools supporting the process of committing source code to
version control, building application artefacts, performing tests, and releasing applications into production.
This process is essential in bringing applications from all business areas from development to production.
The project involved both members of the Agile Development & Testing team (shortened to Tools team in
this report) and the development team responsible for the application used as a sample in the project.
Members of the Tools team included specialists in development and testing tools as well as software
engineering infrastructure such as the CI platform. The development team was headed by the architect
responsible for the application and included two developers working with all steps of coding, testing, and
supporting the application.
The specific application and team in question were selected due to the fact that they were frontrunners in
pushing for a more efficient development and release process, and the application was relevant to the case in
being relatively small and decoupled. PoC participants are listed in table 5.1.
Rethinking Release – a case study
Kenn A. Thisted, 2015
20
Alias
Team
Role
Tim
Tools
CI and build infrastructure
Ulrik
Tools
CI and testing tools
Lasse
Tools
Development and testing tools
Dan
Development
Application responsible
Erik
Development
Developer
Viktor
Development
Developer
Anders
Architecture
Build infrastructure
Rasmus
Architecture
Development tools
Table 5.1 – PoC participants (anonymized), their teams and roles
All of these participants had been involved in pre-study discussions on various challenges and shortcomings
of the current process and tools, and suggestions of improvements pointing towards continuous delivery.
During the project, the build infrastructure specialist from the Tools team and the application responsible
from the development team were recurring characters while the other participants attended when possible
and relevant for their area of expertise.
5.2 Course of events
The timeline below (figure 5.2) illustrates the actual design meetings conducted during the PoC and
observed for the study in this project. Regular meetings were held throughout the course of events from
October through January, but as can be seen the last couple of meetings were at more irregular intervals. This
was due to delays resulting from prioritizing other work, but did not in itself impact the result of the PoC. In
order to evaluate the effort and result a review was held including a retrospective. Shortly after the
redesigned tool was released for the involved development team and potentially others to use.
At one point during the study (HypR #1½) the team brought in support from the Architecture team to
discuss and verify the proposed solution at that time. One of the architects had a unique knowledge of the
current build process and infrastructure since he and the infrastructure specialist from the tools team were
the primary designers and implementers of the existing TopUp build and release process about 10 years ago.
Rethinking Release – a case study
Kenn A. Thisted, 2015
21
Figure 5.2: Project timeline
All meetings were recorded and observations noted (in Danish) using the template mentioned in the
methods chapter. Subsequently reflections relevant to the case were made (in English). Tables 5.2 shows an
(anonymized) fieldwork example from one of the observation sheets.
Time Min.
14:30
Observationer (da)
Reflections (en)
1:27 Tim [anonymized] præsenterer design idé
Temporary solution based on current setup
Initiated in Git repository (code projects)
Current setup: Git & Dimensions, TopUp
Jenkins points to Git and works on the code process
(CI)
Is PoC interesting: Yes, we have learned/are
CD:
learning a lot.
Dimensions: Main – Release – Prod
Baseline code from Git / RM ownership
5:17 Export (like today) onto Feature – Deliver to
main.
5:30 14:39 Høvlet ind på en feature
(integrationsbranch) deliveret (af PRM) til
Main -> Trigger automatisk Delivery
14:40 Udvider Feature med et CD-flag
alt. Opfinde en ny type request: "CD"
7:22 14:41 Kører pipelinen igennem [Jenkins]
14:41 Integration Git-Dimensions er ikke
særlig god – gør vi ikke noget ved her.
8:22 14:42 Vi bygger source, vi versionerer ikke
artefakter
8:58 14:42 CD og TopUp fungerer ikke godt
sammen. Det er TopUp, der er problemet
ift. at implementere CD effektivt
09:34 14:43 Realistisk inden jul: Whitelist over
moduler/projekter, som er CD-godkendt
9:50 14:44 Fx TopDoc eller PHP
10:49 14:44 Er der nogle filer udenfor whitelist
Feature ["CD"] Delivered to Main automatically
triggers Continuous Delivery.
- Equivalent to sign-off (Ready for production)
Main === Release (Automatic)
- pending manual Deploy
Versioning: Source vs. Artefacts
=> CD vs. TopUp will not work together
Problem: TopUp process, not Dimensions tool
- Dimensions as a tool (also) caused problems
Whitelist: CD approved applications
- Tree of depencencies...
Example: No COBOL
Table 5.2: Observations and Reflections example
Rethinking Release – a case study
Kenn A. Thisted, 2015
22
Following meetings observations and reflections relevant to the case were then grouped with other obser vations on the same subject. From grouping a pattern of four distinct groups emerged, and were identified by
their main subjects: software engineering tools, target application architecture and considerations, development team process, and additional learnings for possible future consideration. An excerpt of this grouping
and patten exploration is shown in table 5.3.
Pattern / Categories
Obs.
#1
Relevant observations and reflections
Tools
Term: Continuous Delivery (CD)
Application candidates: TopDoc + Letters integ.
Collaboration impact at development team
Term: Release Pipeline
Add tools to existing setup (time constraint)
As far as we can with as little as possible
Release when we want, independent of others
Building release candidates rather than in prod.
Identification of "Main" as basis for CD
Regulation: Separation of concerns
Release control from RM to PO
Team control and responsibility
Importance of "continuous" principle
Value stream of pipeline
Use existing DSCM environments
Different infrastructure for future development
Base PoC on Dimensions (Git or eq. later)
Requires available release environment
Team: code, Maven scripts, func.+unit tests
App.
•
Process
Learnings
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
Table 5.3: Pattern exploration example
6. Analysis
When analysing the observations, as described above, four main themes became visible (see table 5.3):
a) Considerations and decisions regarding tool design i.e. redesign to add functionality to the existing
tools in order to accommodate the purpose (=> Tools).
b) Impact on the application being developed in order to be able to take advantage of the redesigned
tool (=> Application).
Rethinking Release – a case study
Kenn A. Thisted, 2015
23
c)
Realizations and predictions regarding the impact on the development process including the
opportunity for improved agile collaboration between the development team and their product
owner (=> Process).
d) Learnings for the organization both in general and regarding a potential future continuous delivery
solution (=> Learnings).
This chapter presents the tool design and implementation that manifests this PoC's very strict, limited by
circumstances, solution to rethinking release. It will show what it takes, or how little you can “get away
with” and still create a valuable contribution towards continuous delivery.
6.1 Tool design
Due to the time constraint of the PoC the team realized and decided that the design and implementation of a
continuous delivery approach in this context should be based on expanding existing infrastructure rather
than introducing new technology to add to or replace current components. For example they explicitly
decided that introducing Git to replace Dimensions would be out of scope. Figure 6.1 shows the original
design sketch.
Figure 6.1: HypR PoC design sketch
Rethinking Release – a case study
Kenn A. Thisted, 2015
24
The team discussed different options and decided to concentrate the effort on when developed and tested
code is promoted to Main, automating the way through integration and release. From various perceptions of
"continuous delivery", guided by introductory sources on the subject [Phillips et al. 2014; Wooton et al. 2013],
the process would end at potentially shippable software in a Release state ready to be pulled into production
by release management upon request from the product owner.
6.1.1 Extension to user interface
The design of the solution was based on introducing a continuous delivery “check mark” to the existing
Feature in Dimensions. For the development team this means that they will identify the application as CDready (once) and then have the option of supplying the name of a dedicated Jenkins Job in a field, added as
an attribute to the Feature Request in this PoC (see figure 6.2), in order to take advantage of continuous
delivery.
Figure 6.2: "CD Jenkins Job" attribute added to Feature Request
6.1.2 Limitations
The PoC only supports a narrow subset of possible changes to the code base. Changes supported have to be
code only (no database changes) and atomic to the application as in dependencies are not allowed (fig. 6.3).
A detailed description of the solution, including a diagram providing an architecture perspective, was
published on the Topdanmark intranet. The translation of this detailed description (originally in Danish)
explains the solution at a technical level that targets existing and new users of the tool now supporting this
new continuous delivery option of the software development process (see figure 6.3 below).
Rethinking Release – a case study
Kenn A. Thisted, 2015
25
Continuous Delivery in Dimensions - detailed description
A field 'CD Jenkins Job' has been added to the Feature Request in Dimensions. On the
Main BAS a specific CD job is created. Entering the name of this job into the field triggers
the CD process. The job name cannot be one previously linked to automatic creation based
on POM files being delivered to Main. Also this job cannot have upstream nor downstream dependencies.
When a Feature containing the right job name is delivered to Main in Dimensions, this
triggers the Jenkins job to be run on Main. This specially designed job must have the
notification plugin enabled with a post build notification via REST to the CD Dimensions
Bridge. The Bridge will then evaluate the result of the job, and if it is successful deliver the
original Feature directly to the Release branch in Dimensions. On the Release branch the
'ususal' Jenkins jobs will run and build code of the Feature once more. When this build is
completed successfully, a release candidate is ready.
Limitations:
•
Only the Tools team can configure jobs on the Main BAS Server (Creating the
special job must only be done the first time)
•
Only one CD job at a time can run on Main
•
Application changes using this CD concept:
- must be built and delivered using Maven via BAS servers
- cannot contain database changes
- cannot have build dependencies to other applications
(service dependencies are allowed)
- other applications cannot have build dependencies to this application
Figure 6.3: HypR PoC architecture and detailed description
6.1.3 The extent of the change
The existing Dimensions tools code base consists of about 10,000 lines of code. Implementing this solution
changed only about 70 lines of code. In addition to that the added CD Bridge (figure 6.3) consists of about
200 lines of code.
Rethinking Release – a case study
Kenn A. Thisted, 2015
26
// Then deliver items
deliverItems(items , fromBranch , toBranch , deliverReport) ;
//Launch any Continuous Integration jobs
handleContinuousDelivery(toBranch , requests) ;
// Finally deliver request(s)
if ( mode .equals(DeliverModeEnum. DELIVER_MODE ))
{
for (RequestWrapper request : requests)
{
DLog. info ( "Completing " + request.getName()) ;
doDeliverMode(request , fromBranch , toBranch , deliverReport) ;
}
}
/**
* This method handles any Continuous Delivery requests
*
* @param toBranch the branch to be delivered to
* @param requests the delivered requests
*/
private void handleContinuousDelivery (Branch toBranch , List<RequestWrapper> requests)
{
if ( toBranch.isMain() )
{
String jobName = getJobName(requests) ;
if ( jobName != null && ! "" .equals(jobName.trim()) )
{
String url = "http://" + objectFactory. getBaseDatabase().toLowerCase() + "main/jenkins/job/" + jobName + "/build" ;
HttpClient httpClient = new DefaultHttpClient() ;
HttpPost httpPost = new HttpPost(url) ;
try
{
HttpResponse response = httpClient.execute(httpPost) ;
if (response.getStatusLine().getStatusCode() == 200 ||
response.getStatusLine().getStatusCode() == 201 )
{
DLog. info ( "Jenkins Continuous Delivery job started. StatusCode="
+response.getStatusLine().getStatusCode()) ;
}
else
{
DLog. info ( "Jenkins Continuous Delivery job could NOT be started.
StatusCode=" +response.getStatusLine().getStatusCode()+ " - Feature is now part of the
normal release..." ) ;
removeJobName(requests) ;
}
}
catch (IOException e)
{
DLog. error ( "Jenkins Continuous Delivery job could not be started. IO
Message: " +e.getMessage()) ;
removeJobName(requests) ;
}
}
}
}
Figure 6.4: Code example with added handleContinuousDelivery method.
Rethinking Release – a case study
Kenn A. Thisted, 2015
27
The above example (figure 6.4) shows (in bold) the small extent of the code change needed to implement the
continuous delivery design. Basically one handleContinuousDelivery method is added handling the
request for continuous delivery by verifying that this happens on the Main branch, and that a valid jobName
is supplied. Basically this along with the CD Bridge forms the implementation.
6.2 Application impact
The application presented by the development team in this PoC had to undergo a couple of changes during
the project.
Quite early in the PoC the team faced a requirement involving a database schema update, and since this is
not supported by this continuous delivery solution, that requirement was threatening the completion of the
project within the time frame. Given priority, however, a clever workaround was devised, that allowed the
project to continue without much interruption. The database schema update was split in two, such that
additions to the schema were implemented separately in an ordinary release before the continuous delivery
changes, while deletions from the schema were held back until the PoC was completed. This way we were
able to accommodate both real world requirements and the continuous delivery PoC at the same time.
Also during the time of the PoC the application under work was split into two separate parts: one front-end
part and one back-end part. From an architecture perspective this separates functionality in and near the
user interface from handling database persistence. This split would allow the front-end to be released
separately from, and at a higher frequency using continuous delivery, than the back-end, which would still
have to follow the ordinary release cycles.
In addition to these direct application impacts the PoC also change the teams perception of tests. They
realised that test coverage for a successful run to be trusted sufficiently to release the application based on
that will present a new challenge. This means that the team will have to build and maintain a sufficient set of
unit tests, and balancing unit tests with higher level tests e.g. functional tests.
Finally during the PoC the team realised that in order to be automated, which is a requirement in continuous
delivery, database schema changes will eventually have to be versioned and handled just like code. Also
handling test data is expected to be a challenge, which we did not look further into during this project.
Rethinking Release – a case study
Kenn A. Thisted, 2015
28
6.3 Process impact
The impact of the way the development team will work with the new release process also includes changes
in their interactions with their product owner and end users.
Continuous delivery will allow fro proper agile slicing of small vertical user stories. Due to the monthly
releases in TopUp, slicing and prioritizing user stories used to be more targeted towards composing a batch
of user stories that would fit the monthly capacity. The team explicitly mentioned the impact that the
opportunity of continuous delivery will have on the dialogue with their product owner in being able to
prioritize and release smaller, more targeted user stories.
This also means that the team will be able to take advantage of getting user feedback much earlier than
before and thus being able to respond to change more efficiently. This is true both after releasing but also as
early as when presenting potentially shippable increments in Release.
6.4 Learnings for the organisation
Throughout this project learnings were part of observations and reflections made as fieldwork. In addition a
final retrospective was held to facilitate a shared team reflection and evaluation continuing the participatory
aspect. Significant learnings for the combined team and the IT departments in general are listed here.
•
Despite the restriction in time and technology we were actually able to design and implement a very
narrow continuous delivery solution confirming that we could in fact achieve the goal of a
significantly higher frequency for software releases in Topdanmark. For now it is restricted to a very
small subset of applications, but is expected to serve as a basis for further development and
initiating experiences with working this way.
•
To expand this effort and create a consistent solution including other applications, we must involve
IT operations in order to ensure sufficient capabilities from Release into Production.
•
The technologies used to implement this PoC will not be sufficient to implement continuous delivery
for general use in Topdanmark. Since moving all existing applications to continuous delivery is not
realistic this implies the need to build a new process separate from TopUP implementing more
Rethinking Release – a case study
Kenn A. Thisted, 2015
29
appropriate tools like distributed version control (e.g. Git) and versioning of binary artefacts to
support application dependencies across multiple versions “at the same time”.
•
There was general agreement that in implementing this as a collaborate effort together with one
primary target team brings essential focus to the task at hand. We were simply able to better scope
the effort, and descope unnecessary features, and customize the design and implementation
according to the needs required to support the specific application supplied by the team. Taking the
next and possible future applications into consideration was easy to avoid working like this.
•
As stated by one of the developers even the solution implemented in this PoC is already impacting
the way the development team works with development and user stories in collaboration with the
product owner representing their line of business.
In summary the final design and implementation proved to be significantly simpler than expected at the
outset. Realizing that the technological implementation needed to achieve this within the short time span
would not be able to support a future general solution, motivation was challenged, but in the end the
common perception is that we gained important learnings for our next step, while already being able to take
advantage of and gain experience with more frequent releases with select applications.
In addition we gained experience in how to address implementing continuous delivery. We learned that
close collaboration is a key aspect and helps target a successful effort. Another important element was that
the development team from the outset had substantial understanding and knowledge about the concepts
involved in continuous integration and delivery (see related work above). This is recognized as being a
prerequisite for an efficient and even successful adoption of the concept.
7. Discussion
Regarding software engineering a sound understanding of the aspects of continuous integration and
continuous delivery is key to introducing these subjects into an organization let alone implement solutions
based on them. One will have to navigate ambiguous definitions across different sources of information but
should anyway be able to extract the essence of the intentions behind the concepts.
Basic sources of information are important for basic information, but once one begins digging deeper into
Rethinking Release – a case study
Kenn A. Thisted, 2015
30
the landscape of continuous engineering, great value of understanding various aspects, assessing the
organizational level, and identifying valuable activities are to be found using maturity models.
Collaboration is valuable
When reading about and discussing continuous software engineering often focus is on the technical aspects
and implementations of software development and release processes. This is perhaps understandable since
these support the extent of automation that is essential for the success building and maintaining infrastructure supporting these processes. Another important issue to consider, however, is the value of
collaboration. During this project we learned that joining forces in a collaborative team helped us focus the
scope of the effort and establish the right level of ambition for the solution. In retrospect though, we could
have been more efficient. Due to other priorities with both teams we did not manage to obtain quite the close
level of collaboration that had been envisioned at the outset. We have no doubt in the value of collaboration,
and I believe that having been able to “enforce” this even more, perhaps even by co-locating the teams,
would have increased efficiency in implementing and verifying the solution.
It takes less than you think
In the beginning of the HypR PoC most participants saw a considerable challenge in implementing what was
then perceived as sufficient infrastructure technology to support continuous delivery. Based on initial
perceptions of the range of technologies often discussed when addressing the subject, at least a few of the
team members did not find it realistic to produce a solution within the time frame given. In innovation,
however, restrictions often promote creative ideas, and thus the team managed to focus design and
implementation of the solution on a simple idea involving only the addition of one small component (the CD
Bridge) and very small changes to the existing infrastructure (additions to the code). This way the solution is
somehow in contrast with the general perception of continuous delivery infrastructure.
Small and smart automation
The landscape of tools supporting continuous software engineering consists of both piecing together
industry standard open source components and emerging large commercial frameworks from new and
existing vendors. One advice to take away from this PoC, however, is that based on your existing
infrastructure it is definitely worth considering to start introducing continuous integration and delivery as
concepts by expanding your existing process support with small and smart automation supplements rather
Rethinking Release – a case study
Kenn A. Thisted, 2015
31
than thinking that a complete solution must initially be built from scratch.
Prepare to leave behind
That said if you are not a greenfield operation, but rather have a considerable amount of legacy software,
you must realise that not all software fits easily into the concepts of continuous software engineering. In
order to take advantage of continuous software engineering where it makes immediate sense and supports
business needs for frequent releases and fast feedback one should not hesitate implementing solutions
supporting these needs. For mature organizations this would generally mean that much software would still
need to be developed and released as usual and as such be left behind. Subsequently one could consider if
and how to move or evolve this software to fit into the continuous concepts.
Architecture impact
Software architecture must be considered in relation to continuous software engineering. A loosely coupled
component-based architecture fits better into continuous delivery than a monolithic architecture where the
whole application must be released as one. The target application in this PoC represents two examples of
how to create a fit for continuous delivery. For one the application is actually an extension of a large existing
system, but it is developed as a separate component. And the split between user interface and persistence
layer that was mentioned earlier further supports being able to take advantage of continuous delivery.
8. Conclusion
Rather than letting us be overwhelmed by the broad spectrum of continuous software engineering efforts
described in literature and maturity models, a targeted effort that makes a difference goes far and can
provide great value on its own. One thing is the technical solution of automating continuous delivery, but
also important is the organizational learnings and acknowledgement that arise from beginning to embrace
this improved way of working. Combining the tools and process aspects of continuous delivery is what truly
supports agile software development.
As show in this case study it is possible with small means to achieve a significantly higher release frequency,
and I can only encourage anyone to explore the options. Already having experiences with agile
development, continuous integration, and deployment pipelines are important shortcuts along with a strong
Rethinking Release – a case study
Kenn A. Thisted, 2015
32
mindset of striving to automate the processes involved.
Quality is an attribute inherent in choosing continuous delivery as an approach building on the foundations
of agile development methods and continuous integration. All things equal this neither improves nor
decreases the quality of software produced this way but rather maintains the same level of quality as before.
The importance of a desired sufficient level of quality as a prerequisite for releasing software more often is
significant though. If not one will just repeat bad practices more frequently and produce bad software faster.
But all things are not equal, and I believe that the active decisions having to be made regarding software
when considering continuous delivery will in itself create attention to improving software quality.
The case study also demonstrated how a continuous delivery solution could be designed and implemented.
The solution builds on existing infrastructure and initiatives and emphasizes starting with experimenting
with small and smart additions to the existing tools rather than from the outset expecting to implement a
full-fledged framework from scratch. Conducting this tightly scoped PoC required creative thinking and we
managed to design and implement a solution that was significantly different from our initial perceptions of
what would be needed.
Future Research
This case study has inspired a small series of interesting candidates for future research:
•
Employing the experience of small-scale implementations of continuous delivery in additional case
studies in order to confirm or compare the results.
•
Studying the effect (process, architecture) of introducing continuous delivery in development teams.
•
Further digging into the different perceptions and definitions of, as well as relations between, the
various continuous * concepts and technologies in continuous software engineering.
•
Elaborating on the evolution of different continuous delivery maturity models, the relation between
them, or their effect when systematically applied to industry contexts.
•
Relating the experiences of this study to the need of supporting multiple development and release
cycles or rythms in the field of software ecosystems [Dittrich 2014] and/or the recent concept of
bimodal IT [Colella et al. 2014; Gartner 2014].
Rethinking Release – a case study
Kenn A. Thisted, 2015
33
References
[Bass et al. 2014]
Len Bass, Ingo Weber, Liming Zhu. 2015. DevOps - A Software Architect's Perspective.
Draft chapters retrieved from SlideShare.net July-September 2014 via Australia's
Information Communications Technology Research Centre of Excellence (NICTA).
http://www.ssrg.nicta.com.au/projects/devops_book/
[Beck 1999]
Kent Beck. 1999. Embracing change with extreme programming. Computer 32, 10
(October 1999), 70-77
[Beck et al. 2001]
Beck et al. 2001. Principles behind the Agile Manifesto. Retrieved 2nd March 2015
from http://agilemanifesto.org/principles.html
[Bosch (Ed.) 2014]
Jan Bosch (Ed.). 2014. Continuous Software Engineering. Springer International
Publishing Switzerland.
[Bratteteig et al. 2013]
Bratteteig et al. 2013. Methods: organising principles and general guidelines for
Participatory Design projects. In Rutledge International Handbook of Participatory
Design. Ruthledge, New York, NY.
[Colella et al. 2014]
Heather Colella, Tina Nunno, Andy Rowsell-Jones, Mary Mesaglio. 2014. Three Steps
to Successfully Implementing Bimodal-Aware IT Governance. Gartner, Inc.
Retrieved 2nd March 2015 from http://www.gartner.com/document/2901217
[Dittrich 2014]
Yvonne Dittrich. 2014. Software engineering beyond the project – Sustaining
software ecosystems. Information and Software Technology 56, 11 (November 2014),
1436-1456.
[Fowler 2006]
Martin Fowler. 2006. Continuous Integration. Retrieved 2nd March 2015 from
http://www.martinfowler.com/articles/continuousIntegration.html
[Fowler 2013]
Martin Fowler. 2013. Continuous Delivery. Retrieved 2nd March 2015 from
http://martinfowler.com/bliki/ContinuousDelivery.html
Rethinking Release – a case study
Kenn A. Thisted, 2015
34
[Gartner 2014]
Gartner Symposium. 2014. Evaluate Rate of Change, Required Governance and
Acceptable Risk. Presented at the Gartner Symposium, 9-13 November 2014,
Barcelona, Spain
[Humble and Farley
Jez Humble and David Farley. 2011. Continuous Delivery: reliable software releases
2011]
through build, test, and deployment automation. Addison-Wesley/Pearson Education,
Boston, MA.
[Humble and Russel
Jez Humble and Rolf Russel. 2009. The Agile Maturity Model – Applied to Building and
2009]
Releasing Software. ThoughtWorks Inc., San Francisco, CA.
[Humble et al. 2014]
Jez Humble, Joanne Molesky, and Barry O'Reilly. 2014. Adopt Lean Engineering
Practices. In Lean Enterprise – How High Performance Organizations Innovate at Scale.
O'Reilly Media, Sebastopol, CA.
[Jacobsen et al. 1999]
Ivar Jacobsen, Grady Booch, and James Rumbaugh. 1999. The Unified Software
Development Process. Addison-Wesley, Reading, MA.
[Minick 2014]
Eric Minick. 2014. Continuous Delivery Maturity Model. IBM urban{code}.
Retrieved 2nd March 2015 from
https://developer.ibm.com/urbancode/docs/continuous-delivery-maturity-model/
[Olsson et al. 2012]
Helena Holmström Olsson, Hiva Alahyari, and Jan Bosch. 2012. Climbing the
"Stairway to Heaven" – A Multiple-Case Study Exploring Barriers in the Transition
from Agile Development towards Continuous Deployment of Software.
38Th Euromicro Conference on Software Engineering and Advanced Applications (SEAA).
Cesme, Izmir, Turkey.
[Olsson and Bosch
Helena Holmström Olsson and Jan Bosch. 2014. Climbing the "Stairway to heaven":
2014]
Evolving From Agile Development to Continuous Deployment of Software. In
Continuous Software Engineering. Springer International Publishing Switzerland.
Rethinking Release – a case study
Kenn A. Thisted, 2015
35
[Phillips et al. 2014]
Andrew Phillips, Michiel Sens, Adriaan de Jonge, and Mark van Holsteijn. 2014. An
IT Manager's Guide to Continuous Delivery. XebiaLabs, Boston, MA.
[Praqma unknown]
Unknown. Continuous Delivery Maturity Model. Praqma.
Retrieved 2nd March 2015 from
http://www.praqma.com/sites/default/files/img/cdmaturity_paper_5_0.pdf
[Rehn et al. 2013]
Andreas Rehn, Tobias Palmborg, and Patrik Boström. 2013. The Continuous Delivery
Maturity Model. InfoQ. Retrieved 2nd March 2015 from
http://www.infoq.com/articles/Continuous-Delivery-Maturity-Model
[Robson 2002]
Colin Robson. 2002. Designs for Particular Purposes: Evaluation, Action and
Change. In Real World Research, 2nd Edition. Blackwell Publishing. Oxford, UK.
[Simonsen and
Jesper Simonsen and Toni Robertson. 2013. Participatory Design: An Introduction. In
Robertson 2013]
Rutledge International Handbook of Participatory Design. Ruthledge, New York, NY.
[Ståhl and Bosch 2014] Daniel Ståhl and Jan Bosch. 2014. Continuous Integration Flows. In Continuous
Software Engineering. Springer International Publishing Switzerland.
[Wootton et al. 2013]
Benjamin Wootton, Mark Prichard, and Andrew Phillips. 2013. Preparing for Continuous Delivery. DZone, Inc., Cary, NC
…
Rethinking Release – a case study
Kenn A. Thisted, 2015
36