views:

48

answers:

3

Note: I use TRAC integrated with SVN, framework testing tools, an excellent mixture of staging servers, development servers, and other tools to speed development and keep track of tasks.

I am asking about the specific process of design, and even more specifically, the design of functionality and flow in a web application.

--- Original question ---

So far I spend a lot of time with my text editor open basically talking to myself, then coding for a while, then talking to myself again. When there is more than just me we do some whiteboarding, but that's about it.

What do you find works well, specifically for projects for very small teams or one-developer shows.

BTW I usually develop with Django, this last project also involves RabbitMQ and Orbited, plus a fair chunk of jquery-assisted JavaScript.

+1  A: 

Another mainly solo developer here. I recommend using a bug/issue tracker. I use TRAC (although I'm looking at alternatives). It might seem strange, since you're the one creating, assigning, and closing all tickets, but it really helps to plan out/prioritize development. I also use the wiki to organize my thoughts on the roadmap, main goals of each release, etc.

Ryan Ginstrom
I use TRAC actually, I really like it. But does TRAC really help you *design* something? I'm looking for workflow tools, Balsamiq is an example of something that doesn't quite help me, and use cases are an example of a method that I vaguely understand and help me from time to time.
Henry
No, it doesn't help you design the system. But it's very good at prioritizing your development focus, which is also very useful. It's also a good way to document the design, using the wiki and linking variously to the source.
Ryan Ginstrom
+1  A: 

+1 for a good question.

Web development is not much different to any other development.

P.20 of that venerable classic breaks a typical project down into 1/3 planning, 1/6 coding, 1/4 component test and 1/4 system test. I might catch some flak for that, YMMV and all, but that looks about right to me.

Whether or not you agree with the proportions, the message is "don't jump right in and code; think about it first (measure twice, cut once). How often have you jumped in and coded only to get near to "then end" and discover that you have a fundamental design flaw and have to through away much of your code & rewrite chunks more?

You need methodologies (Processes) and Tools, and each can necessitate the other.

Methodologies

  • Design it first! Gather requirements, make a system level design document then detailed design. If you are more than one, have these reviewed by someone (client can maybe review the high level docs?). If if you are alone, the simple act of writing it down forces you to slow down and think and will uncover problems. A good idea is to have a requirements traceability matrix to ensure that each requirement gets designed, implemented and tested somewhere.

  • After you review the high level design, you can being the detailed design, and after you review that, you can begin to implement. When the high level design is reviewed you can, in parallel, or later, produce a high level test spec. When the detailed level design is reviewed you can, in parallel, or later, produce unit test specs.

  • Note that test cases should be automated and should require no human interaction. Get into the habit of running regression tests after every code change - automate this if you can, with nightly build and or coupled with check-in to your version control system.

  • When everything is thoroughly unit tested, you can begin your system level testing.

Tools

At the very least you ought to be considering these:

  • A good IDE (WYSIWYG for web design), preferably with debugging capabilities, and it would be nice if it interfaced with your version control system, bug tracker, etc. A spill chuker is useful for websites ;-)

  • A project management tool to plan the project (Open Workbench does some nice Gantt charts)

  • A version control system.

  • A change request and bug tracker.

  • An automated test system.

  • An automated build system like Hudson (it may not seem relevant if you don't compile and link, but at least it can verify that all files exist and can schedule regression testing for you)

  • A backup system in case of disk crash, laptop loss, etc.

And if all that seems like too much "extra" to do, I was sceptical too once, until I saw that it actually saves time because you discover problems earlier when they cost less to fix. In fact, I am so sure of this that I do all of my personal one-man hobby projects this way. All of them.

LeonixSolutions
I should have asked my question differently. I have an IDE, a project management tool, version control system, change request and bug tracker, unit tests, integration tests, backups, etc. I meant, specifically, *workflow*. When you're hashing out what goes where, who talks to what, developing or using existing protocols, what tools and methods do you use?
Henry
+1  A: 

Pencils!

Seriously, we use JIRA to track work/issue, Confluence to track requirements before they're baked enough to put in JIRA.. Anything to scratch together wire-frames, etc. (Including OmniGraffle, and Pencils).

I find the combination of JIRA and Confluence for tracking chunks of work and longer-lived concepts and standards pretty darned effective.

royal
@royal thanks, this is really interesting stuff, and exactly the kind of response I was looking for.
Henry