expect(frame.state).toBe(frame.POSTWAITING);\r
expect(frame.updateState(4).state).toBe(frame.POSTWAITING);\r
expect(frame.state).toBe(frame.POSTWAITING);\r
+ \r
+ appendEnd(1);\r
+ expect(frame.updateState(1).state).toBe(frame.BEGINNING);\r
+ expect(frame.updateState(1).state).toBe(frame.ENDING);\r
+ expect(frame.updateState(1).state).toBe(frame.POSTWAITING);\r
} );\r
/*無効同値クラスを調べておく (Equivalence partitioning, the following is the invalid partion)*/\r
it("should be this for the value (the invalid partion)", function() {\r
frame.setFrame(i);\r
}\r
\r
- frame.beginList = frame.$list.beginList;\r
- frame.endList = frame.$list.endList;\r
+ frame.beginList = base("$frame").$listbeginList;\r
+ frame.endList = base("$frame").$list.endList;\r
frame.state = frame.WAITING;\r
frame.begin = 0;\r
var obj = { name: "", value: 0};\r
expect(frame.currentFrame).toBe(0);\r
expect(frame.state).toBe(frame.POSTWAITING);\r
expect(obj.value).toBe(1);\r
+ var t = 0;\r
frame.addEvent("begin", function(evt) {\r
expect(evt.state).toBe(frame.BEGINNING);\r
+ t = 1;\r
});\r
frame.addEvent("end", function(evt) {\r
expect(evt.state).toBe(frame.ENDING);\r
+ t = 2;\r
});\r
frame.addEvent("play", function(evt) {\r
expect(evt.state).toBe(frame.PLAYING);\r
+ t = 3;\r
});\r
frame.setFrame(0);\r
+ expect(t).toBe(2);\r
+ \r
+ t=0;\r
+ frame.begin = 0;\r
+ frame.state = frame.WAITING;\r
+ expect(frame.getMaxList(12, frame.endList)).toBe(0);\r
+ frame.setFrame(12);\r
+ expect(frame.state).toBe(frame.POSTWAITING);\r
+ expect(t).toBe(2);\r
\r
/*addBeginListメソッドのチェックなど*/\r
expect(frame.addBeginList(1).value).toBe(1);\r
var $list = begin.$list;\r
expect(begin.$list).toBe($list);\r
expect(begin.updateList().$list).not.toBe($list);\r
- expect(begin.$activate.end.$list).toBe(begin.$list);\r
} );\r
/*無効同値クラスを調べておく (Equivalence partitioning, the following is the invalid partion)*/\r
it("should be this for the value (the invalid partion)", function() {\r
function check(attrName, num) {\r
s.setAttribute(attrName, "1");\r
expect(s.hasAttributeNS(null, attrName)).toBeTruthy();\r
- var l = attr.push(s);\r
+ var fr = attr.push(s);\r
expect(attr.element).toBe(p);\r
var timelines = base("$frame").timelines;\r
expect(timelines.length).toBe(num);\r
var line = timelines[num-1];\r
- expect(line.string).toBe("0");\r
- expect(line).toBe(l); //タイムラインのオブジェクトを返す\r
- var act = line.$activate;\r
+ expect(line).not.toBe(fr);\r
+ var act = fr.$activate;\r
expect(act.dur).toBeNull();\r
- expect(act.end).toBe(0);\r
expect(act.repeatCount).toBeNull();\r
expect(act.repeatDur).toBeNull();\r
expect(act.min).toBe("0");\r
function check2(attrName, value) {\r
s.setAttribute(attrName, value);\r
expect(s.hasAttributeNS(null, attrName)).toBeTruthy();\r
- attr.push(s);\r
+ var fr = attr.push(s);\r
expect(attr.element).toBe(p);\r
var timelines = base("$frame").timelines;\r
var line = timelines[timelines.length-1];\r
- expect(line.string).toBe(values[0]);\r
- var act = line.$activate;\r
+ expect(fr.string).toBe(values[0]);\r
+ var act = fr.$activate;\r
expect(act.dur).toBe(values[1]);\r
- expect(act.end).toBe(values[2]);\r
expect(act.repeatCount).toBe(values[3]);\r
expect(act.repeatDur).toBe(values[4]);\r
expect(act.min).toBe(values[5]);\r
ele = document.createElementNS("http://www.w3.org/2000/svg", "set");\r
p.appendChild(ele);\r
frame = base("$frame");\r
- frame.timelines.length = frame.$endFrame.timelines.length = 0; //配列の初期化\r
+ frame.timelines.length = 0; //配列の初期化\r
frame.startTime = Date.now();\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
} );\r
afterEach( function() {\r
$set.isCSS = false;\r
$set.isCSS = false;\r
expect($set.timeline).not.toBe(frame.$begin);\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
expect(ele.parentNode.getAttributeNS(null, "fill")).toBe("red");\r
\r
+ var line = $set.timeline;\r
+ expect(line.$list.state).toBe(line.$list.PLAYING);\r
+ console.log(frame);\r
frame.setFrame(24);\r
- frame.$endFrame.setFrame(24);\r
+ expect(line.$list.state).toBe(line.$list.POSTWAITING);\r
expect(ele.parentNode.hasAttributeNS(null, "fill")).toBeFalsy();\r
} );\r
/*同値分割をして、有効同値クラスを調べておく (Equivalence partitioning, the following is the valid partion)*/\r
$set.isCSS = false;\r
var f = function(num) {\r
frame.setFrame(num);\r
- frame.$endFrame.setFrame(num);\r
expect(ele.parentNode.getAttributeNS(null, "fill") || null).toBeNull();\r
}\r
f(0);\r
f(1);\r
f(23);\r
frame.setFrame(24);\r
- frame.$endFrame.setFrame(24);\r
expect(ele.parentNode.getAttributeNS(null, "fill")).toBe("red");\r
frame.setFrame(25);\r
- frame.$endFrame.setFrame(25);\r
expect(ele.parentNode.getAttributeNS(null, "fill")).toBe("red");\r
f(48);\r
f(49);\r
f(1);\r
f(23);\r
frame.setFrame(24);\r
- frame.$endFrame.setFrame(24);\r
expect(ele.parentNode.getAttributeNS(null, "fill")).toBe("red");\r
frame.setFrame(25);\r
- frame.$endFrame.setFrame(25);\r
expect(ele.parentNode.getAttributeNS(null, "fill")).toBe("red");\r
frame.setFrame(48);\r
- frame.$endFrame.setFrame(48);\r
expect(ele.parentNode.getAttributeNS(null, "fill") || null).toBe("red");\r
frame.setFrame(49);\r
- frame.$endFrame.setFrame(49);\r
expect(ele.parentNode.getAttributeNS(null, "fill") || null).toBe("red");\r
ele.setAttributeNS(null, "begin", "1s");\r
ele.setAttributeNS(null, "attributeName", "fill");\r
$set.isCSS = false;\r
var f = function(num) {\r
frame.setFrame(num);\r
- frame.$endFrame.setFrame(num);\r
expect(ele.parentNode.getAttributeNS(null, "fill") || null).toBe("red");\r
}\r
f(0);\r
frame.timelines.length = 0;\r
frame.startTime = Date.now();\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
} );\r
/*境界条件を調べておく (limit value analysis)*/\r
it("should be this for the value (limit value analysis)", function() {\r
$animate.init(ele);\r
expect($animate.isCSS).toBeFalsy();\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
var p = ele.parentNode;\r
/*getAttributeNSメソッドは、IE11では空文字列を返す(DOM 2に準拠)のに対して、\r
* 他のブラウザではnullを返すため、その対策をする*/\r
\r
function f(fr, result) {\r
frame.setFrame(fr);\r
- frame.$endFrame.setFrame(fr);\r
expect(p.getAttributeNS(null, "d") || "").toBe(result);\r
};\r
\r
to = attr[2];\r
function g(fr, result) {\r
frame.setFrame(fr);\r
- frame.$endFrame.setFrame(fr);\r
expect(p.style.getPropertyValue(attrName) || p.getAttribute(attrName) || "").toBe(result);\r
};\r
\r
\r
function f(fr, result) {\r
frame.setFrame(fr);\r
- frame.$endFrame.setFrame(fr);\r
expect(p.getAttributeNS(null, "d")).toBe(result);\r
};\r
\r
( function(attrName) {\r
function g(fr, result) {\r
frame.setFrame(fr);\r
- frame.$endFrame.setFrame(fr);\r
expect(p.style.getPropertyValue(attrName)).toBe(result);\r
};\r
\r
\r
function f(fr, result) {\r
frame.setFrame(fr);\r
- frame.$endFrame.setFrame(fr);\r
expect(p.getAttributeNS(null, "d") || null).toBe(result);\r
};\r
f(0, null);\r
\r
f = function (fr, result, attr) {\r
frame.setFrame(fr);\r
- frame.$endFrame.setFrame(fr);\r
expect(p.style.getPropertyValue(attr).replace(/\s/g, "")).toBe(result.replace(/\s/g, ""));\r
};\r
} );\r
\r
function f (fr, result, attr) {\r
frame.setFrame(fr);\r
- frame.$endFrame.setFrame(fr);\r
expect(ele.parentNode.getAttributeNS(null,attr)).toBe(result);\r
};\r
f(0, "#83.0C", "fi");\r
expect(isFiredBeginEvent).toBeTruthy();\r
} );\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
expect(frame.first).toBeNull();\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
expect(frame.first).toBeNull();\r
\r
frame.timelines = [];\r
};\r
expect(frame.first).toEqual(a);\r
frame.setFrame(11);\r
- frame.$endFrame.setFrame(11);\r
expect(frame.first).toEqual( {frame: 12,\r
eventType: "end",\r
target: ele,\r
};\r
expect(frame.first).toEqual(a);\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
expect(frame.first).toEqual(a);\r
frame.setFrame(1);\r
- frame.$endFrame.setFrame(1);\r
a = a.next;\r
expect(frame.first).toEqual(a);\r
frame.setFrame(5);\r
- frame.$endFrame.setFrame(5);\r
expect(frame.first).toEqual(a.next);\r
\r
ele.addEventListener("repeatEvent", function(evt) {\r
target: ele\r
}) );\r
frame.setFrame(9);\r
- frame.$endFrame.setFrame(9);\r
expect(frame.first).toEqual({\r
frame: 13,\r
eventType: "repeat",\r
frame.timelines.length = 0;\r
frame.startTime = Date.now();\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
} );\r
afterEach( function() {\r
$animate.numberOfList = -1;\r
frame.timelines.length = 0;\r
frame.startTime = Date.now();\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
} );\r
afterEach( function() {\r
$animate.numberOfList = -1;\r
frame.timelines.length = 0;\r
frame.startTime = Date.now();\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
} );\r
afterEach( function() {\r
$animate.numberOfList = -1;\r
frame.pauseAnimation();\r
frame.timelines.length = 0; //配列の初期化\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
} );\r
/*境界条件を調べておく (limit value analysis)*/\r
it("should be this for the value (limit value analysis)", function() {\r
evt = ele.ownerDocument.createEvent("MouseEvents");\r
evt.initMouseEvent("mousedown",true, true, window, 0, 0, 0, 0, 0, false, false, false, false,0, p);\r
frame.setFrame(frame.currentFrame);\r
- frame.$endFrame.setFrame(frame.currentFrame);\r
expect($animate.isEnd).toBeFalsy();\r
p.dispatchEvent(evt);\r
frame.setFrame(frame.currentFrame + 1);\r
- frame.$endFrame.setFrame(frame.currentFrame + 1);\r
frame.setFrame(frame.currentFrame + 24);\r
- frame.$endFrame.setFrame(frame.currentFrame + 24);\r
expect(evt.target.getAttributeNS(null, "fill") || null).toBe("rgb(10, 10, 1)");\r
} );\r
} );\r
frame = base("$frame");\r
frame.timelines.length = 0; //配列の初期化\r
frame.setFrame(0);\r
- frame.$endFrame.setFrame(0);\r
ele.setAttributeNS(null, "begin", "indefinite");\r
ele.setAttributeNS(null, "dur", "1s");\r
ele.setAttributeNS(null, "dur", "1s");\r