CodeTools
Test
facilitate the creation of Maple code test suites
Calling Sequence
Parameters
Options
Description
Examples
Compatibility
Test( input, expected)
Test( input, expected, verification)
input
-
expression to be evaluated for correctness
expected
expected result of evaluation of input
verification
expression of type verification, or one of the names testerror or testnoerror, or a procedure which returns type/verify similar to the verify command.
label = string or posint
A label for the test used in the pass/fail message printed. It is "Test i" by default, where i is replaced by a number that counts how many times Test has been called in this session. These labels are important because they are used by the TestFailures command to indicate which test cases have failed.
quiet = truefalse
If true, no pass/fail messages will be printed.
boolout = truefalse
If true, true will be returned if the test passed, and false otherwise. If false, the default, NULL will be returned if the test passed, and an exception will be thrown if it fails.
The CodeTools[Test] command is a front-end utility used for the creation and verification of a suite of Maple test projects. By default it returns a NULL result if the test succeeds and an error if the test fails.
If only input and expected are given, the input is evaluated using verify and compared against the expected result.
If input is a string, it will be parsed using parse.
If the expected output is an expression sequence, then input and expected should each be enclosed in a list.
If the third argument type is a verification expression then it is passed as a third verify argument for testing.
The CodeTools[Test] command knows about two special verifications:
testnoerror ignores the expected parameter and causes the test to fail when there is an exception during the evaluation of input.
testerror is nearly the opposite of testnoerror and causes the test to pass only if there is an exception during the evaluation, and expected is a string that matches the error message prefix.
If the third argument is not a verification type or not one of above mentioned special verifiers, then it must be a procedure with a type/verify return.
If more than three parameters are passed to "Test" , the others are passed as addition arguments to the specified verifier.
withCodeTools
CPUTime,DecodeName,EncodeName,GCTime,Log,Profiling,ProgramAnalysis,RealTime,RecursiveMembers,Test,TestFailures,ThreadSafetyCheck,Usage
Tests that pass.
Testintx,x2,integration range or variable must,testerror,label=Test Pass 1
Test Pass 1 passed
Testintx,x2,,testerror,label=Test Pass 2
Test Pass 2 passed
Testintx2,x,,testnoerror,label=Test Pass 3
Test Pass 3 passed
Testintx,x,x22,label=Test Pass 4
Test Pass 4 passed
Testintx,x,xsqrt22,simplify,label=Test Pass 5,boolout
Test Pass 5 passed
true
A≔Matrix1,2,3,4
A≔1234
TestA,A,label=Test Pass 6,boolout,quiet
A≔1|2,3|4
B≔1|2.001,2.999|4
B≔12.0012.9994
CodeTools:-TestA,B,float1,digits=4,label=Test Pass 7,boolout,quiet
Tests that fail.
Testintx2,x,integration range or variable must,testerror,label=Test Fail 1
Test Fail 1 failed Expected error but did not receive one
Error, (in CodeTools:-Test) TEST FAILED: Test Fail 1
Testintx,x2,,testnoerror,label=Test Fail 2
Test Fail 2 failed Expected no errors, but got: Error, integration range or variable must be specified in the second argument, got x^2
Error, (in CodeTools:-Test) TEST FAILED: Test Fail 2
Testintx,x,x24,simplify,label=Test Fail 3
Test Fail 3 failed Expected result : 1/4*x^2 Evaluated result: 1/2*x^2
Error, (in CodeTools:-Test) TEST FAILED: Test Fail 3
Testintx,x,xsqrt22,label=Test Fail 4,boolout
Test Fail 4 failed Expected result : x^2/sqrt(2)^2 Evaluated result: 1/2*x^2
false
The boolout and quiet options work well together.
Testintx,x2,,testerror,boolout,quiet
Testintx2,x,,testerror,boolout,quiet
The CodeTools[Test] command was introduced in Maple 15.
For more information on Maple 15 changes, see Updates in Maple 15.
See Also
type/verification
type/verify
verify
Download Help Document