Scrumban

From apppm
(Difference between revisions)
Jump to: navigation, search
(Applications)
(Applications)
Line 106: Line 106:
 
|'''Result (Scrumban)'''
 
|'''Result (Scrumban)'''
 
|-
 
|-
|Limitation 1
+
|No lead time management
 
|
 
|
12
+
Just-In-Time
 
|
 
|
5
+
Decisions are taken and work is done when is needed
 
|-
 
|-
|Limitation 2
+
|Restricted team size
 
|
 
|
 
13
 
13
Line 118: Line 118:
 
5
 
5
 
|-
 
|-
|Limitation 3
+
|Limited roles in a team
 
|
 
|
 
9
 
9
Line 124: Line 124:
 
4
 
4
 
|-
 
|-
|Limitation 4
+
|Reduced external stakeholders' contribution within sprints
 
|
 
|
 
10
 
10

Revision as of 20:39, 20 February 2021

Made by Xabi Martínez de Zabarte (s210323)

Contents

Main Idea

Introduction

Scrumban is a project management framework, mainly used by software development teams[1]. It is a relatively new tool which is still in a development stage. It is essentially an improved version of Scrum, which maintains its fundamental characteristics and adds Kanban principles. Some of these principles are pull system, workflow, standard work, performance metrics and continuous improvement. Contrary to popular belief, Scrumban is not exactly a mix between Scrum and Kanban, but a pathway starting at Scrum and ending at a more evolved development framework. [1]

The idea was first introduced by Corey Ladas, a pioneer methodologist in the area of software development, who published in 2009 the book “Scrumban: Essays on Kanban Systems for Lean Software Development”. Corey Ladas defined Scrumban as a transition method for teams using Scrum. One of its most important features is that it can be implemented at any level of an organisation. Scrumban arises from some limitations detected at Scrum throughout the years and feedback from practical experience. These limitations, set out in the following sections, have been the subject of speech by some of the experts in the methodology.

Ken Schwaber, co-founder of Scrum, publicly made the following statement: “I estimate that 3 out of 4 organisations using Scrum will not obtain the expected benefits out of the framework. (…) Scrum exposes the inefficiencies or dysfunctions within the product development practices at an organisation. The intention of Scrum is to make them visible in order to solve them, but unfortunately many organisations change Scrum to adapt to those inefficiencies instead of solving them.”[2].

Mike Cohn, an Agile-Scrum community leader, also criticized Scrum teams for not being focused on finding innovative solutions to the challenges they face. Cohn was not critical at the Scrum framework itself, but at the increasing mentality among practitioners, which he considers prioritizes a safe approach for completing the tasks rather than promoting innovation. [2]

To sum up, Scrumban arose with the goal of overcoming weaknesess of Scrum, in order to transform it to a more profitable framework, combining the best of Agile and Lean methods.


What is Scrum?

Scrum framework overview.[3]
Scrum is a software development framework, the most well-known among all. At teams using Scrum, participants select items (loads of work) of high priority from the Product Backlog, a list with tasks assigned to the team. The Development Team oversees completing those assessments within the duration of a work cycle, called Sprint. The selected item is called Sprint Backlog. One of the main goals of the framework is to make each Sprint more effective than the previous one. Once a sprint ends, completed items are delivered and non-completed items are returned to the Product Backlog. [3]


Teams In most of the cases, from 3 to 9 people. [4]


Roles Individuals at teams have different roles, which are the Scrum Master, Product Owner and Development Team. [3]


Meetings Each sprint begins with a Sprint Planning Meeting arranged by the Scrum Master, to which all members of the team are called. Other stakeholders may also be part of the Sprint Planning Meetings. Daily Scrums or short meetings are also held every day, where all team members reunite.


Work cycles Teams using Scrum work in 1-to-4-week periods or cycles, called sprints. These periods last for 2 weeks in most of the cases.


Rules It follows strict rules.



What is Kanban?

Kanban set of principles overview.[3]
Kanban is a continuous process, unlike sprints in Scrum. It is a set of principles applicable to a broad diversity of situations. In this case, work items are pulled directly from the Product Backlog. Each of the columns from the board has a strict limit of Work In Progress (WIP). This is to ensure items are pulled throughout columns within the minimum time. A column with empty spots is an indicator to pull items from the previous column. In a Kanban context, products are delivered as soon as they are done. Continuous revisions are made to guarantee the process gets more efficient and effective in order to improve the quality of the results. The results of the work delivered by the team are always subject to improvement, no matter how good they still are.


Teams No limitations. [4]


Roles Agile Coach, a Product Owner and the Development Team.. [3]


Meetings Daily Standup meetings where all team members are present.


Work cycles A continuous workflow.


Rules It follows relaxed rules.



Applications

Limitations of Scrum Inputs from Kanban Result (Scrumban)
No lead time management

Just-In-Time

Decisions are taken and work is done when is needed

Restricted team size

13

5

Limited roles in a team

9

4

Reduced external stakeholders' contribution within sprints

10

4


What are the limitations of Scrum?

  • No lead time management.
  • Restricted team size.
  • Limited roles in a team.
  • Limited external stakeholders' contribution within sprints.
  • No workflow management within sprints.
  • No vision about internal state of work.
  • No iterative approach.


How does Scrumban overcome them?

  • Delivered quality. No time estimations are made for specific work, the result must be as good as possible and is not subject to a time frame.
  • Just-in-Time. The decisions are taken and the work is done when is needed.
  • Short delivery terms. The work is delivered within the minimum time.
  • Kaizen. All work and processes are subject to a continuous improvement.
  • Waste reduction. Exclusion of whatever that is not adding value to the client or customer.


asdf[5]

When should teams use Scrumban?

-Maintenance projects.

-Hardening phases and product packaging.

-New product development teams.

-Scrum teams having workflow, resources and processes issues.

-Management of improvement after implementing Scrum.

Implementation of Scrumban in teams working with Scrum

As mentioned before, Scrumban was conceived as a pathway from Scrum to a more evolved working environment. At an organisation, teams which have experience working with Scrum are more likely to understand Scrumban framework from the very beginning. In order to get the most out of Scrumban, there is a set of activities available for Team Managers to introduce the new working environment and organise their teams before starting to work. [1]


Kickstar process activities

1. Introductory Remarks: Two important factors all team members should know before beginning:

  • The transition to Scrumban does not mean a significant change in team roles or current responsibilities. It is important to specify this point in order to avoid barriers caused by fear to change.
  • Every team member must understand and agree with his or her purpose at the team.


2. Stakeholder Evaluation: Service orientation is a relevant factor in Scrumban framework. One of the first activities is to identify stakeholders and any pain they could have. In order to achieve a continuous improvement, it is highly important to get stakeholders to work with the team, together in the same direction. According to Klaus Leopold, the following activities could be helpful for this stage:

  • To visualize the power and influence of each stakeholder, using cards of different sizes.
  • To visualize the degree in which each stakeholder involved supports the initiative. Draw a center point, and place the cards used before around, at different distances from the point. The closer to it, the bigger support from each stakeholder.
  • To visualize the frequency of relationships among stakeholders. Draw different line types linking stakeholders’ cards. The thicker the line, the stronger the relation. Discontinuous lines mean sporadic relations.
  • To visualize the quality of relationships among stakeholders with special symbols. As an example, a circle could mean a friendly/healthy relationship, a triangle a neutral/weak relationship, a cross an adversarial relationship.

These tasks create a clear vision of what parts are more powerful and the current status of relationships; enabling a better understanding of the work to be carried out in order to find a common solution. It is a helpful activity to prioritize a pain solving approach.


3. Defining purpose and success criteria: High levels of performance are most likely to be achieved by teams who have a common and well-defined purpose. Previously to beginning to work, the Team Leader should ask the following question: “Why does our Team exist?”. After that, the team will discuss about the answer. When everyone agrees with the answer, it is time to begin the following activity.


4. Identifying how work is done: The objective is to understand in a realistic way the situation of the team. What work is requested, who makes the demands (internal or external clients), how demands are communicated, which is the frequency and quantity of orders, etc. This activity is also helpful to categorize the types of work of the following activity.


5. Understanding Work types: The Team Leader should ask the following questions to the team and let them some time to think and answer them. What types of work have more value for our clients and/or partners? What types of work have a higher and lower demand in quantity? What types of work are more urgent? What types of work are more aligned with the team’s purpose? What types of work are less aligned with the team’s purpose? After considering these questions, work types could be classified according to the following categories.

  • By source. For instance, a specific product, maintenance items or retail banking.
  • By size. In terms of effort.
  • By results. For instance, product launch or analysis reports.
  • By type of flow. For instance, development, maintenance or analysis.
  • By risk profile. For instance, standard work, urgent work, compliance with regulations.
  • By relevance.


6. Basic Management: If the team to which Scrumban is being introduced has been using Scrum before, GetScrumban game is an interesting tool to better understand those new features. The game simulates how a software development team using Scrum can broaden its current capabilities, overcome common challenges or create new ways to improve agility. The game experiments with principles such as pulling system vs. work assignment, evolving adjustments vs. radical change, delay costs vs. subjective prioritization, different service classes vs. a single workflow, or a continuous workflow vs. iterations (sprints).

Creation of the work board

Once the kickstart activities are completed it is time to create the working tool. As mentioned before, Scrumban framework is a pathway starting from Scrum and ending at a more evolved working tool. For this reason, the board used in Scrumban looks similar to the one used in Scrum. This board can be both physical -using a cardboard and post-its- and digital -using applications such as Trello-.

Step 1. The board in a Scrumban framework has several columns, where developers will put notes. Each note refers to a task or work to be done. Each column refers to the phase in which the work is. The notes will advance throughout columns, from left to right. The objective is they can reach the final column within the minimum time, but without establishing time limits. Columns can be defined, from left to right, as To do, Ready, Designing, Developing, Testing, and Done.


Step 2. The following step is to define Work In Progress (WIP) limits. Consists in defining a maximum number of positions for each column, or said in other words, a maximum amount of work in a same phase. This restriction enables the pull system from Kanban. This means tasks will be automatically pulled through columns -to the right- whenever a position is left empty. Thanks to it, a constant and well organised workflow is ensured.


Step 3. Afterwards, the 3 columns of the in-progress phases are divided into 2 subcolumns, defined as In Progress and Done.


From left to right, steps 1, 2 and 3.[3]


Step 4. The following step is to define a minimum number of work in the To Do phase. This limit will be a meeting activator. Instead of arranging meeting every certain period, the team will reunite whenever the work To Do is above the line. In other words, team meetings are triggered by the work itself. This rule allows to close the workflow circle, and guarantees the team is always on the look for new tasks and activities to improve the quality of the work under development. At the same time, it maintains all team members active and busy.


Step 5. The next step is to reorder continuously tasks in columns. The most relevant or urgent tasks will be reordered to the top of the columns, in order to prioritize them and make them flow throughout the board within the minimum time.


Step 6. A couple of important aspects to understand Scrumban are the following. On the one hand, work is not assigned sistematiacally to team members. Unlike in Scrum, teams must not early bind work. The goal of the method is to ensure a good workflow and always maintain all members active, that is why an individual will not be in charge of a task from beginning to end. On the other hand, time estimations must not be made. The quality of the delivered work is more important than the timeslot in which it is done.
From left to right, steps 4, 5 and 6.[3]



(to be continued)

Limitations

Weaknesses of Scrumban

Like any other management method, tool or framwork; Scrumban also has some limitations. In this case, mainly because the fundamentals of Scrumban are very similar to those of Scrum, there are some weaknesses that Scrumban has inherited from Scrum. Some of them are mentioned next:


  • Team size:
  • External stakeholders:
  • Role
  • Skill and expertise
  • Distributed environment
  • Documentation
  • Estimation


[2] (p. 1631.)

Annotated bibliography

The references provided next may be consulted for further reading on the topic of software project management framework Scrumban.

  • Ladas, C. (2009) Scrumban: Essays on Kanban Systems for Lean Software Development. Lean Series. Seattle WA: Modus Cooperandi Press.
-First book explaining the fundamentals of Scrumban, written by the methodologist who first conceived the method. Ladas explains how agile methodologies such as Scrum have helped software developers to be more efficient, while at the same time there is still room for more benefits. Lean methods such as Kanban can make these processes even more powerful and profitable. The author provides essays for real-world cases to give teams the background to create more robust practices.


  • Bhavsar, K. et al. (2020) Scrumban: An Agile Integration of Scrum and Kanban in Software Engineering, International Journal of Innovative Technology and Exploring Engineering (IJITEE), vol. 9, issue 4. ISSN: 2278-3075.
-This recently published paper exposes how emerging software engineering technologies seek an Agile process and framework for their management at an organisational level. The authors explain the limitations of Scrum, and how the formation of hybrid framework Scrumban can be a solution to the challenges of Scrum, considering as well the limitations of Scrumban.


  • Reddy, A. (2015) The Scrumban [r] evolution: getting the most out of Agile, Scrum, and lean Kanban. Addison-Wesley Professional.
-The author explains the role of Kanban as a catalyst to increase the value of existing software development processes, augmenting the benefits of Scrum. It is a comprehensive, coherent and practical book in order to help teams to implement Scrumban and get the most out of it.


-I would like to make a special mention to Gary, whose content regarding Scrumban, both in his YouTube channel and his website (Development That Pays) was very useful for me to understand the concept at the very beginning. I highly recommend his contribution to everyone who has never heard about Scrum and Scrumban before.

References

  1. 1.0 1.1 1.2 A. Reddy.(2015) "The Scrumban (R)evolution", Software Project Management
  2. 2.0 2.1 2.2 K. Bhavsar, V. Shah and S. Gopalan.(2020) "Scrumban: An Agile Integration of Scrum and Kanban in Software Engineering", Software Project Management
  3. 3.0 3.1 3.2 3.3 3.4 3.5 3.6 Gary Straughan.(2017) "Development That Pays: Scrumban", Software Project Management
  4. 4.0 4.1 Alexander, M.(2020) "The beginner's guide to Scrumban", Software Project Management
  5. Corey Ladas.(2009) "Scrumban - Essays on Kanban Systems for Lean Software Development", Software Project Management
Personal tools
Namespaces

Variants
Actions
Navigation
Toolbox