Not an answer to your question, but I usually just redefine 
clojure.tools.logging/log* instead for tests.

On Monday, April 27, 2015 at 9:34:14 AM UTC-7, Vebjorn Ljosa wrote:
>
> In one of my tests, I was trying to mock something 
> (`clojure.tools.logging/warn`) that happened to be a macro. It had me 
> puzzled for a while until I discovered that `with-redefs` resets the value 
> of the vars after the body is executed, but does not reset the flag that 
> says that the var is a macro:
>
> $ lein repl
> Clojure 1.6.0
> …
> user=> (defmacro foo [] `(prn "I am a macro")) 
> #'user/foo 
> user=> (clojure.test/function? 'foo)
> false
> user=> (with-redefs [foo (fn [] 42)])
> nil
> user=> (clojure.test/function? foo) 
> true
> user=> (foo) 
> ArityException Wrong number of args (0) passed to: user/foo 
> clojure.lang.AFn.throwArity (AFn.java:429) 
> user=> (foo 42 42) 
> (clojure.core/prn "I am a macro")
>
> Is this a bug?
>
> I looked at the source for `with-redefs-fn`, and the fix appears simple: 
> record for each val whether it's a macro or not, and then call the 
> `(setMacro)` method on the vars that should be macros after resetting their 
> values.
>
> Vebjorn
>

-- 
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
Note that posts from new members are moderated - please be patient with your 
first post.
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
--- 
You received this message because you are subscribed to the Google Groups 
"Clojure" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to clojure+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to