[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: testing macros and fixtures
From: |
Phillip Lord |
Subject: |
Re: testing macros and fixtures |
Date: |
Tue, 13 Oct 2015 10:23:50 +0100 |
User-agent: |
Gnus/5.13 (Gnus v5.13) Emacs/24.5 (gnu/linux) |
Okay. This is definately something worth looking at, then. I think
writing tests is probably too hard at the moment!
Phil
Kaushal Modi <address@hidden> writes:
> verilog-mode runs similar tests from outside emacs.
>
>>From the terminal, the verilog-mode functions are run in emacs batch mode
> on files in the tests/ dir and and the results are compared against the
> files in tests_ok/ dir (if I understand correctly).
>
> Repo on github which is then commited to emacs core:
> https://github.com/veripool/verilog-mode
>
> Perl script to run batch tests:
> https://github.com/veripool/verilog-mode/blob/master/batch_test.pl
>
>
> --
> Kaushal Modi
>
> On Mon, Oct 12, 2015 at 5:13 PM, Phillip Lord <address@hidden>
> wrote:
>
>>
>> I have been thinking about testing since it was raised in one of the
>> last gargantuan threads.
>>
>> ERT is quite nice, but one of the things that I have found lacking is a
>> nice set of predicates, for use within should.
>>
>> So, when I wrote test for my "lentic" package I needed some functions
>> like, so that I could do things like:
>>
>> (should
>> (test-eq-after-this
>> "blah-before.txt"
>> "blah-after.txt"
>> (insert "hello")))
>>
>> which opens "blah-before.txt" runs (insert "hello") then compares the
>> result with "blah-after.txt". My version of this also does a diff of the
>> results if the two are not equal.
>>
>> I've noticed that "puppet-mode" has some thing similar. For instance:
>>
>> (puppet-test-with-temp-buffer "# class
>> bar"
>> (should (eq (puppet-test-face-at 1) 'font-lock-comment-delimiter-face))
>> (should (eq (puppet-test-face-at 3) 'font-lock-comment-face))
>> (should (eq (puppet-test-face-at 7) 'font-lock-comment-face))
>> (should (eq (puppet-test-face-at 8) 'font-lock-comment-face))
>> (should-not (puppet-test-face-at 9))))
>>
>> And julia-mode has indentation checking tests like so:
>>
>> (julia--should-indent
>> "
>> if foo
>> bar
>> else
>> baz
>> end"
>> "
>> if foo
>> bar
>> else
>> baz
>> end"))
>>
>>
>> My own experience is that these are actually quite hard to right. The
>> ones in lentic have never worked quite right -- that is, when it all
>> works they are fine, but restoring state after a crash doesn't always
>> work. Similarly, checking that, for example, test files are not already
>> open before a test is run interactively.
>>
>> So, the point of my question is this; are there any good libraries
>> providing this kind of fixture logic? A lot of this should surely be
>> re-usable between different packages.
>>
>> Phil
>>
>>
>>
>>
>>