Saturday, November 29, 2014
Agile Development using the right technology and tools
Digital service / system development and managing changes in
complex software-based systems requires creativity, agility, and enabling
tools. Without preparation for appropriate technology and tools, change is
costly and risky.
Agile development is ultimately driven by the suitable state
of the art tools and technologies to ensure the holistic objective is met by
simply aligning with the Organization structure, goal and process. To ensure
effective agile development, choice of right tools based on purpose of the
overall product / solution architecture of the business objective plays a
critical role.
The discussion revolves around most suitable technology for agile
technology and general agreement comes to a point based on wider usages and
acceptance globally and at the same time prioritization of competitive
non-functional requirement of business goal. In different cases non-functional
requirement such as reliability, security, performance, flexibility, operating
cost, development cost, customer SLA, customer engagement etc. takes priority
among themselves and finally decision is drawn.
In digital world REST architecture and RESTful development is
considered to have edges other conventional technology such as Soap / WSDL considering
few non-functional requirements to have higher priority over others and there
is whole gamut of standards, guidelines and best practices are evolving to make
use of REST / JSON web services. On the database layer SQL vs NoSQL is also
being discussed to take care of unstructured and structured data together. On the middleware similar options available on
hub / spoke, publish / subscribe, workflow, ESB concept supporting multiple
technologies.
Once the technology is finalized based on complete end to
end requirement of the project, the decision on selecting tools becomes
critical to bring agility on the ground. The situation here requires thorough
understanding on pain point for sponsors to effectively benefit from agile
development and it should not lead to achieving one or two objectives like
reducing timeline at higher cost and lesser satisfaction by employees or
customers. There are many commercial and
freeware tools available to help capture requirement through model to help
Model driven development and testing, but with many limitations. Some of the critical
requirements of technology and tools are mentioned here for your review and
feedback.
1.
Technology should have
a.
Well defined roadmap.
b.
Easy to understand and implement
c.
Adhered to best practices, standards and
guidelines of established SDOs.
2.
Tools should be able to
a.
Capture all functional and non-functional
requirements
b.
Provide version control to facilitate change
management
c.
Create specification and document
d.
Test the system from all aspects such as unit
testing, integration testing, system testing and acceptance / functional
testing.
e.
Report on progress to meet project requirement
f.
Make presentation on issues, challenges and
risks
There are many more points which can be added based on your
feedback.
Agile
development can be beneficial when everything done for the development of
products, services, and solutions is done with most optimized way and at the
same time when users of the developed product bring agility in the society. Wednesday, November 26, 2014
Agile Development using the right technique
Agile development ultimately driven by the suitable state of
the art technique to ensure the holistic objective is met by simply aligning
with the Organization structure, goal and process. Agile development is very much associated with
requirement capturing using “User story” template for better alignment. But
there are many cases where requirement is being captured using Use Case
template, Story Point and Model driven Architecture.
Out of many ways of capturing requirement and defining
acceptance criteria, MDE / MDA proves to have advantage over other mechanism
due to below reasons.
1.
User Story – Aligns very well with business
requirement and business value, but technically bring lot of challenges to
handle change request, version control, and effort estimation. Effort estimation
using story point has been always ambiguous with a degree of accuracy varying
from +/- 30% and this figure in effect introduces 60 % risk to project timeline
and cost.
2.
Use Case – This technique is not very often used
with agile development using scrum, but there are many projects, which kick
start using Use Case document. This technique of requirement capture is subject
textual description of all functional, behavioral, non-functional and system
requirement, which always brings in understanding gap between the customer and
developer. And also this technique brings in all challenges such as change
management, version control and effort estimation.
3.
MDA / MDE – This technique has been used but
very rarely in Agile development for digital services and it proves to be much
more reliable and overcome many short coming identifying through user story and
use case template for requirement capturing. The major advantage was observed with
the viewing of business requirement, implementation, effort estimation and
version control.
MDE / MDA tools are
available today which transform the business model to database in SQL or NoSQL
format, generate specs for Soap, REST and many other technologies. The tools
are capable of capturing non-functional, behavioral and functional requirement and
combine them to Database, API and connectors for realization of business
requirement. This mechanism brings in lot of advantage over other technique.
However it is open debate and discussion.
Your feedback and comments on advantage and disadvantages of
various techniques are welcome.
Monday, November 24, 2014
System Development using the Agile process
Successful digital service providers will be the ones
who are agile and fast-moving, highly efficient and customer-centric and those
who know how to partner to deliver the services their customers want.
Agile development is in practice for a decade now and still many organizations prefer to continue in their traditional process for software development instead of adoption of agile process. The current situation is not because the benefits of agile development is not well understood, but due to lack of micro level plans for adoption. There is possibility for every software project to adopt development principles and manifesto to large extent. Typical list of process steps are mentioned below.
If all processes and principles mentioned in
agile processes are followed in an ideal condition, then project success rate
in terms of meeting timeline and budget is likely for more than 90 % project.
But in reality the success rate is very low and that brings the question mark
on where things go wrong. Most important among all points is the customer and
customer interaction, which never happens. Agile process makes it little linear
by mentioning that customer proxy can take the role of customer in case
customer is not available due to the busy schedule. Most of the failure happens
due to this reason as agile process story estimation and story point
computation starts with proper understanding between the group of developers
and customers.
The root cause of agile project failures are due to below
mentioned reasons, which worth noting to incorporate in the successive agile
projects.
1.
Involvement of actual customer rather than proxy
customer
2.
Include the cost of customer/s time in the
budget
3.
Ensure technical customer and cost controlling
customer/s are included for collaboration with the development team, which is
very difficult to achieve in mega projects.
4. There should be some other parallel
collaboration between customer and developers other than system / software
development. For example some team game
or cooking or trekking should be considered as other areas of collaboration
which opens up understanding of body language with ease during discussion on
stories and acceptance criteria.
Monday, November 17, 2014
Agile Development and Organization Structure
Agile Development sets the mindset of different members in
different ways which makes it difficult to adopt in true spirit. The perception
created through mere understanding of standard documents / processes defined in
various books as applicable to set of technical team for improving the time to
develop and productivity of the team. This leads either rejection or partial
adoption of agile principles / manifesto/ practices on the ground and more
detail can be found here.
To answer the road blocks I would like to highlight some of
the real life issues / observations of various members those will be part of
the agile process if implemented in a holistic approach. Some of the initial
resistance to agile adoption by staffs are as below.
1.
We have been working extra time through out to
make sure the delivery time line is met.
2.
There is likely to be reduction in staff count
after successful adoption, which will make our job at risk.
3.
The cost / benefit perceived through agile
process adoption works out to long gestation period for return with no guarantee
on viability.
4.
Available Technology / Tools makes the agile
process impossible for adoption.
5.
Agile process is a fancy process applicable in
specific environment or platform.
6.
Project size does not allow for adoption of agile
process as agile team with a scrum master, the size is restricted to 8-10 and
number of agile scrum master has an upper limit.
7.
List goes on …
In fact most of the reasons indicated above are views of
persons those who do not want change to take, which is typical type of “resistance
to change” for many reasons. There are senior executive such CEO / COO / CIO /
CTO who also share similar views those are averse to risk taking.
With the evolution of Digital economy, there are questions
being raised on the roles and responsibilities of each and how to minimize
overlapping to ensure that the industry trend is well understood to make the
corporate profitable at the most economical value to the customers.
There was a time when the customers were demanding for
implementation of EDI to their suppliers, vendors and partners to ensure that
the message exchange happens faster with minimum human intervention and error.
With this development, the ERP, CRM and core Enterprise applications were
integrated with EDI message and this is in practice as on date in many
enterprise.
In the similar note the customer are also evaluating the
suppliers , vendors and partners about the agile process in place to take care
of any requirement incorporation in the shortest possible time.
To start agile
process in development environment, the below mentioned top down approach
should be taken on priority to establish a holistic agile organization.
1.
Restructure your Organization:
a.
Make the Organization structure flat (horizontal
organization or delayering).
b.
Make the team reporting like a matrix
organization.
2.
Increase the Skillset of Employees
a.
Skillset of individual should be enhanced to a
point where self-responsibility and accountability comes automatically from the
employees rather than through enforcement or coercion.
b.
Multi-skilling should be enhanced to take care
of different demand of skillset at different stages of development of life
cycle.
3.
Select the right technology and Tools: This will
be covered in the next section and provide answer to many known problems and
issues.
Subscribe to:
Posts (Atom)