Midje is a test framework for Clojure. I created it to support top-down as well as bottom-up testing, to encourage readable tests, to provide a smooth migration path from clojure.test, to support a balance between abstraction and concreteness, and to be gracious in its treatment of you, my valued guest.
Here's a simple Midje test:
(fact (numerical-reverser 103) => 301)
I call this a "fact" because, in a world without mutability,
it just is a fact that the
numerical-reverser of 103 is
301. Since I work test-first, I like to think of programming as making false claims
about the world of the program, then changing that world to
make the claims true.
I use the arrow because I think of tests as examples. When people show snippets of code as examples, they often use an arrow to separate what you type from what you should expect to see.
The object on the right-hand side of the arrow can be a function, in which case the value of the left-hand side is passed to it. So this is also a fact:
(fact (numerical-reverser 103) => odd?)
Midje comes with a selection of predefined
that are more useful for testing than
Midje's other useful features are described in the user guide. If anything there is unclear, ask in the mailing list. If you like videos of people programming, here's an 8-minute infomercial that concentrates on transitioning from clojure.test. If you like looking straight at code, this heavily annotated example has a bunch. If you want to run that example, you can download it:
- Click here.
- In a shell, go to the directory your browser unpacked the example into. It should be named
- Go to
- Type "./run" or "lein test".
- The facts in
test/*/core_test.cljwill be checked.
You can download everything to get more examples.
- Sean T. Allen
- Alex Baranosky
- Phillip Calçado
- Ben Mabey
- Brian Marick
- Bob Martin
- Sébastien RoccaSerra
- Wilkes Joiner