Failure and trashing
Last week wasn't a very good week. The rate of work that I did vs. the work that I expected to do was very low. Basically, I should have done all that work in about a day or two.
Most of the issue was because I had no time in the zone this week, meeting, pairing on other people's code, etc have taken a lot of little pieces, but the main issue was that I kept going in the wrong direction. I needed to implement something similar to Outlook's rules, but for search, where you can add more criteria for your search, and the user can specify and/or condition, etc.
It is fairly simple to do it on the back end, but my problem was that I couldn't get a solid UI story as well as as solid interaction story between the client / server. It kept being this close, but I never got there, argh! I run into all sorts of problems, from realizing that my querying method wasn't going to scale for that approach, and switching back to NHibernate, which can scale, to javascript debugging fubars that kept creeping up, assembly versionning issues,
And all my solutions where of increasing complexity. So far, I worked on the same feature for about the estimated time that I given it, but it is not complete by any mean. I finally decided that I am not going to take this kind of cheek from my code and deleted it. Then I started from scratch, I run into some of the same problem, but now my goal was to make it stupid. Not make it work, just make it stupid enough to look like it would work.
That approach have worked, surprisingly. I got the first big piece of it working (the and / or with UI and client/server interactions) in about three hours, and the rest was fairly smooth sailing from there.
I keep telling my team members, if you are on something more than 15 minutes, either call someone or move to something else. I really should start listening to myself, occasionally I actually says something that I ought to do.
Anyway, I think that I covered in about a day the entire feature, and I now can extend it to the next feature with great ease.
Oh, and by the way, I want to give a big thanks to the guys from Lunaverse, the Story Verse code has been a source of great inspiration for this feature.
Comments
This is very much true. I can still remember how nervous I was when a colleague of mine had been working on an assigned task for more then few minutes when we had been developing a very first version of Sprinx CRM.
Even today when I am developing almost only small robots etc., I still feel that you should follow the simpliest way you can see in front of you.
Heck with pairs coding, Get your own work done or risk getting fired.
"I keep telling my team members, if you are on something more than 15 minutes, either call someone or move to something else." That's my case as well, on the one hand I keep telling people that once your are stuck you need to take a break but then on the other hand I forget to apply this rule to myself.
Comment preview