Hello, answering Pawel's comment to my last entry I'll elaborate a bit on testers in my present context.
"How can you actually live without them?" well we just don't, when I came here there weren't any and I haven't asked to hire any so, no there aren't any dedicated testers. But of course there are numerous people that take the tester's role. For example when it comes to specifying acceptance criteria this is a job of analysts (or people in the analyst's role at the moment). When it comes to punching all the application buttons to see if it breaks then usually we have some people from helpdesk to do the job, or other non-programmers taking the tester's role. But yes we have to dedicated and trained testers. For the record, I wish we did but for now I have more serious problems to deal with introducing basic agile practices.
I disagree that customers shouldn't play a role in testing, I agree that things have to be tested internally before deployed on a customer accessible machine, but I would strive to let the customer see the developed features as soon as possible under all cost. Rapid feedback is what tells us we are right, without it we may be just waisting our time and his money.
"Unit testing is a good concept to check the code itself. Still, there are other aspects of software that are quite difficult to test with unit testing. Examples: user interface, localization, static information stored in databases and files. It's nearly impossible to check these without testers."
Well for starters I think the interface testing problems are very much resolved by acceptance test frameworks that execute functional tests on the system through the interface itself (Selenium, Canoo WebTest for the browser, other frameworks I can't recall now for rich client GUI's).
That said I should emphasize the need to have the UI as thin as possible, through the usage of FIT (or FitNesse) - Framework for Integrated Tests. Testing the top level UI is sometimes necessary but it's usually better to test just 5mm below - that's why you need the UI to be dumb and thin. That's because the UI usually changes, a lot. But it's possible to mix and match those approaches (and that's what I'm recently planning to do) and e.g. call Selenium from FitNesse.
Localization? I can think of at least one way to check for that, while validating the GUI
Static info in DB and files. Well that can easily be done by all testing frameworks, best shot is probably xUnit or FIT (depending on the test nature). During writing the test just write additional code that will check the contents of a file or execute a statement against a database.
Having said all that I agree that are some things that can't be tested automatically, at least not for a reasonable price. That include compliance to a formal standard, having a nice look and feel, etc. My point is - we try to bring the number of those things down by magnitudes, so that the costs (and time) of manual tests are far lower. Then manually checking for those few things isn't such a horrible thing to do.
"Moreover, it's good to have real people checking what you've done as oppose to cold machines which will never really understand requirements. Software testing software...? I think it's Sci-fi"
not really, think of regression testing, once people who understand the requirements have set up acceptance criteria and a proper environment machines may take the role of running the system against those criteria. This is a common problem we also have when we don't have automated acceptance tests. At the end of a cycle there is very little time to check for all those things that were OK 2 months ago if they are still working properly. Very often we just do a little fix, which in turn breaks some functions but we just don't have time to check the whole system for this. Having acceptance tests would have minimized this problem greatly. I didn't say the problem is totally eliminated, I said it is minimized. I may be wrong but I would guess that it would catch over 90% of cases.
Wednesday, January 03, 2007
Monday, December 11, 2006
My first Q&A session
There was a comment (by Pawel) to my last post that included a series of questions. I decided to pick them up and answer them in the open, so maybe they'll inspire you people to discuss this further.
1. How many users you expect to use the software you've been recently developing?
It is supposed to be deployed and used simultaneously at over 3 thousand locations.
2. Do you develop web software or desktop software?
This project is desktop software, but a previous one and one coming up is a webapp so generally this is irrelevant.
3.1. How do you test?
We have automated test suites. Well OK, we are aiming for those, close to the truth is: we are growing our test suites, automated of course.
The customer also does manual acceptance testing of his own, but that's his free will. As I wrote I came to the project late so it is not fully covered by both unit level nor acceptance level tests, but we have them exercised all the time. People are running unit tests locally as part of the Test Driven Development method. Of course they're supposed to be run automagically on the integration machine as well.
3.2. Do you have testers?
Not quite. There was no tester on the team. It's a small team, now having 3 full time developers and 2 half-time. Some time ago I asked one of the half-time developers to get to know FitNesse and now she's our acceptance test guru, so yes she may be thought of as a tester, but I wouldn't call her that. To my knowledge she's more a developer in the role of a tester. A full blown tester has more testing-specific knowledge than she does at this point. But she's getting there.
She's now in the process of educating the rest of the team about writing automated acceptance test, and will be the person to aid them later.
3.3. And how do you mimic production environment?
The integration machine is a production class unit. How did we make it production-like? Well we just did, I don't get the question. I think there is no generic answer to this, every project is specific in this matter so please tell me about your problem.
4. Do you deploy bit by bit to production so users can use the bit of software you finished and tested and give you some feedback?
Well not quite ;), The relationship with the customer was formed and agreed to a long time ago so I wasn't able to change that, so he's not on-site. We rather integrate the modules after each increment and our internal customer (customer proxy) does the checking. The real customer has longer response times and testing cycle than we require to keep on moving. But as for now it works well (I know it's a risk but we're handling it well for now).
5. When do you fix bugs?
Depends what severity and size. Severe bugs we fix on the double. Minor bugs we schedule according to importance like regular features during the weekly planning game.
6. Do you build software every day/night?
No need for that, this is also project specific. The build takes a few minutes, it's a small team, luntbiuld (or cruisecontrol) does the job of checking our VCS regularly (or at least it should, up until now we had this manual - don't ask me why) and building the project when changes were detected.
7. Do you babysit software you finished providing bug fixes, technical support and deploying new releases when needed?
Yes, depending on the agreement with the customer but in the vast majority the customer buys also maintenance support and/or has new feature ideas. Mainly it's because we need to babysit this software we go to all the lengths to have all those tests in place. It brings the maintenance costs down very quickly.
1. How many users you expect to use the software you've been recently developing?
It is supposed to be deployed and used simultaneously at over 3 thousand locations.
2. Do you develop web software or desktop software?
This project is desktop software, but a previous one and one coming up is a webapp so generally this is irrelevant.
3.1. How do you test?
We have automated test suites. Well OK, we are aiming for those, close to the truth is: we are growing our test suites, automated of course.
The customer also does manual acceptance testing of his own, but that's his free will. As I wrote I came to the project late so it is not fully covered by both unit level nor acceptance level tests, but we have them exercised all the time. People are running unit tests locally as part of the Test Driven Development method. Of course they're supposed to be run automagically on the integration machine as well.
3.2. Do you have testers?
Not quite. There was no tester on the team. It's a small team, now having 3 full time developers and 2 half-time. Some time ago I asked one of the half-time developers to get to know FitNesse and now she's our acceptance test guru, so yes she may be thought of as a tester, but I wouldn't call her that. To my knowledge she's more a developer in the role of a tester. A full blown tester has more testing-specific knowledge than she does at this point. But she's getting there.
She's now in the process of educating the rest of the team about writing automated acceptance test, and will be the person to aid them later.
3.3. And how do you mimic production environment?
The integration machine is a production class unit. How did we make it production-like? Well we just did, I don't get the question. I think there is no generic answer to this, every project is specific in this matter so please tell me about your problem.
4. Do you deploy bit by bit to production so users can use the bit of software you finished and tested and give you some feedback?
Well not quite ;), The relationship with the customer was formed and agreed to a long time ago so I wasn't able to change that, so he's not on-site. We rather integrate the modules after each increment and our internal customer (customer proxy) does the checking. The real customer has longer response times and testing cycle than we require to keep on moving. But as for now it works well (I know it's a risk but we're handling it well for now).
5. When do you fix bugs?
Depends what severity and size. Severe bugs we fix on the double. Minor bugs we schedule according to importance like regular features during the weekly planning game.
6. Do you build software every day/night?
No need for that, this is also project specific. The build takes a few minutes, it's a small team, luntbiuld (or cruisecontrol) does the job of checking our VCS regularly (or at least it should, up until now we had this manual - don't ask me why) and building the project when changes were detected.
7. Do you babysit software you finished providing bug fixes, technical support and deploying new releases when needed?
Yes, depending on the agreement with the customer but in the vast majority the customer buys also maintenance support and/or has new feature ideas. Mainly it's because we need to babysit this software we go to all the lengths to have all those tests in place. It brings the maintenance costs down very quickly.
Tuesday, October 31, 2006
Still alive
Well I'm not dead as one might think (or hope), not yet at least. It isn't that easy to kill the beast. I haven't been posting anything lately because I've been away for a while (eg. at ENASE'06: Advocatus Diaboli Walk Through eXtreme Programming), furthermore there is a lot of integration work going on in the project now as a pilot deployment is being set up, so things are going well and forward. At least a few of us think so ;).
Next few months I will probably start a new project from the beginning for one of our old customers. We'll try the agile way of course, so you'll again be able to track what's going on. Next Tuesday we're having a planning game to see how big the picture is and to be able to formulate a legal agreement based on that.
About the current project I'll just say that now I'm devoting most of my time to one of it's components. My initial mission was to ensure that it will make the launch date and not explode. Now that this is secured I'm looking for ways to improve this components architecture, mainly the low-level (code style, object reuse, etc) architecture. There are two well skilled people working on that project, so the work is going quite well.
See you soon.
Next few months I will probably start a new project from the beginning for one of our old customers. We'll try the agile way of course, so you'll again be able to track what's going on. Next Tuesday we're having a planning game to see how big the picture is and to be able to formulate a legal agreement based on that.
About the current project I'll just say that now I'm devoting most of my time to one of it's components. My initial mission was to ensure that it will make the launch date and not explode. Now that this is secured I'm looking for ways to improve this components architecture, mainly the low-level (code style, object reuse, etc) architecture. There are two well skilled people working on that project, so the work is going quite well.
See you soon.
Tuesday, August 08, 2006
Last iteration (or is it?)
Again I apologize for not posting any new entries. The day of moving to our new home gets closer and closer (hopefully this weekend) and so every afternoon til late in the night I work hard to make it prettier ;).
At the project site we have just completed iteration 7, one story slipped to iteration 8, which started Monday. The project velocity dropped from 13/14 Gummi Bears to about 12 Gummi Bears, that is because more and more time we work trying to integrate our front-end system with the back-office system which is developed by an other team.
Nevertheless we just started our hopefully last iteration, though we packed it with 13 Gummi Bears we hope to finalize it. So that's really good, Friday is the date that I foretold 7 weeks ago :D based on one iteration's progress. Cool. Much luck I guess, ehh, hell with that, we're simple grrrreat! :D
The sad part is that this is not the end, the system is a part of a whole, and now we have to integrate it with an other part of the system, we developed the front-end and there is a back-end being finished as we speak that has to work with our front-end. We know the team, we like each other and are in contact, but the development method was different and we didn't plan things together. We started integrating a few weeks ago, little by little, that's why the velocity dropped a bit. Things are not that bad, minor changes and tweaks were til now sufficient so we hope (yeah, that's all we've got-hope) things will work out in a matter of a week or so.
I'm not too happy with that integration going on as a side topic, I know that according to XP, we should integrate every Friday. But that's as far as I was able to go given the time I had, the progress the project had, and the pressure there was. If I had the time and opportunity I would gladly bring those techniques to the other team, schedule even iterations, and have integrations in every iteration.
There is more work to be done, the feature list is not exhausted yet, these were just the primary-value features. So I hope I will get a chance to push the development process a bit further down this road.
As for now, next Monday I plan to have a planning game that will discover all the integration tasks that have to be done, so we can schedule then and track as we did with normal feature tasks. After all it's one of the customer wishes that the system is integrated as a whole, so I imagine a User Story: "The system parts are integrated and it doesn't fall apart when used." :D LOL.
Oh and our Mrs accepted her first tasks for the former and present iteration! Overestimated them by 100%. Sweet :). Brave young woman. :) She's doing a really good job.
One thing I think we have to do better is the retrospective. It's Friday afternoon, everybody wants to go home, and it's really hard to concentrate on reflecting. Coincidentally today I read a chapter from Testing Extreme Programming by Lisa Crispin et al. It was about retrospectives, how to handle them. She gave ideas and examples of how to use this idea brought by Martin Fowler in 2001.
I think I'll try to use the iteration grade card she provided. It's just a list of iteration activities and the team assigns grades to them, so we all know what we need to improve.
The original Martin's three questions list (what to start, stop, continue doing) also looks appealing, I'll think things through and hope to use something this Friday.
So stay tuned for more "of the battlefield" reports.
At the project site we have just completed iteration 7, one story slipped to iteration 8, which started Monday. The project velocity dropped from 13/14 Gummi Bears to about 12 Gummi Bears, that is because more and more time we work trying to integrate our front-end system with the back-office system which is developed by an other team.
Nevertheless we just started our hopefully last iteration, though we packed it with 13 Gummi Bears we hope to finalize it. So that's really good, Friday is the date that I foretold 7 weeks ago :D based on one iteration's progress. Cool. Much luck I guess, ehh, hell with that, we're simple grrrreat! :D
The sad part is that this is not the end, the system is a part of a whole, and now we have to integrate it with an other part of the system, we developed the front-end and there is a back-end being finished as we speak that has to work with our front-end. We know the team, we like each other and are in contact, but the development method was different and we didn't plan things together. We started integrating a few weeks ago, little by little, that's why the velocity dropped a bit. Things are not that bad, minor changes and tweaks were til now sufficient so we hope (yeah, that's all we've got-hope) things will work out in a matter of a week or so.
I'm not too happy with that integration going on as a side topic, I know that according to XP, we should integrate every Friday. But that's as far as I was able to go given the time I had, the progress the project had, and the pressure there was. If I had the time and opportunity I would gladly bring those techniques to the other team, schedule even iterations, and have integrations in every iteration.
There is more work to be done, the feature list is not exhausted yet, these were just the primary-value features. So I hope I will get a chance to push the development process a bit further down this road.
As for now, next Monday I plan to have a planning game that will discover all the integration tasks that have to be done, so we can schedule then and track as we did with normal feature tasks. After all it's one of the customer wishes that the system is integrated as a whole, so I imagine a User Story: "The system parts are integrated and it doesn't fall apart when used." :D LOL.
Oh and our Mrs accepted her first tasks for the former and present iteration! Overestimated them by 100%. Sweet :). Brave young woman. :) She's doing a really good job.
One thing I think we have to do better is the retrospective. It's Friday afternoon, everybody wants to go home, and it's really hard to concentrate on reflecting. Coincidentally today I read a chapter from Testing Extreme Programming by Lisa Crispin et al. It was about retrospectives, how to handle them. She gave ideas and examples of how to use this idea brought by Martin Fowler in 2001.
I think I'll try to use the iteration grade card she provided. It's just a list of iteration activities and the team assigns grades to them, so we all know what we need to improve.
The original Martin's three questions list (what to start, stop, continue doing) also looks appealing, I'll think things through and hope to use something this Friday.
So stay tuned for more "of the battlefield" reports.
Sunday, July 30, 2006
"Papa Oscar Sierra do you copy?"
And now to get back to the subject ... ah yes the project
So we are pass our magic date, the 28th of July.
The girl that I introduced 2 weeks ago to the team is very capable and intelligent. She learns fast and is eager to do stuff. Maybe Monday she'll get to accept her first task, she'll still do it in pair with a senior programmer but it'll be her estimate and responsibility, I think that will help her grow.
As I observed and measured the velocity of the project, i.e. the number of Gummi Bears completed each week I reported them back to the executives this value together with the (Gummi Bears left) / (velocity) = projected number of iterations needed to complete. What really amazed me was that the speed, was quite constant and the projected finish date was about the same last week and the first time I reported i.e. a month ago. I just hope that we will actually finish by that date :))). That would be a great proof of effectiveness and accountability of this team and this method for the rest of the company.
The thing that bothers me most right now is that although we will finish, there are possible integration problems on the edges of the other projects, as our project is a part of a bigger whole. Unfortunately I was put to work here too late to be able to pick all the loose ends and tie them together, I had to concentrate on one team and help them to it's best. I guess if I would've tried to do too much at once I would have failed on all the fronts. We're starting to integrate early as possible given the completion state of the other modules, and the other teams' work styles. When we get through all this maybe I'll be given a chance to help the rest of the teams as well.
As for now my motto is:
"We'll never make it out alive"
"Nonsense. You're just saying that because no one ever has."
We had a jolly meeting with the customer's representative. :) That was really fun. Not the type of "ha ha" fun though. It turned out that none (as in "zero") of the executives from our side have shown up (everyone was, on vacation, too busy or else). And the most interesting part of that was that we were the ones to tell him that "we aren't gonna make it". Though I reported that for the first time over a month ago no information was passed to the client. I can't supervise my supervisors (otherwise they wouldn't be my ... you get the point ;) ), but I really thought they would do something else that just sit back and wait. Maybe there was something in that tactic, we just don't get the strategy behind it. Maybe they deliberately kept that news to themselves because the slip was not to severe and they wanted nature to handle those little difficulties, but even then I expected that they would inform us about that strategy and the tactics in use.
Anyway, as we often say in Poland, we had more luck than intellect and on that very meeting the client introduced, the thing that we programmers like the most - changes :). Maybe not so drastic ones as my wall 40cm shorter than planned, but still. So, the customer's representative is willing to play on our side and cover for us, and he'll cover those 2 weeks that we're short of in the time needed to specify and implement those new changes. I don't like that too much, as I prefer openness to covering up, but at this particular moment that was politically the best option to be taken, and so we did. At least at that moment I was convinced by the rest that this was the case. We'll see, and learn.
We encountered one severe problem while trying to unit test a particular system component, a quite basic component that is part of the system's framework. The base line is that it is untestable. Two sets of programmers attacked this problem twice without effect, so we decided to pick the lesser evil that postpone the unit tests, and catch those possible mistakes in the higher planes. We wrote ourselves a User Story saying we need to be able to unit test this component. We'll pick it up when all higher priority stories are complete. Actually we're still thinking on a good name for such a story to be a true User Story, not a Developer Story. I know this is the "internal quality" issue and we should not cut corners here, but I really didn't feel like loosing another day or two just to find that there is no way to do that in the current design. And the refactoring needed to do that is just too expensive right now. Those kinds of things just happen when you get a in touch the Test Driven Development practice with a project that ran without it for the last half a year. I'm not proud of it, but I just didn't know any better way to proceed. I'm really open to suggestions (as in "please enlighten me").
OK there are may matters that I would gladly blog about and I surely will in future entries but as for now it's getting late, too late for me to see, I feel like I'm knocking on the nighty night's door ... hey! hey! hey! hey, yeah!.. knock, knock, knocking on the ...
So we are pass our magic date, the 28th of July.
The girl that I introduced 2 weeks ago to the team is very capable and intelligent. She learns fast and is eager to do stuff. Maybe Monday she'll get to accept her first task, she'll still do it in pair with a senior programmer but it'll be her estimate and responsibility, I think that will help her grow.
As I observed and measured the velocity of the project, i.e. the number of Gummi Bears completed each week I reported them back to the executives this value together with the (Gummi Bears left) / (velocity) = projected number of iterations needed to complete. What really amazed me was that the speed, was quite constant and the projected finish date was about the same last week and the first time I reported i.e. a month ago. I just hope that we will actually finish by that date :))). That would be a great proof of effectiveness and accountability of this team and this method for the rest of the company.
The thing that bothers me most right now is that although we will finish, there are possible integration problems on the edges of the other projects, as our project is a part of a bigger whole. Unfortunately I was put to work here too late to be able to pick all the loose ends and tie them together, I had to concentrate on one team and help them to it's best. I guess if I would've tried to do too much at once I would have failed on all the fronts. We're starting to integrate early as possible given the completion state of the other modules, and the other teams' work styles. When we get through all this maybe I'll be given a chance to help the rest of the teams as well.
As for now my motto is:
"We'll never make it out alive"
"Nonsense. You're just saying that because no one ever has."
We had a jolly meeting with the customer's representative. :) That was really fun. Not the type of "ha ha" fun though. It turned out that none (as in "zero") of the executives from our side have shown up (everyone was, on vacation, too busy or else). And the most interesting part of that was that we were the ones to tell him that "we aren't gonna make it". Though I reported that for the first time over a month ago no information was passed to the client. I can't supervise my supervisors (otherwise they wouldn't be my ... you get the point ;) ), but I really thought they would do something else that just sit back and wait. Maybe there was something in that tactic, we just don't get the strategy behind it. Maybe they deliberately kept that news to themselves because the slip was not to severe and they wanted nature to handle those little difficulties, but even then I expected that they would inform us about that strategy and the tactics in use.
Anyway, as we often say in Poland, we had more luck than intellect and on that very meeting the client introduced, the thing that we programmers like the most - changes :). Maybe not so drastic ones as my wall 40cm shorter than planned, but still. So, the customer's representative is willing to play on our side and cover for us, and he'll cover those 2 weeks that we're short of in the time needed to specify and implement those new changes. I don't like that too much, as I prefer openness to covering up, but at this particular moment that was politically the best option to be taken, and so we did. At least at that moment I was convinced by the rest that this was the case. We'll see, and learn.
We encountered one severe problem while trying to unit test a particular system component, a quite basic component that is part of the system's framework. The base line is that it is untestable. Two sets of programmers attacked this problem twice without effect, so we decided to pick the lesser evil that postpone the unit tests, and catch those possible mistakes in the higher planes. We wrote ourselves a User Story saying we need to be able to unit test this component. We'll pick it up when all higher priority stories are complete. Actually we're still thinking on a good name for such a story to be a true User Story, not a Developer Story. I know this is the "internal quality" issue and we should not cut corners here, but I really didn't feel like loosing another day or two just to find that there is no way to do that in the current design. And the refactoring needed to do that is just too expensive right now. Those kinds of things just happen when you get a in touch the Test Driven Development practice with a project that ran without it for the last half a year. I'm not proud of it, but I just didn't know any better way to proceed. I'm really open to suggestions (as in "please enlighten me").
OK there are may matters that I would gladly blog about and I surely will in future entries but as for now it's getting late, too late for me to see, I feel like I'm knocking on the nighty night's door ... hey! hey! hey! hey, yeah!.. knock, knock, knocking on the ...
Saturday, July 29, 2006
"How not to get bored" or "XP is about social change"
Sorry again, I promised I'll write and I didn't, my only excuse is that the people that are finishing off you apartment also didn't make it on time, and as for the moment the sky gently but steadily lowers itself towards my head. Next weekend I'm supposed to move, this weekend I was supposed to paint the walls etc, but I can't because other work is not finished yet.
To summarize, when you feel a bit bored, or you feel your life is too predictable, or feel otherwise odd please do yourself a favour and buy a new unfinished apartment and then set a firm unmovable date by which you have to move to that place. Then 3 weeks before that deadline have your wife buy a new dog, and then have a team of "talented"(past tense as in "maybe there were times when they were talented") pros start working to finish this apartment. Don't forget to fasten your seat belt and hold on tight (and be sure to take your heart pills) ...
It that's not enough please try this:
Measure the place for your new kitchen, put the numbers all over the blueprints, but many more numbers there, measure every detail and put the numbers as close together as possible. Then after a week cursorily read that blueprint, put it aside, never look at it again and then carefully design your kitchen. Go to IKEA, buy that damn kitchen, bring it over, unpack, put the LEGO parts together, and have your friend carpenter come have your kitchen put in place. Then at the beginning of a brand new week, when you stand with him and explain where you wish which part to be realize that one of the walls doesn't have 355cm but 315. Remember the blueprint part of this exercise is the key part, otherwise you'll find your mistake soon enough to change the plans in the planning phase.
Unfortunately this is not a software project, and kitchen parts are not Java classes. Unfortunately in the real physical world it's not easy to apply such changes. But feat not!. Life shows that even then if you have a master carpenter at your side he'll find a way to seamlessly shirk a few parts here and there and after a few hours of looking at your life passing before your eyes you see a bright light that illuminates your brand new kitchen.
So actually this is a case study of an agile technique put to use in the real world that seemed very BDUF-like :). My friend, if he wasn't my friend, could say: "Hey dude, get lost! I have better things to do than to cover for your mistakes, call me when you have all the parts fit the plans". But he didn't say that. Instead he said "OK, so let's see what we have here, this part has 50cm not 60, we can shrink that other part another 20cm, and the one over there we can also rebuild a little".
So all you agile non-believers this is hard evidence that this kind of work style actually works, the key thing is the state of mind and the attitude. "XP is about social change".
To summarize, when you feel a bit bored, or you feel your life is too predictable, or feel otherwise odd please do yourself a favour and buy a new unfinished apartment and then set a firm unmovable date by which you have to move to that place. Then 3 weeks before that deadline have your wife buy a new dog, and then have a team of "talented"(past tense as in "maybe there were times when they were talented") pros start working to finish this apartment. Don't forget to fasten your seat belt and hold on tight (and be sure to take your heart pills) ...
It that's not enough please try this:
Measure the place for your new kitchen, put the numbers all over the blueprints, but many more numbers there, measure every detail and put the numbers as close together as possible. Then after a week cursorily read that blueprint, put it aside, never look at it again and then carefully design your kitchen. Go to IKEA, buy that damn kitchen, bring it over, unpack, put the LEGO parts together, and have your friend carpenter come have your kitchen put in place. Then at the beginning of a brand new week, when you stand with him and explain where you wish which part to be realize that one of the walls doesn't have 355cm but 315. Remember the blueprint part of this exercise is the key part, otherwise you'll find your mistake soon enough to change the plans in the planning phase.
Unfortunately this is not a software project, and kitchen parts are not Java classes. Unfortunately in the real physical world it's not easy to apply such changes. But feat not!. Life shows that even then if you have a master carpenter at your side he'll find a way to seamlessly shirk a few parts here and there and after a few hours of looking at your life passing before your eyes you see a bright light that illuminates your brand new kitchen.
So actually this is a case study of an agile technique put to use in the real world that seemed very BDUF-like :). My friend, if he wasn't my friend, could say: "Hey dude, get lost! I have better things to do than to cover for your mistakes, call me when you have all the parts fit the plans". But he didn't say that. Instead he said "OK, so let's see what we have here, this part has 50cm not 60, we can shrink that other part another 20cm, and the one over there we can also rebuild a little".
So all you agile non-believers this is hard evidence that this kind of work style actually works, the key thing is the state of mind and the attitude. "XP is about social change".
Thursday, July 27, 2006
"Is there anybody out there?"
Fortunately there is :) Thank you Johanna! (see comment to my previous entry)
I have had some major disruptions lately both at work and at home. A few interesting projects are emerging, and I'm moving to a new apartment in 2 weeks so e.g. today our kitchen was put together :)
I promise tomorrow evening I'll blog an extensive update on what has happened in the project since last time.
Thanks again for keeping me blogging, it's easier when I know it's not just for myself :)
I have had some major disruptions lately both at work and at home. A few interesting projects are emerging, and I'm moving to a new apartment in 2 weeks so e.g. today our kitchen was put together :)
I promise tomorrow evening I'll blog an extensive update on what has happened in the project since last time.
Thanks again for keeping me blogging, it's easier when I know it's not just for myself :)
Monday, July 17, 2006
What a weekend ;)
Wow, I have to go to sleep, but before I do that I have to report. So the last iteration ended a day earlier because Friday we all taken by the company for a integration party in the country. We integrated with another company that does a system we have to interface with. It was really cool :), the lake's water had 25*C, it was a really pleasant swim.
Then I came back Saturday evening with a little hangover, and Sunday I had to drive my wife 1100km so she could buy a dog. That was really crazy, I vaguely remember anything from this trip, although I was the driver ;)). The puppy is really cute and adorable ;)). It's a samoyed, for now a white and fluffy snowball. The dog is intended to be trained by my wife and then used for children's AA (Animal Assisted) Therapy. She's a really great woman.
Anyway Today morning, after the third night barely touching the pillow I went to work. To tell you the truth we did really well last week. Although we lost one day, we still managed to keep up the speed and maintain 15 Gummi Bears. That leaves us in a steady 2 week overdue with the project, but at least that's something I can be fairly certain. The project peers got the message today, and my head didn't fall yet, so I guess they do feel OK about it.
Today was also a very important day as a lady joined our team, a student from the local university. She's really smart and in spite of being without any professional experience I foresee she'll be a valuable asset to our development team. The first sign of that was that the fact of her coming forced us to move today to a bigger room down the hall, so now we have more space and the air is not so ... intense anymore ;).
Anyway as I said, I ought to go to sleep,
bye for now!
Then I came back Saturday evening with a little hangover, and Sunday I had to drive my wife 1100km so she could buy a dog. That was really crazy, I vaguely remember anything from this trip, although I was the driver ;)). The puppy is really cute and adorable ;)). It's a samoyed, for now a white and fluffy snowball. The dog is intended to be trained by my wife and then used for children's AA (Animal Assisted) Therapy. She's a really great woman.
Anyway Today morning, after the third night barely touching the pillow I went to work. To tell you the truth we did really well last week. Although we lost one day, we still managed to keep up the speed and maintain 15 Gummi Bears. That leaves us in a steady 2 week overdue with the project, but at least that's something I can be fairly certain. The project peers got the message today, and my head didn't fall yet, so I guess they do feel OK about it.
Today was also a very important day as a lady joined our team, a student from the local university. She's really smart and in spite of being without any professional experience I foresee she'll be a valuable asset to our development team. The first sign of that was that the fact of her coming forced us to move today to a bigger room down the hall, so now we have more space and the air is not so ... intense anymore ;).
Anyway as I said, I ought to go to sleep,
bye for now!
Tuesday, July 11, 2006
It's hot!
Oh, my! It's hot! A friend told me that he heard on the news that Warsaw just below Cairo on the list hottest cities this day. Good grief, why did it come to that, if I wanted such temperatures I would gladly do to Cairo in person. It didn't have to come to me instead...
Well, anyway yesterday we did manage to have our Planning Game, it went well, in about 2hrs we were up and running. Interesting though that I still have to ask questions like:
- is this decomposition of this User Story complete?
- Think, if you do all those tasks will it be all?
- In your estimates do you account for test-driving the code and possibly writing some mocks on the way?
As I ask those questions I see that they do add new tasks or change estimates after giving if a thought. Maybe there always needs to be someone to remind that, maybe, I just thought I wouldn't have to constantly keep reminding that.
I updated the executives this new estimates, we'll see where will that bring us ;))
After an hour of work in this tropical climate, two of the programmers said they're going home to work there and at least have a shower every two hours. There was no way to stop them, and I don't blame them. There is no way to get air-conditioning because the building is quite old and it's electrical system is too weak for that. There are no showers. I just hope temperatures will fall soon, if not then we'll have to look for an other office, as the project may b in serious jeopardy. The rest, including me, stayed as home we wouldn't be any more productive home, although we would feel better we'd have our wives and children all over us ;)
See ya soon, if the temperatures wont kill me...
Well, anyway yesterday we did manage to have our Planning Game, it went well, in about 2hrs we were up and running. Interesting though that I still have to ask questions like:
- is this decomposition of this User Story complete?
- Think, if you do all those tasks will it be all?
- In your estimates do you account for test-driving the code and possibly writing some mocks on the way?
As I ask those questions I see that they do add new tasks or change estimates after giving if a thought. Maybe there always needs to be someone to remind that, maybe, I just thought I wouldn't have to constantly keep reminding that.
I updated the executives this new estimates, we'll see where will that bring us ;))
After an hour of work in this tropical climate, two of the programmers said they're going home to work there and at least have a shower every two hours. There was no way to stop them, and I don't blame them. There is no way to get air-conditioning because the building is quite old and it's electrical system is too weak for that. There are no showers. I just hope temperatures will fall soon, if not then we'll have to look for an other office, as the project may b in serious jeopardy. The rest, including me, stayed as home we wouldn't be any more productive home, although we would feel better we'd have our wives and children all over us ;)
See ya soon, if the temperatures wont kill me...
Saturday, July 08, 2006
Velocity goes up
And today we ended the third iteration. I was happy to record 15 Gummi Bears done this time, that compared to 9 last time, and 15 the first time is a good sign. I'll post this information to the executives on Monday directly after our Planning Game
What we noted was that 30% of programming time was done in pairs, I think of it as a good thing, and hope that it'll increase. We also found that all the cards from this iteration were underestimated. Some even by 100%. Lesson learned, hope to do better last time. All those numbers I took from XPlanner and that's one of the good things about this tool, it's simple and gives such numbers on demand, e.g. at the retrospective to see and comment for all.
One more thing that we talked about was a new member of the team. I talked a few days ago with a student of the Warsaw University, and she made a very good impression on me, disputing with me about various subjects. The woman has potential, we'll see how she'll fit the team. I asked them if they have nothing against her joining us, what they think about this idea, as I would like to pair her with somebody. At first she'll of course be just learning as the has none professional experiences and we're thight on schedule, but as I said, she seems bright enough to catch up and commit to the project soon. Anyway the team reacted positively and said to give her a try. And that's what we'll do. I'll call her tomorrow. It was important to me to talk to them first not just put her there, for the team to feel as one, and so be sure that it wont be a problem for anybody. Fortunately everybody was thumbs up.
What we noted was that 30% of programming time was done in pairs, I think of it as a good thing, and hope that it'll increase. We also found that all the cards from this iteration were underestimated. Some even by 100%. Lesson learned, hope to do better last time. All those numbers I took from XPlanner and that's one of the good things about this tool, it's simple and gives such numbers on demand, e.g. at the retrospective to see and comment for all.
One more thing that we talked about was a new member of the team. I talked a few days ago with a student of the Warsaw University, and she made a very good impression on me, disputing with me about various subjects. The woman has potential, we'll see how she'll fit the team. I asked them if they have nothing against her joining us, what they think about this idea, as I would like to pair her with somebody. At first she'll of course be just learning as the has none professional experiences and we're thight on schedule, but as I said, she seems bright enough to catch up and commit to the project soon. Anyway the team reacted positively and said to give her a try. And that's what we'll do. I'll call her tomorrow. It was important to me to talk to them first not just put her there, for the team to feel as one, and so be sure that it wont be a problem for anybody. Fortunately everybody was thumbs up.
They do listen!
I had a talk with one of the executives yesterday, I told him about my concern about the information I push to them, if anyone listens to it. To my surprise he said "yes" we (meaning other executives) are very happy to see those numbers and listen to that carefully. I don't see any business moves that they do, but then again that's non of my concern as long as they listen and understand what I say about the project, and it's status.
Thursday, July 06, 2006
The estimates' update: not so shiny after all
At the daily standup we found that one card that was estimated for an hour or so took two days' work of a pair!. Well shit happens but thing had to be done, so we've shed a tear and moved on. Anyway our velocity isn't gonna be what I expected, too bad. As the last weeks velocity dropped from 15 to 9, I hove to stay at least at this level. This places us having 6 more one-week iterations to come, and the magical date is in 3 weeks. I can't do anything about it. Or can I? What I did was communicated that to the executives and managers loud and clear, I have no idea what they're going to do about it. I hope they're not blind.
I have to speed up my actions and publish the projected project path every Monday, not Wednesday or Thursday. It's 2-3 days lost!
I have to speed up my actions and publish the projected project path every Monday, not Wednesday or Thursday. It's 2-3 days lost!
The Matter Resistance: mocks and attitude
All progress is done in the light of resistance. Without it you don't have a real chance to refine your thoughts and check if what you believe is really something that you can trust. The discussions as long as they don't get personal and long as they don't become monologues are very constructive as you may find holes in your ways and only then you have a chance to spot them and in effect progress.
So yesterday I did have a chance for that in two areas.
First I discovered that I favor static mocks over dynamic too much. It started when a colleague asked whether or not he uses mocks correctly, because he found that changing some system behavior he has to change the dynamic mocks he uses as they are still set to the old way and the test fail. I said that it's perfectly normal and he should change them as well. Then he's shown me how he uses those dynamic mocks (dynamic proxies), and I said that in most of these cases I would use a static mock (a null implementation), and we talked a little more.
The conclusion was that there isn't a hard line which separates the use of static versus dynamic mocks, but more importantly I found that I got too friendly with the static ones, as e.g. it is a good thing that his tests didn't pass as it's a empirical proof that those tests really do test something, and that has built more trust in us. And that's good.
I found that the use of static mocks in such a case might have not cached the change and we wouldn't get that valuable piece of feedback, but what struck me was that a dynamic mock has a greater chance to uncover a badly written test (or mock), because you set specific expectations and not just a dummy null implementation that does not verify how it's been used. I certainly have to pay more attention to that and make more use of them.
But then my further remark was that on the other end the extensive usage of dynamic mocks may uncover, cause, or sanction tight coupling and an unclear architecture, so you have to stay alert and primarily use your head then mocks :).
The second thing was a chat with the leading programmer, he also plays a role of a customer proxy. He was the one to earlier refuse to work on some subject for now, as he has a different view on how do implement something from the rest of the team. He told me that although he sees that those things I've brought to the team are good and helpful he does not identify with them. He said he will not cause any trouble and will cooperate, but personally this is not a way he wishes to work, he has a long (10+ years) history of software and hardware development and he likes to work alone or with his partner who grasps everything just like him. Additionally he says that all the planning, story cards and stuff he has in his head and that suffices if he and his partner are the only one on the team. He says he has a history of happy customers that loved the products he gave them, done quite internally with little in-process feedback from the customer, and those programs are till today flawless.
Well what could I say to that? I said: "Well, let me treat that as one of the wonders of nature. I'm happy for you, but too many times I saw just the opposite to fall for that." What was I supposed to say? :)
We had an open talk so we assured each other that all your disputes are not personal and stay professional, so that we progress as a whole. Again he added that this is very interesting for him to realize that this style of work as advocated by XP is very useful and valid but it is not the style he wishes to practice in the future and maybe that's a sign for him to change some things in his professional life.
I'll never give up trying to convince him to those values but I know I'll have a hard time doing that. Nevertheless it was a healthy discussion and I hope it has set our attitudes towards each other in the right direction.
So yesterday I did have a chance for that in two areas.
First I discovered that I favor static mocks over dynamic too much. It started when a colleague asked whether or not he uses mocks correctly, because he found that changing some system behavior he has to change the dynamic mocks he uses as they are still set to the old way and the test fail. I said that it's perfectly normal and he should change them as well. Then he's shown me how he uses those dynamic mocks (dynamic proxies), and I said that in most of these cases I would use a static mock (a null implementation), and we talked a little more.
The conclusion was that there isn't a hard line which separates the use of static versus dynamic mocks, but more importantly I found that I got too friendly with the static ones, as e.g. it is a good thing that his tests didn't pass as it's a empirical proof that those tests really do test something, and that has built more trust in us. And that's good.
I found that the use of static mocks in such a case might have not cached the change and we wouldn't get that valuable piece of feedback, but what struck me was that a dynamic mock has a greater chance to uncover a badly written test (or mock), because you set specific expectations and not just a dummy null implementation that does not verify how it's been used. I certainly have to pay more attention to that and make more use of them.
But then my further remark was that on the other end the extensive usage of dynamic mocks may uncover, cause, or sanction tight coupling and an unclear architecture, so you have to stay alert and primarily use your head then mocks :).
The second thing was a chat with the leading programmer, he also plays a role of a customer proxy. He was the one to earlier refuse to work on some subject for now, as he has a different view on how do implement something from the rest of the team. He told me that although he sees that those things I've brought to the team are good and helpful he does not identify with them. He said he will not cause any trouble and will cooperate, but personally this is not a way he wishes to work, he has a long (10+ years) history of software and hardware development and he likes to work alone or with his partner who grasps everything just like him. Additionally he says that all the planning, story cards and stuff he has in his head and that suffices if he and his partner are the only one on the team. He says he has a history of happy customers that loved the products he gave them, done quite internally with little in-process feedback from the customer, and those programs are till today flawless.
Well what could I say to that? I said: "Well, let me treat that as one of the wonders of nature. I'm happy for you, but too many times I saw just the opposite to fall for that." What was I supposed to say? :)
We had an open talk so we assured each other that all your disputes are not personal and stay professional, so that we progress as a whole. Again he added that this is very interesting for him to realize that this style of work as advocated by XP is very useful and valid but it is not the style he wishes to practice in the future and maybe that's a sign for him to change some things in his professional life.
I'll never give up trying to convince him to those values but I know I'll have a hard time doing that. Nevertheless it was a healthy discussion and I hope it has set our attitudes towards each other in the right direction.
Tuesday, July 04, 2006
First pair programming experiences
Yesterday we started with a usual Monday Planning Game for this week, it took us approx. 2 hours, so I figure we're getting better at it.
We carried on the stories unfinished in the previous Iteration, and allocated a bit more than last week, but less than the first week, we'll see how that turns out.
Yesterday I encouraged the team to pair a little, so two of the programmers worked on separate things, and another two paired (a junior and a senior). They obviously did seem to take much fun out of it, I personally hope to have raised their productivity.
The people sat together at one laptop (I know it isn't how it's supposed to be, but I'll deal with that later) and so after watching them for a few minutes I told the other guy to bring his keyboard and mouse and plug it in, so they both were able to easily type and move around.
I have my personal doubts about Pair Programming to go over, and fears to diminish. I am quite sure that PP should be used a lot, I not sure how much, pairing for 100% of the coding time does not make sense to me. 50%, 70%, but 100%? There are many simple tasks that no matter how much heads you put together it isn't gonna make it nor faster nor better. I know the arguments, I just have that gut feeling (fear?) and some mixed experiences with that on previous teams that lead me to this conclusion. Though I'd be very happy to discover otherwise. E.g. I never got close to achieving the 15% overhead of PP as measured by Alistair Cockburn, I have some thoughts on why that might've happened to me but that doesn't change the fact.
We carried on the stories unfinished in the previous Iteration, and allocated a bit more than last week, but less than the first week, we'll see how that turns out.
Yesterday I encouraged the team to pair a little, so two of the programmers worked on separate things, and another two paired (a junior and a senior). They obviously did seem to take much fun out of it, I personally hope to have raised their productivity.
The people sat together at one laptop (I know it isn't how it's supposed to be, but I'll deal with that later) and so after watching them for a few minutes I told the other guy to bring his keyboard and mouse and plug it in, so they both were able to easily type and move around.
I have my personal doubts about Pair Programming to go over, and fears to diminish. I am quite sure that PP should be used a lot, I not sure how much, pairing for 100% of the coding time does not make sense to me. 50%, 70%, but 100%? There are many simple tasks that no matter how much heads you put together it isn't gonna make it nor faster nor better. I know the arguments, I just have that gut feeling (fear?) and some mixed experiences with that on previous teams that lead me to this conclusion. Though I'd be very happy to discover otherwise. E.g. I never got close to achieving the 15% overhead of PP as measured by Alistair Cockburn, I have some thoughts on why that might've happened to me but that doesn't change the fact.
Saturday, July 01, 2006
First problems
Today we had our second Retrospective and the end of the second Iteration. Also today is the day we encountered our first problems. I feared everything was going so smooth, so I'm relieved to find that everything's quite normal.
The first problem is we underestimated two of the stories we committed to, and thus didn't complete as much as we wanted to. The raw velocity for this Iteration was 9 Gummi Bears, considering the half done stories about 13, but I know we have to stick to those 9 as only those stories were fully closed.
We also discovered that the task decomposition of one of the stories was overly bad, there was no way to implement it according to the tasks, the tasks should be aligned rather orthogonally to how we decomposed the story on Monday.
The second problem was (and still is) of a different nature. Yesterday one of the developers agreed to work with another one on a certain story. Today he found that his way of implementing this and similar stories is very different from the way proposed by the person who took responsibility for the story. I told them to have a positive discussion on that subject, so they did for almost an hour, then we brought the subject to the team's forum, so we collectively decided that the original idea was better. So that person said "OK, I'm sure this will not work (although he wasn't able to convince us). Do it the way you want to do it, but please, for the sake of the deadline we have in a few weeks, please keep me out of the implementation details of this story. After this deadline I'll be more than happy to learn that and maintain that part of the system (although I know it'll be a disaster), but for the time please take that responsibility and leave me out of it."
At first that scared me. Then again I said something like: "well OK, maybe it's a good thing, we'll pair you with other people so that everyone's comfortable, and we'll see after this deadline how things work out."
I really didn't know what to do. I knew that he was a very valuable asset in that area, and he could have helped a lot because no one understands this business as well as him. But then again I don't want him to feel brutally forced and pinned down to doing something that makes him sick. Out of two evils I figured that the latter is worse, as it could cause a lot of collateral damage if this person really feels that way towards this idea.
I dunno if I made the right choice, we'll have to wait, observe and learn from that. Maybe one reason for that in the first place was his absence on the Planning Game on Monday, but I'm not sure his presence would've prevented it.
We had a longer retrospective than originally planned but we needed to say things, I hope they were true. We agreed that we don't take those arguments and quarrels personally, and we don't stop to like each other, we just happen to have different opinions on many technical problems. Personally I think that diversity is a plus for the team, as long as it doesn't tear the team apart, which apparently didn't happen (yet).
Anyway, my wife and I are going to visit our parents for the weekend, so I hope to rest a bit for the next Planning Game on Monday starting another adventurous Iteration. So stay tuned...
The first problem is we underestimated two of the stories we committed to, and thus didn't complete as much as we wanted to. The raw velocity for this Iteration was 9 Gummi Bears, considering the half done stories about 13, but I know we have to stick to those 9 as only those stories were fully closed.
We also discovered that the task decomposition of one of the stories was overly bad, there was no way to implement it according to the tasks, the tasks should be aligned rather orthogonally to how we decomposed the story on Monday.
The second problem was (and still is) of a different nature. Yesterday one of the developers agreed to work with another one on a certain story. Today he found that his way of implementing this and similar stories is very different from the way proposed by the person who took responsibility for the story. I told them to have a positive discussion on that subject, so they did for almost an hour, then we brought the subject to the team's forum, so we collectively decided that the original idea was better. So that person said "OK, I'm sure this will not work (although he wasn't able to convince us). Do it the way you want to do it, but please, for the sake of the deadline we have in a few weeks, please keep me out of the implementation details of this story. After this deadline I'll be more than happy to learn that and maintain that part of the system (although I know it'll be a disaster), but for the time please take that responsibility and leave me out of it."
At first that scared me. Then again I said something like: "well OK, maybe it's a good thing, we'll pair you with other people so that everyone's comfortable, and we'll see after this deadline how things work out."
I really didn't know what to do. I knew that he was a very valuable asset in that area, and he could have helped a lot because no one understands this business as well as him. But then again I don't want him to feel brutally forced and pinned down to doing something that makes him sick. Out of two evils I figured that the latter is worse, as it could cause a lot of collateral damage if this person really feels that way towards this idea.
I dunno if I made the right choice, we'll have to wait, observe and learn from that. Maybe one reason for that in the first place was his absence on the Planning Game on Monday, but I'm not sure his presence would've prevented it.
We had a longer retrospective than originally planned but we needed to say things, I hope they were true. We agreed that we don't take those arguments and quarrels personally, and we don't stop to like each other, we just happen to have different opinions on many technical problems. Personally I think that diversity is a plus for the team, as long as it doesn't tear the team apart, which apparently didn't happen (yet).
Anyway, my wife and I are going to visit our parents for the weekend, so I hope to rest a bit for the next Planning Game on Monday starting another adventurous Iteration. So stay tuned...
Friday, June 30, 2006
Talking to executives
After measuring the velocity of the first iteration I summed up the Gummi Bears of all the rest of the stories to come up with a first impression of the number of iterations needed to complete those stories.
So Tuesday I felt brave and waltzed into by boss's office with good news and bad news. :). The good news were it's not as bad as it might have been, and to say the truth, not as bad as I suspected. The bad news was we are one iteration short for now, as I said in my previous blog entry.
His reaction was like: "OK", which scared me because I didn't know what it really meant. As I talked to him more we came to a conclusion that we have to observe at least one more Iteration.
I think things may speed up in some degree, because one of the programmers is now 3 days a week, and is willing to be full-time in the summer. Additionally I hope to finish other external things and also start committing to development tasks. I'd really like that.
We also agreed that every week I will publish project status and prognosis to all the managers engaged in this project. I did that yesterday. I also gave them access to XPlanner to see for themselves (those that are in a distant location) how the project progresses (or not).
I'm curious how they'll react.
So Tuesday I felt brave and waltzed into by boss's office with good news and bad news. :). The good news were it's not as bad as it might have been, and to say the truth, not as bad as I suspected. The bad news was we are one iteration short for now, as I said in my previous blog entry.
His reaction was like: "OK", which scared me because I didn't know what it really meant. As I talked to him more we came to a conclusion that we have to observe at least one more Iteration.
I think things may speed up in some degree, because one of the programmers is now 3 days a week, and is willing to be full-time in the summer. Additionally I hope to finish other external things and also start committing to development tasks. I'd really like that.
We also agreed that every week I will publish project status and prognosis to all the managers engaged in this project. I did that yesterday. I also gave them access to XPlanner to see for themselves (those that are in a distant location) how the project progresses (or not).
I'm curious how they'll react.
Subscribe to:
Comments (Atom)
 
