Files
kiss-vscode/src/test/cases/BasicTestCase.hx

161 lines
4.3 KiB
Haxe

package test.cases;
import utest.Test;
import utest.Assert;
import kiss.Prelude;
@:build(kiss.Kiss.build("src/test/cases/BasicTestCase.kiss"))
class BasicTestCase extends Test {
function testStaticVar() {
Assert.equals("Howdy", BasicTestCase.message);
}
function testHaxeInsertion() {
Assert.equals(23, BasicTestCase.mathResult);
}
function testStaticFunction() {
Assert.equals(6, BasicTestCase.myFloor(6.5));
}
function testFuncall() {
Assert.equals(7, BasicTestCase.funResult);
}
function testField() {
Assert.equals(5, new BasicTestCase().myField);
}
function testMethod() {
Assert.equals(5, new BasicTestCase().myMethod());
}
function testArray() {
var arr = BasicTestCase.myArray;
Assert.equals(3, arr.length);
Assert.equals(1, arr[0]);
Assert.equals(2, arr[1]);
Assert.equals(3, arr[2]);
// Kiss arrays can be negatively indexed like Python
Assert.equals(3, arr[-1]);
Assert.equals(2, arr[-2]);
Assert.equals(1, arr[-3]);
}
function testArrayAccess() {
Assert.equals(3, BasicTestCase.myArrayLast);
}
function testVariadicAdd() {
Assert.equals(6, BasicTestCase.mySum);
}
function testVariadicSubtract() {
Assert.equals(-2, BasicTestCase.myDifference);
}
function testVariadicMultiply() {
Assert.equals(60, BasicTestCase.myProduct);
}
function testVariadicDivide() {
Assert.equals(0.5, BasicTestCase.myQuotient);
}
function testMod() {
Assert.equals(4, BasicTestCase.myRemainder);
}
function testPow() {
Assert.equals(256, BasicTestCase.myPower);
}
function testUnop() {
Assert.equals(7, BasicTestCase.myInc);
}
function testMin() {
Assert.equals(1, BasicTestCase.myMin);
}
function testMax() {
Assert.equals(9, BasicTestCase.myMax);
}
function testLessThan() {
Assert.equals(true, BasicTestCase.myComp1);
Assert.equals(false, BasicTestCase.myComp2);
}
function testLesserEqual() {
Assert.equals(true, BasicTestCase.myComp3);
Assert.equals(true, BasicTestCase.myComp4);
}
function testGreaterThan() {
Assert.equals(true, BasicTestCase.myComp5);
Assert.equals(false, BasicTestCase.myComp6);
}
function testGreaterEqual() {
Assert.equals(true, BasicTestCase.myComp7);
Assert.equals(true, BasicTestCase.myComp8);
}
function testEqual() {
Assert.equals(true, BasicTestCase.myComp9);
Assert.equals(false, BasicTestCase.myComp10);
}
function testIf() {
Assert.equals(true, BasicTestCase.myIf1);
Assert.equals(false, BasicTestCase.myIf2);
Assert.equals(false, BasicTestCase.myIf3);
Assert.equals(false, BasicTestCase.myIf4);
Assert.equals(true, BasicTestCase.myIf5);
Assert.equals(false, BasicTestCase.myIf6);
Assert.equals(true, BasicTestCase.myIf7);
Assert.equals(false, BasicTestCase.myIf8);
Assert.equals(false, BasicTestCase.myIf9);
Assert.equals(true, BasicTestCase.myIf10);
}
function testMacros() {
Assert.equals(7, BasicTestCase.incrementTwice(5));
var seasonsGreetings = "ho ";
Assert.equals("ho ho ho ", BasicTestCase.doTwiceString(() -> {
seasonsGreetings += "ho ";
}));
}
// TODO to really test typed variable definitions, check for compilation failure on a bad example
function testTypedDefvar() {
Assert.equals(8, BasicTestCase.myInt);
}
function testTryCatch() {
Assert.equals(5, BasicTestCase.myTryCatch("string error"));
Assert.equals(6, BasicTestCase.myTryCatch(404));
Assert.equals(7, BasicTestCase.myTryCatch(["list error"]));
}
function testTypeCheck() {
Assert.equals(5, BasicTestCase.myTypeCheck());
}
function testGroups() {
Assert.equals([[1, 2], [3, 4]].toString(), BasicTestCase.myGroups1().toString());
Assert.equals([[1, 2, 3], [4]].toString(), BasicTestCase.myGroups2().toString());
}
function testLet() {
_testLet();
}
function testConstructors() {
Assert.equals("sup", BasicTestCase.myConstructedString);
}
}