Wednesday, December 12, 2007

Playing with Smart Client Software Factory - The start

A couple of months ago, I happended to attend a presentation on a Software Product developed using Microsoft.NET Framework and I was pretty impressed with its features and the user interface. Since the Lead Architect himself was presenting the capabilities, I curiously asked how long did it take for you to come this far in terms of features that he presented. And he said we have been working on this for around 8 months now and we have a 6 people development team. I knew that the team had other tasks as well and I was pretty amazed. Then he said - "Its based on Smart Client Framework from Microsoft" in a way that sounded like - What! you dont know about Smart Client ?

Since then, i have been interested to know what MS is providing that makes Windows Forms Application development simple. So for the last couple of days I have been trying to understand what this is all about. My first stop was google and I would advise reading David Hill's blog to know more about Smart Client.

My attempts to download took me to the patterns and practices home page in MSDN and from there i jumped to CodePlex ( MS Open Source Project Repository). I downloaded everything that is available on SmartClient and when I ran the Setup, i saw a "Check Dependencies" button to the right and could immediately see that there were some items missing on my PC. Oh, btw, I have Visual Studio 2005 Professional Edition with Service Pack 1 installed on my Dell Latitude D620 Laptop. And I also have .NET 3.0 and the Visual Studio Extensions for .NET 3.0 In installed. Coming back, the items missing were -

Guidance Automation Extensions
Guidance Automation ToolKit
SQL Server 2005 Compact Edition

You could complete the installation and comeback to have Guidance Automation support. However I decided to install them before I go ahead. So I quit the installation and downloaded all of the above. I also noticed that there is an Enterprise Library 3.1 released in May 2007. uh! There is also a Microsoft .NET 3.0 Framework SP1, but since the installation failed, I gave up. Anyway it was not a dependency. I installed the items in the order as listed above and then finally i installed the Smart Client Software Factory.

I m all set for exploring Smart Client Software Factory. I launched Visual Studio and verified that I can create a solution that is using the Smart Client Software Factory and it works!

Keep looking at this space for updates on my experiments with Smart Client Software Factory.

Thanks for Reading.

Saturday, December 8, 2007

Reverse Engineering Sequence Diagrams - Are they effective

I have been asked this question several times - How do we synchronize designs automatically? THis is more of a question for sequence diagrams than for class diagrams.

Just to give a little bit more background, in almost all the projects that fall in my perimeter, we use OOAD with UML for design. We follow design, coding and unit testing in that order. We have still some catch up to do with agile practices (such as Model Storming, Refactoring). We typically prepare Class Diagrams, Sequence Diagrams and occasionally State Chart Diagrams to capture the design. Once we are satisfied with the design, we transition to Coding.

During coding phase, often times we introduce methods, private members, modify method signatures and occasionally even add new classes. And since the focus is entirely on implementation, the models prepared during design phase go out of sync. Of course if there is a gross design miss, we go back to the design phase, which is relatively very less. But this topic is more about the other majority of cases when the changes to design are nominal. I should be careful with words here. When i say "nominal" it means no major structural changes.

Once the coding & unit testing is over, typically developers are asked to synchronize original design models & documentation to match their implementation (what a pity!). And thats when they crib. Because both Rational Rose (or XDE) and MS Visio (to some extent) can reverse engineer class diagrams, but not sequence diagrams. I know some of you would be thinking - "There are loads of tool available that do it for you". My wishful thinking brings out 2 different questions(although they are related) -
  1. Why did IBM Rational Rose / MS Visio not provide this functionality even though there tools available out there that do it for you?
  2. Supposing even if you had a tool that automatically regenerated sequence diagrams for you, is it really helpful?
I think I have an answer for both the questions. I think part of the answer for the first question lies in the second question and more over thats what this blog is about. So lets try to explore the second question first and for that we need to backtrack and understand why(and more importantly when) we need sequence diagrams.

A sequence diagram depicts the time ordering of messages exchanged between objects. Following is a sequence diagram that depicts the scenario of a customer viewing the account balance using an Automated Teller Machine(ATM).




Perhaps, I overdid the example. Anyway, I think it serves the purpose. I have tried to depict a high level flow right from the insertion of ATM card to the balance display. For the sake of simplicity, i have used only a minimal set of objects.


What if this sequence diagram had been auto generated from reverse engineering the code?

  1. The auto generating tool would have depicted the message flow related to the low level functionality of reading the card. Obviously there is more to it than just a ReadCard(). Since the goal of this diagram was to depict the "View Balance" Scenario, we did not drill down on ReadCard().
  2. Take a close look at the message OnOptionSelected(ViewBalance). The design decision is that the option chosen will be handled by the ATM object(A switch-case implementation). It could be ViewBalance, WithdrawMoney or ChequeDeposit. Once again we were interested in just the ViewBalance and hence did not show the others. There is no way the sequence diagram generating tool would know the difference and would have message flows for other options too.
  3. Lastly, the actual code contains other aspects such as using a Messaging mechanism to post messages to other parts of the system. It can also include a Trace Logging mechanism for debugging purposes. Typically these would be calls to other infrastructural components. You may not want a sequence diagram depicting a functional scenario include message flows related to these.
The point of the matter is what is depicted in a sequence diagram is totally a designer's decision and the sole goal is to display the message flow between objects for a specific usage scenario and context and a auto generator tool can never match it. An auto generating tool on the other hand relies on the method calls present in the actual code and obviously there can be more than one scenarios cutting through the same object( For example, Withdraw, Deposit and Balance all cut through the Account object) and even though they are meant for different scenarios, they would all appear in the same sequence diagram.

In short, reverse engineering tool can only be of little help. A reverse engineering sequence diagram is more of a flow diagram than anything else and thus are not effective in the true sense of it. Atleast thats what I tend to think. What are your thoughts on this?

Friday, December 7, 2007

User Stories & Constraints for Requirements

I am part of a project, the goal of which is to identify high level requirements, draw conceptual architecture and finally provide cost estimate of execution(based on the requirements and the conceptual architecture) of what is perceived as another huge project. The project has been going on for just above 4 months and nearing completion in a week. When the project started we defined some rules of engagement and one of them was use of agile methodologies for execution management.

We went through few planning meetings, understanding the process, team building etc. The concept was new and appealed to everyone. Things were going good, until we stumbled upon a roadblock in the first sprint and that was - How to capture requirements? In the past we had used Use cases and "shall constructs" to define requirements. We could have gone the Use cases way but it would have taken lot of time given the size of the envisioned product and our project was "time boxed". The problem with using "shall" constructs is a single usage scenario is split into multiple statements and then you struggle with combining them together for the sake of understanding or estimation.

What we were actually looking for is -
  1. A means of succinctly stating the requirements in user language; i.e. In a way so that we can identify the benefit
  2. Something that could immediately bring out the business value to the user.
  3. Something that we can base the acceptance test cases on.
The reason being we needed a means of prioritizing the requirements and also validating them. We wanted the ability to weigh and rank the requirements so that we can arrive a product backlog that would feed into the release planning(on a side note, we envision using agile methodologies for execution management).

This led us to explore User stories(on a side note, its a terrible name! for an artifact that is tremendously useful). Here is a definition from agile modeling that I found strikingly similar to what we needed.

A user story is a very high-level definition of a requirement, containing just enough information so that the developers can produce a reasonable estimate of the effort to implement it


There is another definition( another useful resource on XP) which treats User stories as a lead to the conversation between developer and customer.

However, we were not comfortable with the format and examples as the business value was not coming up and moreover the examples were not succinct. Finally one of my searches took me to a blog by Michael James and thus i found a reference to the best book on User Stories - User Stories Applied by Mike Cohn and also a primer on INVEST principle.

We finally used the format suggested by Mike Cohn and that is

As a <User>, I can <Requirement function statement>, so that <value derived from requirement>. Here is an example -

As a Technician, I can monitor sensor data and calibration values so that I can diagnose problems in the behavior of the engine.

Note that there are 3 broad portions -
  1. The User portion identifies the role. This helps in prioritizing the requirement as the product we are developing have several actors at various levels.
  2. The second part identifies the requirement. This is the high level requirement. Some care needs to be taken to balance the content of the requirement so that it can be estimated.
  3. The third part identifies the business value derived from the requirement. So for the same actor, we can prioritize what functions are important.
Although this captures the requirement succinctly, it does not do a good job of specifying the operating conditions. The product owner had it covered already through a sub-section called "Constraints". Constraints are deterrents or conditions that impact the requirement captured in the user stories and we used the "shall" constructs for constraints. As an example a constraint for the above user story is -

The technician shall be able to view the monitored values from a distance of 10 meters.


Typically there are only a handful of them if you organize the user stories properly and are easy to remember at the time of estimation.

Where we are now - We are almost done with requirements, except for a select few, the estimation has been done and we are very satisfied with how it turned out.

Where to go from here - Certainly we can write acceptance test cases. To enhance the documentation, we can expand each user story into a full blown Use case OR we can drill down each user story into a bunch of testable and traceable requirements or both. But thats for the actual project execution to decide next year. Right now, i m looking forward to the holidays.

If you have any queries, comments, please do share. If you ever used User stories, i would be keen on what your experience has been.

Thursday, December 6, 2007

My experience with SCRUM - Agile Project Management

A post after a long long time. There are several topics that i want to write about, but time has been a issue always. I am still struggling to manage time and i see a potential new year resolution since its almost the end of year.

I have always been motivated to look at agile practices. For e.g. TDD, Pair Programming, Continuous Integration etc. That sounds reasonable given the kind of work I am involved with - HMI Tools development and bulk of the development being in .NET. All of these practices are related to Software Delivery, whereas what I m going to share with you is agile Project Management - SCRUM.

My first stint with SCRUM was a 15 mins daily meeting in the morning for one of the projects. We used to call the meeting itself "SCRUM". Not fully correct, but not fully incorrect either. We used to go through the 3 ubiquitous questions -
1. What you did yesterday?
2. What are you doing today?
3. Are there any roadblocks in your way?

It served a good means of tracking the project status daily and immensely helped my Manager. But did it serve the purpose ? I would say, partially as we were not following it in the spirit of Sprints, Product Backlog etc.

My second stint with SCRUM was a full fledged agile project management and interestingly it was not for a software delivery. There was no "working product" which is the soul of any agile practice. We applied SCRUM to deliver Requirements & Conceptual Architecture for a new software product. What made it even more interesting was the Product Owner wanted me to "project manage" the work and was very keen on experimenting with SCRUM. I was made the scape goat and was designated as the SCRUM Master(because i was the only one who had any experience with SCRUM before :-) ) and thus i came to experience the agile way of managing project.

As always, I surfed the web, downloaded presentations, materials etc. to educate myself with SCRUM. I also got an excellent training material from one of my friends by none other than Ken Schwaber himself. Unfortunately I cannot share it as i am not allowed to.

As the work we wanted to accomplish was not a working product, we had to use a unique way of arriving at the Product Backlog. We brainstormed and used mind map to identify the various topics pertaining to "Service Engineering" which was the theme of the product. Once we had the level 3 topics, we worded them as verb phrases and bingo we had the backlog. For e.g. 'Collecting Data about the Machine' was one such level 3 topic. We voted the rank (points) of the product backlog items. The Product Owner set the priority of each item and that's how we went about allocating them to Sprints of 2 weeks duration. Most of this activity was performed as a team within meeting room.

The GOAL was pretty simple. Draft Requirements and Architecture for each product backlog item allocated to the sprint and there was a responsible team member for each item. The sprint tasks then comprised of Interviewing Customers, Interviewing Subject Matter Experts, Observing Users work in a real shop floor and translating those to User stories. This way it was easy to see what was accomplished during the Retrospectives of the Sprints. And yeah, by the way we had the 15 mins Daily SCRUM meeting as well.

The planning & tracking was fairly simple using an excel sheet that tracks the Burndown and there are several examples available on the web. I started with a version that i found on Web and had to customize it to our needs. It was kind of bumpy in the first 2 sprints, but then we settled down nicely and have been consistently able to hit the estimated project velocity based on the BurnDown.

All in all, I must say i enjoyed every bit of SCRUM. Some of the important learnings from my experience of SCRUM are -
1) You do not have to dig past project data to come up with estimates. Just apply your confidence and pick a number. Within a couple of sprints, you will have enough data from the sprint itself to feed into and that is far more reliable than all other data you have as it is for the actual team and actual work.

2) Risks get constant and immediate attention and are always on the top of the stack. Obviously you never defer them as it is at the top. Another advantage is, since the Product owner is involved, the 'Classification of the Risk' is also adequately done. I.e. you do not chase false positives.

3) There is no detailed upfront schedule planning. You could do that, but i found it unnecessary. Within a couple of sprints, with the team velocity, I could project the project end date given no change in backlog. But in reality, you add more backlog items (we did too!) and immediately, based on the team velocity, you will know when you will finish. I.e you can forecast a realistic end date.

4) The project management is very very simple. There is no fooling around with complex numbers. The very fact that I could use a simple Excel sheet to "project manage" the work says it all. In terms of time, I had to spend no more than 2 hrs a week to analyse the numbers etc. for a team of 6 people.

5) Estimation is a on-going process as it is part of Sprint planning at the beginning of every sprint. Moreover every team member gets to estimate his/her task. So if you get it wrong the first time (or first sprint), use that knowledge to correct it in the later sprints. This is perfect as productivity tends to increase with project experience.

6) The focus is on "what the team achieved" rather than on "who failed". There are no finger pointing. Its the team that "accomplishes" and its the team that "fails".

Here is an example burndown sheet that i used for tracking the current sprint. The product backlog itself was contained in another sheet in a format as prescribed in Example of burndown for scrum backlog and sprint


To know about Scrum -
Excellent Wikipedia article
Control Chaos
More Search Links

Useful links for examples of Scrum Burndown Spreadsheets
The most interesting.
Applying SCRUM for an individual
MSDN article showing plugin for Project 2003 usage with SCRUM
Example of burndown for scrum backlog and sprint

If you have any queries or comments or if you simply find this useful, post a comment with your thoughts. I would also be keen on hearing about your experiences with SCRUM if any.

Thanks for reading

Tuesday, June 5, 2007

How to identify components in architecture - Addition

I recently happened to visit www.bredemeyer.com. and i found something interesting related to the topic of identifying components. In my 2nd part i had said - "Logical components transform into more meaningful ones". However i think there is a correction to be made.

In
How: The Software Architecting Process, Bredemeyer refers to terms "Conceptual Architecture" & "Logical Architecture". The former is the earliest conception of a system as a decomposition of functional components. The latter is the refined decomposition of system as components with each component having a well defined interface. In the architecting process, a "Conceptual Architecture" is refined (transformed) into a "Logical Architecture".

When I said "Logical components transform into more meaningful ones", in hindsight, i think i meant to state the above. The earliest conceptions of Logical Components form the pieces of Conceptual Architecture and the transformed version of these pieces are the refined Logical Components and these transformed components along with the well defined boundary(interface) form the constituents of Logical Architecture. In a way A Logical Component transforms into other more refined Logical components.

I hope this adds more clarity to the understanding.

Saturday, May 19, 2007

How to identify components in architecture - Concluding Part

Lets do a quick recap. We looked at CBSE, explored the benefits of CBSE, defined components, physical component and logical component. With this, I believe we are ready to go for the kill - How to identify components ?
We have classified components as 'logical' and 'physical'. Therefore we need to identify both in software architecture. Lets start with 'logical' components as they are the 'first-cut' components.
Logical Components are identified by "functional decomposition" of the system.

Although it sounds simple, it is not. Software Architecture happens during the initial stages of the project, when, seldom complete requirements are available. In fact all you have is a list of high level features/functionality and not to forget another list of desirable non functional requirements such as performance, usability, extensibility, portability etc. Lastly lets not ignore the constraints imposed by external factors such as technology, management etc. An architect needs to take all of these into consideration while arriving at solution.

Expanding upon the above statement, to identify the logical components of the system, I would recommend the following process -
  1. Divide the entire system as a set of functions ( not algorithms). Each and every function should provide a well defined & unique user functionality that is not provided by any other.
  2. Ensure that function should have a well defined boundary.
  3. Decompose further considering other non functional aspects such as performance, usability, technology, standards etc. to refine the function(s) into component(s). Yeah! this is lot of work and tricky as well.
  4. For each component so identified, define an interface.
  5. Finally, validate that it fits well with the other components.
These steps will have to be carried out multiple times, until a convincing logical architecture is arrived.

Perhaps an Example would help. Consider a Real time Data Acquisition and Control system for a device connected to the serial port. Lets further assume that the data needs to be displayed on screen as well as recorded to a file. I can see 4 basic functions(and a good starting point) -
  1. Data Acquisition
  2. Control
  3. Display
  4. Record
Refining further, Data Acquisition can be further split into 2 components - 1) Data Reader 2) Data Publisher. The second component comes from the architectural style chosen to display/record the data. Since the data is being read real time over the serial bus, a push model is adequate.

Now lets look at Control - A close look reve
als that 'Control' involves writing Data to the serial interface. So we need a Data Writer as well. The following figure depicts what we have compiled so far without interfaces.



Continuing with the refinement process..
Since Read & Write services complement each other, I think it makes sense to make it a single component and of course give a suitable name. This is what it all looks like along with the interfaces. Note that there is scope of further refinement, depending upon the requirements as well as application of other architectural styles.




Now having explored an example, let me clarify what did I mean by transformation of logical components. Taking the example above, Data acquisition got transformed (rather morphed) into 2 components - "Device Read/Write services" and "Data Publisher". In other words, a logical component at a higher level of abstraction gets transformed into one or more logical components ( that is closer to implementation) at a lower level of abstraction.

As mentioned before, it does not stop here. For e.g. If the development is done using .NET, then DataSet and DataGrid(for ScreenView) could be chosen for data representation and display. This will lead to further decomposition (perhaps the publisher is no longer required in the ScreenView as DataSet and DataGrid bind well).

Component Identification CheckList - Here is a list of guidelines that can be used to validate the credibility of the logical component. If all of these are positive for a component, then its a good abstraction of a component.

  1. Functional Cohesion - The component must fulfill a single goal completely.
  2. Well defined Boundary - Simple and well defined interface.
  3. Replaceable - Consider change scenarios that could occur in future and ensure that changes are isolated as components.
  4. Re-usability - Can it be reused as is? Are there portions that hinder reuse? If so, then there is a need for further decomposition.
That brings us to the end of Logical Component Identification.

I m not going to stress much on physical component identification as it is basically how you package the functionality.Taking the example above, all of the logical component may be packaged into a single executable ( if the deployment dictates that there be no files other than a single executable! ). Alternatively, it makes sense to package the UI components into one package and retain the non UI components (such as DataLogger) as separate DLL(s). Another option is to package the Publisher along with the Device Read/Write services. I leave it open. Although, the best option (unless otherwise constrained by something else) is to leave each of the component as a separate physical component.

This brings to the conclusion of my first technical topic and I would be glad to know what you think of it. I personally feel that i ran through some of the stages. If you want to know in detail or have trouble understanding some of the portions above, i would be more than glad to help.

Saturday, May 12, 2007

How to identify components in architecture - II

In my previous blog, I discussed briefly about the advantages of CBSE and ended with a question instead of an answer. To reiterate, the objective is to identify components and to achieve that first we need to define what a component is and then understand the classification of physical and logical.

First this first ! Scope check - It is constrained to the realm of Software Architecture, although i believe it applies in the general sense as well.

Of all the definitions that i know, the one that i find simplest yet most appealing is -
"A component is a reusable software entity that exposes a set of one or more interfaces"

Lets do a reality check ! Is that really how we perceive components ?

For some of us ( or rather most of us), a software component is a COM component, a Dynamic Link Library(DLL), a Shared Object(Unix/Linux), Frameworks ( MFC, ATL), Libraries(QT, RogueWave).. the list goes on and on and on ....Isn't it ?

If you look closely, there is a similarity between the items in the list above. All of them have a physical identity in the sense that they directly consume resources - time as well as space; and indeed match the preceding definition. Incidentally this solves one of the earlier problems of identifying "physical component".

That leaves us with the question - whats a "Logical Component" ?

A Logical Component is also a reusable entity(not necessarily software! could be a model as well ! ) that is representative of complete or a portion of functionality in the system. Does this mean physical component do not encapsulate functionality? Of course they do.. In fact, often, a physical component can packs more than one Logical component. The differentiating factor is a Logical Component may or may not consume resources of time and space.

The reason for this is Logical Component(s) transform into other "forms" that will consume resources of time and space. But why would they "transform" ? That's because Logical Components are one of the earliest conceptions in software architecture and are susceptible to be replaced by other complete forms in the subsequent architecture process.

Time is not with me.. So I will have to keep the concluding part for my next blog. If you have questions, comments or thoughts, drop a note. I would be glad to share ( & learn)...

Thursday, May 10, 2007

How to identify components in architecture - I

I never thought I would be posting my second blog so late. Actually I wondered how anyone would get to my blog! Thanks to Divyesh, I realized orkut is the way to go for being noticed.

This is my first tech blog and it is interesting!

In the past few months, i have done this twice and I m not satisfied or rather clear about it. No I m not referring to two blogs ;). Twice i had to go through the process of identifying components in a system for 2 different projects.

Component Based Software Engineering or CBSE, is a software engineering discipline wherein a system is decomposed into functional components having well defined interfaces. The concept is to build a system as an integration of several blocks a.k.a component leading to a modular solution. Keep in mind that components are usually at a higher level of abstraction in terms of 'time and space' than objects as in OOP. The key benefits accrued from CBSE are -
  • Software Reuse - Of course if you ever need the functionality again, you can use the component
  • Pluggability - I like this! Although not a standard quality attribute what this means is you can safely replace one implementation with another and cause little or no impact elsewhere in the system
  • Smooth Evolution - It is well known that software systems evolve over a period of time. Decomposing into functional components makes the system evolve in a consistent manner without making a mess thus retaining the maintainability
  • Higher probability of success - This takes the icing and the cake with it! Do you throw away the whole furniture if only a single chair is broken? No. In the same way if a portion of a system is broken, which in CBSE is a component, you only need to throw that component away. The system can still be built and project can continue although with a certain amount of delay.
CBSE is also referred to as CBD or Component Based Development and the architecture itself is called as Component Based Architecture.. I suppose thats enough for background.

So how to identify components ? Wait.. we are not ready yet for that. Before we do that we need to know the difference between 'Logical Components' and 'Physical Components'. I m going to defer it to my next post.

If you have any ideas on CBSE, i m willing to know!