On the Responsibilities of Software Architects and Software Engineers

On the Responsibilities of Software Architects and Software Engineers

On the Responsibilities of Software Architects and Software Engineers in an Agile Environment: Who Should Do What? Antony Tang Ton Gerrits, Peter Nacken Hans van Vliet VU University Océ Technologies VU University Amsterdam the Netherlands Amsterdam the Netherlands [ton.gerrits,peter.nacken]@oce.com the Netherlands [email protected] [email protected] ABSTRACT not easily defined. Architecture frameworks and standards such as As there is considerable freedom for software workers to decide TOGAF [2] and ISO/IEC 42010 [3] only provide general what to do in an agile environment, there is a need to be explicit guidelines. It is up to individual organizations and their architects about social aspects such as task ownership between roles and the to interpret those guidelines to define work practices and agility in owning those tasks. We have conducted interviews and a responsibilities, so architects’ responsibilities are subject to survey at a large organization to explore these issues. The results interpretation and individual preferences. indicate that there are areas where architects and software When an architect adjusts his/her responsibilities to suit the engineers have different views on task ownership. Some of the project situation, their responsibilities may not be made explicit to less exciting tasks such as documentation and issue clarification the software development team. Furthermore, in an agile then easily become a hot potato nobody wants. environment software architects and developers often have overlapping responsibilities, the division of responsibilities Categories and Subject Descriptors cannot be sharply defined. For instance, both roles may do D.2.1[ Requirements / Specifications ], D.2.2 [ Design Tools and analysis, design, documenting, coding and even testing. The Techniques ]. division of responsibilities is further complicated when there are different levels of software architect in a project. General Terms If the mutual understanding of some responsibilities and tasks is Design, Human Factors. not sharply defined and the workers in a software team do not clearly communicate what each person would do, a number of issues can occur. Firstly, architects may be internally focused, Keywords working in an ivory tower or working on their technical design in Agile development, design responsibilities, task ownership. isolation, resulting in undesirable products [4], and the same can be the case for software developers [5]. Secondly, a 1. INTRODUCTION misunderstanding of responsibilities may create delivery gaps Software architects have many responsibilities in a software team. because each person assumes the others would do the work. They gather and understand the requirements from users and Thirdly, there may be unrecognized issues in requirements and stakeholders, analyze the technical feasibility of the design and design as no one has complete knowledge of the situation. implementation, ensure that the implementation fits the project We studied these collaboration aspects within Océ Technologies, scope, budget and schedule [1]. Most important of all, software a large organization that has applied an agile development architects translate and communicate relevant information methodology in the past five years. The organization is flat and between different groups of stakeholders such as business users, workers are encouraged to be proactive in owning up to work managers, other architects and technical specialists and software responsibilities. Océ Technologies has deliberately opted for a flat engineers. structure, as opposed to a hierarchical structure, to foster With the wide variety of functions that architects have to perform, cooperation, innovation and entrepeneurship. In this paper, we their responsibilities can depend on the project situation and are explore the mutual expectations of architects and software engineers with regards to each other’s responsibilities and task ownership. The research involved over 50 architects and software Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies engineers at Océ Technologies. We use two research methods in are not made or distributed for profit or commercial advantage and that this study: interviews, followed by a survey. copies bear this notice and the full citation on the first page. To copy In the interviews, architects and software engineers have indicated otherwise, or republish, to post on servers or to redistribute to lists, that documentation is an area that needs improvement. From the requires prior specific permission and/or a fee. SSE’11 , September 5, 2011, Szeged, Hungary. survey, respondents generally agree that documented knowledge Copyright 2011 ACM 978-1-4503-0850-2/11/09...$10.00. is important. They also agree on the general responsibilities of architects and software engineers. But when it comes to pinpointing who should perform certain tasks and what the extent agility and architecture (see for instance the special issue of IEEE of those tasks is, disagreements between the roles surface. Some Software [12]). Especially in agile software product lines, there is of the less exciting activities such as issue clarification and an inherent tension between the level of the product line and that documentation become a hot potato. of individual teams realizing components thereof. At the level of the product line, one wants to plan and lay down the architecture of the product line. At the level of individual components, an 2. BACKGROUND agile team wants to be agile, and not bother about documentation 2.1 Related Work and other long-range issues [13]. Baskerville et al. gives an There are many processes, methods and best practices to guide the interesting longitudinal study of the evolution of this tension [14]. practice of enterprise, system and software architecture. These In our literature search, we have found no empirical studies with a processes and methods typically define the outcomes and the steps specific focus on mutual expectations of job responsibilities and to achieve those outcomes. However, the implementation of a task ownership between software workers in an agile development process or method needs to be tailored for each organization. The environment. responsibilities and tasks need to be defined according to the people and the type of software being produced. Let us consider 2.2 The Agile Software Organization two extremes. Organizations that produce safety critical software Our study was conducted in Océ Technologies. Océ Technologies can be rigid in defining the responsibilities and tasks that software produces high-end printers for the business markets in high- architects need to perform to ensure that all the work steps are volume printing, wide-format printing and office printing. Printer followed. On the other hand, some organizations practice agile software is one of the main components in a printer. The software development in order to receive early user feedback, and the interacts with users, renders images and controls the print engine. responsibilities of an architect can be more flexible. Development of a printer product is executed by a project team, part of which is responsible for software development. Each In the latter case, the key job responsibilities of an architect in software project has a lead architect. There are many sub-teams in terms of design, documentation and communication [6] can be a software project and each sub-team consists of typically 2-7 defined at a high-level without a clear articulation of what tasks people. Each sub-team has a unit architect and several software and what steps are required, and who would have ownership. The engineers; they are responsible for sub-system development. All details are left to the architects and the software engineers to work teams conduct daily scrum meetings. Team sprints are typically out. There may be explicit agreements on who should do what or every two weeks, and a release is typically every eight weeks. the agreements may be vague when the responsibilities are shared Software engineers are highly motivated and knowledgeable. and more than one party is capable of performing the tasks. Documentation is kept to a minimal on purpose. The culture can Workers in such a team have a tacit understanding of each other’s be described as innovative where the best people are assigned to responsibilities through empowerment and self-motivation [7]. the problems, and job rotation is common. Hsieh et al. proposes an AxE model [8] to represent the Océ Technologies has employed agile development methodology differences in what is anticipated (A) to be delivered by a supplier in the past five years. Their development environment is a mixture of some information and what is expected (E) by a consumer of of plan-driven design and agile development. This mixed that information. For instance, an architect produces a approach of planning and agile is similar to the one described in requirement specification or an architecture design specification [15]. Using approved roadmaps and product features as a basis, which the software engineers use as a basis for implementation. A architects create a high-level architecture design. A high-level mismatch in conveying information between the two parties can architecture design must be approved by management and the happen with the content, the quality or the timing of the delivery architecture council, and is developed in consultation with unit of

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    8 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us