initial commit

This commit is contained in:
Dmitri Granetchi
2014-04-20 18:48:35 +03:00
commit f48651338b
14 changed files with 901 additions and 0 deletions
+138
View File
@@ -0,0 +1,138 @@
package ;
import haxe.unit.TestCase;
class BaseTest extends TestCase {
public function new() {
super();
}
function test1() {
var b = new Bindable1();
b.str = "a";
var callNum = 0;
b.strChanged.add(function (from, to) {
assertEquals(from, "a");
assertEquals(to, "b");
callNum ++;
});
bindx.Bind.bindx(b.str, function (from, to) {
assertEquals(from, "a");
assertEquals(to, "b");
callNum ++;
});
b.str = "b";
assertEquals(callNum, 2);
}
function test2() {
var b = new Bindable1();
b.str = null;
var callNum = 0;
var listener = function (from, to) {
assertEquals(from, null);
assertEquals(to, "");
callNum ++;
}
b.strChanged.add(listener);
bindx.Bind.bindx(b.str, listener);
b.str = "";
assertEquals(callNum, 1);
b.strChanged.add(listener);
bindx.Bind.unbindx(b.str, listener);
b.str = "1";
assertEquals(callNum, 1);
}
function test3() {
var b = new Bindable1();
b.str = null;
var callNum = 0;
bindx.Bind.bindx(b.str, function (_, _) callNum++);
bindx.Bind.bindx(b.str, function (_, _) callNum++);
b.str = "";
assertEquals(callNum, 2);
b.strChanged.removeAll();
b.str = "1";
assertEquals(callNum, 2);
b.strChanged.dispose();
var addError = false;
try {
b.strChanged.add(function (_, _) {});
} catch (e:Dynamic) {
addError = true;
}
assertTrue(addError);
}
function test4() {
var b = new Bindable1();
b.str = null;
var callNum = 0;
var listener = function (from, to) {
assertEquals(from, "1");
assertEquals(to, "2");
callNum ++;
}
b.strChanged.add(listener);
b.strChanged.dispatch("1", "2");
assertEquals(callNum, 1);
bindx.Bind.notify(b.str, "1", "2");
assertEquals(callNum, 2);
}
function test5() {
var b = new Bindable1();
b.str = null;
var callNum = 0;
b.bindChanged.add(function () callNum++);
b.i = 10;
assertEquals(callNum, 1);
assertFalse(Reflect.hasField(b, "noBindChanged"));
bindx.Bind.notify(b.bind);
assertEquals(callNum, 2);
}
}
@:bindable
class Bindable1 implements bindx.IBindable {
public var str:String;
@:bindable
public var i(default, set):Int;
@:bindable
private var privateVar:Bool;
public function new() {
if (this.privateVarChanged == null)
throw "no private binding";
}
function set_i(v) {
i = v;
bindx.Bind.notify(this.bind);
return v;
}
public function noBind() {
}
@:bindable
public function bind() {
}
}
+47
View File
@@ -0,0 +1,47 @@
package ;
import bindx.IBindable;
class InheritanceTest extends haxe.unit.TestCase {
public function new() {
super();
}
function testChild() {
var c = new BindableChild();
c.i = 0;
c.s = "0";
var iChanged = 0;
c.iChanged.add(function (from, to) {
assertEquals(from, 0);
assertEquals(to, 1);
iChanged ++;
});
c.i = 1;
assertEquals(iChanged, 1);
var sChanged = 0;
c.sChanged.add(function (from, to) {
assertEquals(from, "0");
assertEquals(to, "1");
sChanged ++;
});
c.s = "1";
assertEquals(sChanged, 1);
}
}
@:bindable
class BindableParent implements IBindable {
public function new() {}
public var i:Int;
}
@:bindable
class BindableChild extends BindableParent {
public var s:String;
}
+48
View File
@@ -0,0 +1,48 @@
package ;
class TestProperty extends haxe.unit.TestCase {
public function new() {
super();
}
function test1() {
var p = new BindableProperty();
p.s = "1";
var callNum = 0;
p.sChanged.add(function (from, to) {
assertEquals(from, "1");
assertEquals(to, "");
callNum ++;
});
p.s = null;
p.sChanged.removeAll();
p.sChanged.add(function (from, to) {
assertEquals(from, "");
assertEquals(to, "1");
callNum ++;
});
p.s = "1";
assertEquals(callNum, 2);
}
}
class BindableProperty implements bindx.IBindable {
public function new() {
}
@:bindable
public var s(default, set):String;
function set_s(v) {
if (v == null) {
return s = "";
}
s = v;
return v;
}
}
+14
View File
@@ -0,0 +1,14 @@
package ;
import haxe.unit.TestRunner;
class Tests {
static function main() {
var runner = new TestRunner();
runner.add(new BaseTest());
runner.add(new InheritanceTest());
runner.add(new TestProperty());
runner.run();
}
}