in reply to Re^8: Developing a module, how do you do it ?
in thread Developing a module, how do you do it ?
I would like to use more testing
I do test. Just not with the Test::* tools.
It is my contention that when writing a module, you should write the application (or at least an application) that uses that module, concurrently with the development of the module itself. This improves the module design by ensuring that its interface works with the needs of the application. That it has the entry points the application needs, and no more. The application becomes the prototypical test-bed for the module.
Far too many modules are developed in isolation of their use case, designed on the basis of what-if and maybe and it-could-do, hence you end up with clumsy, fragile, bloated, and over-specified interface definitions
Once the module is written and working with the application, then is the time to go back and see if it can be generalised to some degree, without breaking the original use case. At that point I write a generic application -- a cut-down and simplified version of the original use case -- that self-checks its own results and serves as test case and regression test, and lives in the module file itself. It can then be annotated and also serves as user documentation for the module.
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^10: Developing a module, how do you do it ?
by aaron_baugher (Curate) on Mar 03, 2012 at 20:58 UTC | |
by BrowserUk (Patriarch) on Mar 03, 2012 at 21:18 UTC |