Thanks for the comments, Luke, glad we're thinking along the same
lines!
-Stuart Sierra

On Jan 19, 1:24 pm, Luke Amdor <luke.am...@gmail.com> wrote:
> Thanks Stuart for the with-test macro. It will make my life much
> easier. I have been putting my tests in the :test metadata and running
> them with (run-tests). The with-tests macro will make it much more
> readable. I was also having problems with old test metadata hanging
> around.
>
> I am all in favor of putting the tests right next to the function
> being tested. The anti-"side effect" nature of Clojure promotes this
> in fact. If I can have a test suite ran upon loading with no required
> assistance from the caller, that would be great.
>
> I also think that if your test needs a description of what it's doing,
> then that's a smell. It's an excuse for easily readable code and I
> think we can all agree that we should try to make our code as easily
> readable as possible.
>
> Luke
>
> On Jan 18, 3:03 pm, James Reeves <weavejes...@googlemail.com> wrote:
>
> > On Jan 18, 4:24 pm, Stuart Sierra <the.stuart.sie...@gmail.com> wrote:
>
> > > After thinking a while about the discussion about test-is <http://
> > > groups.google.com/group/clojure/browse_thread/thread/59e9cebbe67cab3f/
> > > 508f1e8de753455c>, here's a short article with my current thoughts:
>
> > >http://stuartsierra.com/2009/01/18/tests-are-code
>
> > > Comments welcome here or on the blog.
>
> > I've written an RSpec-like testing framework in Clojure, so I have a
> > few opinions on this.
>
> > 1. I don't like the idea of putting tests next to the functions
> > they're testing. There's an argument that says tests make good
> > documentation, but I'm of the opinion that tests are too repetitive to
> > be effective in that capacity. A good piece of documentation will
> > provide several common examples; a thorough test will go through
> > dozens of edge-conditions. So if tests aren't documentation, putting
> > them next to the functions they test just clutters up the source code
> > with unnecessary information.
>
> > 2. Test should come with a description of what scenario they are
> > testing, so I favour the RSpec approach of using short descriptive
> > strings to identify tests, rather than symbols.
>
> > 3. The biggest problem I've had with tests is generating test data. I
> > like the Quickcheck approach of generating lists of random values
> > (because it's easy for me), but when trying to use that approach in my
> > Fact testing framework I've found that really only works with a
> > minority of problems. I haven't figured out a good solution for easily
> > generating test data, but I think it's one of the most important
> > problems for a unit testing framework to overcome.
>
> > 4. I lean toward the idea that a test should contain a single
> > predicate that's tested with numerous inputs. But again, I haven't
> > figured out a way of doing this that works well in all situations :)
>
> > - James
--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Clojure" group.
To post to this group, send email to clojure@googlegroups.com
To unsubscribe from this group, send email to 
clojure+unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/clojure?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to