Leiningen monkey patches clojure.test so I tend not to trust it for repros.

> On Dec 18, 2018, at 12:05 PM, Andy Fingerhut <andy.finger...@gmail.com> wrote:
> 
> I do not know if Leiningen is involved in the difference in the reproduction 
> project linked below yet (I am testing with the latest Leiningen 2.8.3 here), 
> but I do see a clojure.test `(is (thrown-with-msg? ...` expression that gives 
> no error when running 'lein test' with Clojure 1.9.0, but does with Clojure 
> 1.10.0.  I do not know if it is the same root cause as Mark's example or not, 
> but wanted to create this in hopes it represents a minimal test case to 
> reproduce the behavior difference.
> 
> https://github.com/jafingerhut/clojure-110-is-thrown
> 
> Andy
> 
>> On Tue, Dec 18, 2018 at 7:07 AM Alex Miller <a...@puredanger.com> wrote:
>> In particular, I am challenging this assertion from the original post:
>> 
>> However, the following test (using is from clojure.test) used to work prior 
>> to 1.10, but now fails:
>> 
>> => (is (thrown? AssertionError (f true)))
>> Unexpected error (AssertionError) macroexpanding f at 
>> (test:localhost:62048(clj)*:268:56).
>> Assert failed: (number? x)
>> 
>> When I do this on 1.9 I see:
>> 
>> user=> (is (thrown? AssertionError (f true)))
>> CompilerException java.lang.AssertionError: Assert failed: (number? x), 
>> compiling:(NO_SOURCE_PATH:20:29)
>> 
>> Which is printed differently but is the same behavior, because this is 
>> happening while expanding the is, not during execution.
>> 
>> I believe you're seeing a change in your test suite, I'm just having a hard 
>> time reproducing what you're seeing.
>> 
>> 
>>> On Tuesday, December 18, 2018 at 8:47:11 AM UTC-6, Alex Miller wrote:
>>> This particular example given fails in a similar way on 1.9. Could you give 
>>> me something closer to what you are actually seeing in your test suite? 
>>> Specifically something that is a passing clojure.test test on 1.9 but a 
>>> failure/error on 1.10? 
>>> 
>>> The problem with the given example is that it fails during macroexpansion 
>>> of the test itself, not during test execution, and I don't think that's the 
>>> case you're trying to replicate.
>>> 
>>>> On Tuesday, December 18, 2018 at 8:35:54 AM UTC-6, Alex Miller wrote:
>>>> I think the relevant change here is that exceptions thrown during 
>>>> macroexpansion are now wrapped into CompilerExceptions as a way to attach 
>>>> all of the source context information. The REPL understands this and still 
>>>> prints the original cause so the printing hides some of that structure 
>>>> (but you can see it by looking at the exception chain). 
>>>> 
>>>> This here is a particularly tricky case here though and I think there 
>>>> might be something else coming into play, still looking at it. There was a 
>>>> couple other changes inside the compiler exception handling that might 
>>>> also be coming into play.
>>>> 
>>>> (Would have been great to see this during a pre-release build rather than 
>>>> after release! ;) 
>>>> 
>>>> 
>>>>> On Tuesday, December 18, 2018 at 3:51:58 AM UTC-6, puzzler wrote:
>>>>> Agreed.  It is not a problem for functions which throw AssertionErrors, 
>>>>> only macros.  But this is a change in behavior which breaks test suites 
>>>>> which passed previously.
>>>>> 
>>>>>> On Tue, Dec 18, 2018 at 1:48 AM alex <fmno...@gmail.com> wrote:
>>>>>> I'm not sure, but probably it behaves so because of throwing at 
>>>>>> macroexpand stage.
>>>>>> 
>>>>>> вторник, 18 декабря 2018 г., 11:29:09 UTC+2 пользователь puzzler написал:
>>>>>>> 
>>>>>>> Consider the following macro:
>>>>>>> 
>>>>>>> (defmacro f [x] {:pre [(number? x)]} `(+ ~x 5))
>>>>>>> => (f 3)
>>>>>>> 8
>>>>>>> => (f true)
>>>>>>> Unexpected error (AssertionError) macroexpanding f at 
>>>>>>> (test:localhost:62048(clj)*:265:28).
>>>>>>> Assert failed: (number? x)
>>>>>>> 
>>>>>>> So, as expected it throws an AssertionError if passed a non-number.
>>>>>>> However, the following test (using is from clojure.test) used to work 
>>>>>>> prior to 1.10, but now fails:
>>>>>>> 
>>>>>>> => (is (thrown? AssertionError (f true)))
>>>>>>> Unexpected error (AssertionError) macroexpanding f at 
>>>>>>> (test:localhost:62048(clj)*:268:56).
>>>>>>> Assert failed: (number? x)
>>>>>>> 
>>>>>>> What's odd is that the macro still throws an AssertionError, but the 
>>>>>>> `thrown?` inside the `is` is no longer intercepting the AssertionError, 
>>>>>>> so the test doesn't pass -- instead the error causes a failure in the 
>>>>>>> test suite.
>> 
>> -- 
>> 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.
> 
> -- 
> 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 a topic in the Google 
> Groups "Clojure" group.
> To unsubscribe from this topic, visit 
> https://groups.google.com/d/topic/clojure/b2fdyfhFBrg/unsubscribe.
> To unsubscribe from this group and all its topics, send an email to 
> clojure+unsubscr...@googlegroups.com.
> For more options, visit https://groups.google.com/d/optout.

-- 
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