Toggle menu
15
236
81
27.8K
Kenshi Wiki
Toggle preferences menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

Module:UnitTests/doc: Difference between revisions

From Kenshi Wiki
Prd (talk | contribs)
No edit summary
Prd (talk | contribs)
No edit summary
Line 1: Line 1:
UnitTests provides a unit test facility that can be used by other scripts using '''require'''. Following is an example:
UnitTests provides a unit test facility that can be used by other scripts using '''require'''. See [[Wikipedia:Lua#Unit_testing]] for details. The following is a sample from [[Module:Example/testcases]]:


<syntaxhighlight lang="lua">
{{#tag:syntaxhighlight|
-- Unit tests for [[Module:Bananas]]. Click talk page to run tests.
-- Unit tests for [[Module:Example]]. Click talk page to run tests.
local p = require('Module:UnitTests')
local p = require('Module:UnitTests')


function p:test_hello()
function p:test_hello()
     self:preprocess_equals('{{#invoke:Bananas| hello}}', 'Hello World!')
     self:preprocess_equals('<nowiki>{{#invoke:Example | hello}}</nowiki>', 'Hello World!')
end
end


return p
return p
</syntaxhighlight>
|lang="lua"}}


This would be executed with <code><nowiki>{{#invoke: Bananas/testcases | run_tests}}</nowiki></code>. Test methods like test_hello above must begin with "test".
The talk page [[Module talk:Example/testcases]] executes it with <code><nowiki>{{#invoke: Example/testcases | run_tests}}</nowiki></code>. Test methods like test_hello above '''must begin with''' "'''test'''".


== Methods ==
== Methods ==
=== run_tests ===
=== run_tests ===
* <code>run_tests</code> - Runs all tests. Normally used on talk page of unit tests.
* {{code|1=run_tests}}: Runs all tests. Normally used on talk page of unit tests. <syntaxhighlight lang="wikitext">
<pre>
{{#invoke:Example/testcases|run_tests}}
    {{#invoke:Bananas/testcases|run_tests}}
</syntaxhighlight>
</pre>
* If {{code|1=differs_at}} is specified, a column will be added showing the first character position where the expected and actual results differ. <syntaxhighlight lang="wikitext">
* If <code>differs_at=1</code> is specified, a column will be added showing the first character position where the expected and actual results differ.  
{{#invoke:Example/testcases|run_tests|differs_at=1}}
<pre>
</syntaxhighlight>
<includeonly>
* If {{code|1=highlight}} is specified, failed tests will be highlighted to make them easier to spot. A [[WP:USERSCRIPT|user script]] that [[User:Fred_Gandt/moveFailedModuleTestsToTop.js|moves failed tests to the top]] is also available. <syntaxhighlight lang="wikitext">
[[Category:Modules]]</includeonly>
{{#invoke:Example/testcases|run_tests|highlight=1}}
<noinclude>
</syntaxhighlight>
[[Category:Module documentation pages]]</noinclude>
* If {{code|1=live_sandbox}} is specified, the header will show the columns "Test", "Live", "Sandbox", "Expected". This is required when using the {{code|1=preprocess_equals_sandbox_many}} method.
 
    {{#invoke:Bananas/testcases|run_tests|differs_at=1}}
</pre>


=== preprocess_equals ===
=== preprocess_equals ===
* <code>preprocess_equals(text, expected, options)</code> - Gives a piece of wikitext to preprocess and an expected resulting value. Scripts and templates can be invoked in the same manner they would be in a page.
* {{code|1=preprocess_equals(text, expected, options)}}: Gives a piece of wikitext to preprocess and an expected resulting value. Scripts and templates can be invoked in the same manner they would be in a page. <syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
self:preprocess_equals('{{#invoke:Example | hello}}', 'Hello, world!', {nowiki=1})
    self:preprocess_equals('{{#invoke:Bananas | hello}}', 'Hello, world!',{nowiki=1})
</syntaxhighlight>
</syntaxhighlight>
=== preprocess_equals_many ===
=== preprocess_equals_many ===
* <code>preprocess_equals_many(prefix, suffix, cases, options)</code> - Performs a series of preprocess_equals() calls on a set of given pairs. Automatically adds the given prefix and suffix to each text.
* {{code|1=preprocess_equals_many(prefix, suffix, cases, options)}}: Performs a series of preprocess_equals() calls on a set of given pairs. Automatically adds the given prefix and suffix to each text. <syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
self:preprocess_equals_many('{{#invoke:Example | hello_to |', '}}', {
    self:preprocess_equals_many('{{#invoke:BananasArgs | add |', '}}', {
    {'John', 'Hello, John!'},
        {'2|3', '5'},
    {'Jane', 'Hello, Jane!'},
        {'-2|2', '0'},
}, {nowiki=1})
    },{nowiki=1})
</syntaxhighlight>
</syntaxhighlight>


=== preprocess_equals_preprocess ===
=== preprocess_equals_preprocess ===
* <code>preprocess_equals_preprocess(text, expected, options)</code> - Gives two pieces of wikitext to preprocess and determines if they produce the same value. Useful for comparing scripts to existing templates.
* {{code|1=preprocess_equals_preprocess(text, expected, options)}}: Gives two pieces of wikitext to preprocess and determines if they produce the same value. Useful for comparing scripts to existing templates. <syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
self:preprocess_equals_preprocess('{{#invoke:Example | hello}}', '{{Hello}}', {nowiki=1})
    self:preprocess_equals_preprocess('{{#invoke:Bananas | hello}}', '{{Hello}}',{nowiki=1})
</syntaxhighlight>
</syntaxhighlight>
=== preprocess_equals_preprocess_many ===
=== preprocess_equals_preprocess_many ===
* <code>preprocess_equals_preprocess_many(prefix, suffix, cases, options)</code> - Performs a series of preprocess_equals_preprocess() calls on a set of given pairs. The prefix/suffix supplied for both arguments is added automatically. If in any case the second part is not specified, the first part will be used.
* {{code|1=preprocess_equals_preprocess_many(prefix1, suffix1, prefix2, suffix2, cases, options)}}: Performs a series of preprocess_equals_preprocess() calls on a set of given pairs. The prefix/suffix supplied for both arguments is added automatically. If in any case the second part is not specified, the first part will be used. <syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
self:preprocess_equals_preprocess_many('{{#invoke:ConvertNumeric | numeral_to_english|', '}}', '{{spellnum', '}}', {
    self:preprocess_equals_preprocess_many('{{#invoke:Foo | spellnum |', '}}', '{{spellnum', '}}', {
    {'2'}, -- equivalent to {'2','2'},
        {'2'}, -- equivalent to {'2','2'},
    {'-2', '-2.0'},
        {'-2', '-2.0'},
}, {nowiki=1})
     },{nowiki=1})
</syntaxhighlight>
 
=== preprocess_equals_sandbox_many ===
* {{code|1=preprocess_equals_sandbox_many(module, function, cases, options)}}: Performs a series of preprocess_equals_compare() calls on a set of given pairs. The test compares the live version of the module vs the /sandbox version and vs an expected result. Ensure live_sandbox is specified or there may be some errors in the output. <syntaxhighlight lang="lua">
self:preprocess_equals_sandbox_many('{{#invoke:Example', 'hello_to', {
    {'John', 'Hello, John!'},
     {'Jane', 'Hello, Jane!'},
}, {nowiki=1})
</syntaxhighlight>
</syntaxhighlight>


=== equals ===
=== equals ===
* <code>equals(name, actual, expected, options)</code> - Gives a computed value and the expected value, and checks if they are equal according to the == operator. Useful for testing modules that are designed to be used by other modules rather than using #invoke.
* {{code|1=equals(name, actual, expected, options)}}: Gives a computed value and the expected value, and checks if they are equal according to the == operator. Useful for testing modules that are designed to be used by other modules rather than using #invoke. <syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
self:equals('Simple addition', 2 + 2, 4, {nowiki=1})
    self:equals('Simple addition', 2 + 2, 4,{nowiki=1})
</syntaxhighlight>
</syntaxhighlight>
=== equals_deep ===
=== equals_deep ===
* <code>equals_deep(name, actual, expected, options)</code> - Like equals, but handles tables by doing a deep comparison. Neither value should contain circular references, as they are not handled by the current implementation and may result in an infinite loop.
* {{code|1=equals_deep(name, actual, expected, options)}}: Like equals, but handles tables by doing a deep comparison. Neither value should contain circular references, as they are not handled by the current implementation and may result in an infinite loop. <syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
self:equals_deep('Table comparison', createRange(1,3), {1,2,3}, {nowiki=1})
    self:equals_deep('Table comparison', createRange(1,3), {1,2,3},{nowiki=1})
</syntaxhighlight>
</syntaxhighlight>
== Test options ==
These are the valid options that can be passed into the options parameters of the test functions listed above.
=== nowiki ===
Enabling this wraps the output text in {{tag|nowiki}} tags to avoid the text being rendered (E.g. <nowiki><span>[[Example|Page]]</span></nowiki> instead of <span>[[Example|Page]]</span>)
=== combined ===
{{hatnote|Only available in <code>preprocess_equals</code> and <code>preprocess_equals_preprocess</code>}}
Enabling this will display the output text in both the rendered mode and the nowiki mode to allow for both a raw text and visual comparison.
=== templatestyles ===
{{hatnote|Only available in <code>preprocess_equals</code> and <code>preprocess_equals_preprocess</code>}}
Enabling this fixes the IDs in the [[mw:Strip marker|strip markers]] {{tag|templatestyles}} produces when processed to avoid incorrectly failing the tests.
=== stripmarker ===
{{hatnote|Only available in <code>preprocess_equals</code> and <code>preprocess_equals_preprocess</code>}}
Enabling this fixes the IDs in ''all'' strip markers produces when processed to avoid incorrectly failing the tests.
=== display ===
{{hatnote|Only available in <code>equals</code>}}
An optional function that changes how the output from the tests are displayed. This doesn't effect the comparison process.


== See also ==
== See also ==
* [[Module:ScribuntoUnit]] – alternative unit test module
* [[Module:ScribuntoUnit]] – alternative unit test module


<includeonly>
<includeonly>{{#ifeq:{{SUBPAGENAME}}|sandbox||
[[Category:Modules]]</includeonly>
<!-- Categories go here and interwikis go in Wikidata. -->
<noinclude>
[[Category:Modules for test tools]]
[[Category:Module documentation pages]]</noinclude>
[[Category:Modules that check for strip markers]]
}}</includeonly>

Revision as of 09:56, 16 February 2025

UnitTests provides a unit test facility that can be used by other scripts using require. See Wikipedia:Lua for details. The following is a sample from Module:Example/testcases:

-- Unit tests for [[Module:Example]]. Click talk page to run tests.
local p = require('Module:UnitTests')

function p:test_hello()
    self:preprocess_equals('{{#invoke:Example | hello}}', 'Hello World!')
end

return p

The talk page Module talk:Example/testcases executes it with {{#invoke: Example/testcases | run_tests}}. Test methods like test_hello above must begin with "test".

Methods

run_tests

  • run_tests: Runs all tests. Normally used on talk page of unit tests.
    {{#invoke:Example/testcases|run_tests}}
  • If differs_at is specified, a column will be added showing the first character position where the expected and actual results differ.
    {{#invoke:Example/testcases|run_tests|differs_at=1}}
  • If highlight is specified, failed tests will be highlighted to make them easier to spot. A user script that moves failed tests to the top is also available.
    {{#invoke:Example/testcases|run_tests|highlight=1}}
  • If live_sandbox is specified, the header will show the columns "Test", "Live", "Sandbox", "Expected". This is required when using the preprocess_equals_sandbox_many method.

preprocess_equals

  • preprocess_equals(text, expected, options): Gives a piece of wikitext to preprocess and an expected resulting value. Scripts and templates can be invoked in the same manner they would be in a page.
    self:preprocess_equals('{{#invoke:Example | hello}}', 'Hello, world!', {nowiki=1})

preprocess_equals_many

  • preprocess_equals_many(prefix, suffix, cases, options): Performs a series of preprocess_equals() calls on a set of given pairs. Automatically adds the given prefix and suffix to each text.
    self:preprocess_equals_many('{{#invoke:Example | hello_to |', '}}', {
        {'John', 'Hello, John!'},
        {'Jane', 'Hello, Jane!'},
    }, {nowiki=1})

preprocess_equals_preprocess

  • preprocess_equals_preprocess(text, expected, options): Gives two pieces of wikitext to preprocess and determines if they produce the same value. Useful for comparing scripts to existing templates.
    self:preprocess_equals_preprocess('{{#invoke:Example | hello}}', '{{Hello}}', {nowiki=1})

preprocess_equals_preprocess_many

  • preprocess_equals_preprocess_many(prefix1, suffix1, prefix2, suffix2, cases, options): Performs a series of preprocess_equals_preprocess() calls on a set of given pairs. The prefix/suffix supplied for both arguments is added automatically. If in any case the second part is not specified, the first part will be used.
    self:preprocess_equals_preprocess_many('{{#invoke:ConvertNumeric | numeral_to_english|', '}}', '{{spellnum', '}}', {
        {'2'}, -- equivalent to {'2','2'},
        {'-2', '-2.0'},
    }, {nowiki=1})

preprocess_equals_sandbox_many

  • preprocess_equals_sandbox_many(module, function, cases, options): Performs a series of preprocess_equals_compare() calls on a set of given pairs. The test compares the live version of the module vs the /sandbox version and vs an expected result. Ensure live_sandbox is specified or there may be some errors in the output.
    self:preprocess_equals_sandbox_many('{{#invoke:Example', 'hello_to', {
        {'John', 'Hello, John!'},
        {'Jane', 'Hello, Jane!'},
    }, {nowiki=1})

equals

  • equals(name, actual, expected, options): Gives a computed value and the expected value, and checks if they are equal according to the == operator. Useful for testing modules that are designed to be used by other modules rather than using #invoke.
    self:equals('Simple addition', 2 + 2, 4, {nowiki=1})

equals_deep

  • equals_deep(name, actual, expected, options): Like equals, but handles tables by doing a deep comparison. Neither value should contain circular references, as they are not handled by the current implementation and may result in an infinite loop.
    self:equals_deep('Table comparison', createRange(1,3), {1,2,3}, {nowiki=1})

Test options

These are the valid options that can be passed into the options parameters of the test functions listed above.

nowiki

Enabling this wraps the output text in <nowiki>...</nowiki> tags to avoid the text being rendered (E.g. <span>[[Example|Page]]</span> instead of Page)

combined

Enabling this will display the output text in both the rendered mode and the nowiki mode to allow for both a raw text and visual comparison.

templatestyles

Enabling this fixes the IDs in the strip markers <templatestyles>...</templatestyles> produces when processed to avoid incorrectly failing the tests.

stripmarker

Enabling this fixes the IDs in all strip markers produces when processed to avoid incorrectly failing the tests.

display

An optional function that changes how the output from the tests are displayed. This doesn't effect the comparison process.

See also