mirror of
https://github.com/IT4Change/gradido.git
synced 2025-12-13 07:45:54 +00:00
290 lines
7.9 KiB
JavaScript
290 lines
7.9 KiB
JavaScript
"use strict"
|
|
|
|
var o = require("../../ospec/ospec")
|
|
var domMock = require("../../test-utils/domMock")
|
|
var vdom = require("../../render/render")
|
|
|
|
o.spec("onbeforeupdate", function() {
|
|
var $window, root, render
|
|
o.beforeEach(function() {
|
|
$window = domMock()
|
|
root = $window.document.createElement("div")
|
|
render = vdom($window).render
|
|
})
|
|
|
|
o("prevents update in element", function() {
|
|
var onbeforeupdate = function() {return false}
|
|
var vnode = {tag: "div", attrs: {id: "a", onbeforeupdate: onbeforeupdate}}
|
|
var updated = {tag: "div", attrs: {id: "b", onbeforeupdate: onbeforeupdate}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("a")
|
|
})
|
|
|
|
o("prevents update in text", function() {
|
|
var onbeforeupdate = function() {return false}
|
|
var vnode = {tag: "#", attrs: {onbeforeupdate: onbeforeupdate}, children: "a"}
|
|
var updated = {tag: "#", attrs: {onbeforeupdate: onbeforeupdate}, children: "b"}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.nodeValue).equals("a")
|
|
})
|
|
|
|
o("prevents update in html", function() {
|
|
var onbeforeupdate = function() {return false}
|
|
var vnode = {tag: "<", attrs: {onbeforeupdate: onbeforeupdate}, children: "a"}
|
|
var updated = {tag: "<", attrs: {onbeforeupdate: onbeforeupdate}, children: "b"}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.nodeValue).equals("a")
|
|
})
|
|
|
|
o("prevents update in fragment", function() {
|
|
var onbeforeupdate = function() {return false}
|
|
var vnode = {tag: "[", attrs: {onbeforeupdate: onbeforeupdate}, children: [{tag: "#", children: "a"}]}
|
|
var updated = {tag: "[", attrs: {onbeforeupdate: onbeforeupdate}, children: [{tag: "#", children: "b"}]}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.nodeValue).equals("a")
|
|
})
|
|
|
|
o("prevents update in component", function() {
|
|
var component = {
|
|
onbeforeupdate: function() {return false},
|
|
view: function(vnode) {
|
|
return {tag: "div", children: vnode.children}
|
|
},
|
|
}
|
|
var vnode = {tag: component, children: [{tag: "#", children: "a"}]}
|
|
var updated = {tag: component, children: [{tag: "#", children: "b"}]}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.firstChild.nodeValue).equals("a")
|
|
})
|
|
|
|
o("prevents update if returning false in component and false in vnode", function() {
|
|
var component = {
|
|
onbeforeupdate: function() {return false},
|
|
view: function(vnode) {
|
|
return {tag: "div", attrs: {id: vnode.attrs.id}}
|
|
},
|
|
}
|
|
var vnode = {tag: component, attrs: {id: "a", onbeforeupdate: function() {return false}}}
|
|
var updated = {tag: component, attrs: {id: "b", onbeforeupdate: function() {return false}}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("a")
|
|
})
|
|
|
|
o("does not prevent update if returning true in component and true in vnode", function() {
|
|
var component = {
|
|
onbeforeupdate: function() {return true},
|
|
view: function(vnode) {
|
|
return {tag: "div", attrs: {id: vnode.attrs.id}}
|
|
},
|
|
}
|
|
var vnode = {tag: component, attrs: {id: "a", onbeforeupdate: function() {return true}}}
|
|
var updated = {tag: component, attrs: {id: "b", onbeforeupdate: function() {return true}}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("b")
|
|
})
|
|
|
|
o("does not prevent update if returning false in component but true in vnode", function() {
|
|
var component = {
|
|
onbeforeupdate: function() {return false},
|
|
view: function(vnode) {
|
|
return {tag: "div", attrs: {id: vnode.attrs.id}}
|
|
},
|
|
}
|
|
var vnode = {tag: component, attrs: {id: "a", onbeforeupdate: function() {return true}}}
|
|
var updated = {tag: component, attrs: {id: "b", onbeforeupdate: function() {return true}}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("b")
|
|
})
|
|
|
|
o("does not prevent update if returning true in component but false in vnode", function() {
|
|
var component = {
|
|
onbeforeupdate: function() {return true},
|
|
view: function(vnode) {
|
|
return {tag: "div", attrs: {id: vnode.attrs.id}}
|
|
},
|
|
}
|
|
var vnode = {tag: component, attrs: {id: "a", onbeforeupdate: function() {return false}}}
|
|
var updated = {tag: component, attrs: {id: "b", onbeforeupdate: function() {return false}}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("b")
|
|
})
|
|
|
|
o("does not prevent update if returning true", function() {
|
|
var onbeforeupdate = function() {return true}
|
|
var vnode = {tag: "div", attrs: {id: "a", onbeforeupdate: onbeforeupdate}}
|
|
var updated = {tag: "div", attrs: {id: "b", onbeforeupdate: onbeforeupdate}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("b")
|
|
})
|
|
|
|
o("does not prevent update if returning true from component", function() {
|
|
var component = {
|
|
onbeforeupdate: function() {return true},
|
|
view: function(vnode) {
|
|
return {tag: "div", attrs: vnode.attrs}
|
|
},
|
|
}
|
|
var vnode = {tag: component, attrs: {id: "a"}}
|
|
var updated = {tag: component, attrs: {id: "b"}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("b")
|
|
})
|
|
|
|
o("accepts arguments for comparison", function() {
|
|
var count = 0
|
|
var vnode = {tag: "div", attrs: {id: "a", onbeforeupdate: onbeforeupdate}}
|
|
var updated = {tag: "div", attrs: {id: "b", onbeforeupdate: onbeforeupdate}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
function onbeforeupdate(vnode, old) {
|
|
count++
|
|
|
|
o(old.attrs.id).equals("a")
|
|
o(vnode.attrs.id).equals("b")
|
|
|
|
return old.attrs.id !== vnode.attrs.id
|
|
}
|
|
|
|
o(count).equals(1)
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("b")
|
|
})
|
|
|
|
o("accepts arguments for comparison in component", function() {
|
|
var component = {
|
|
onbeforeupdate: onbeforeupdate,
|
|
view: function(vnode) {
|
|
return {tag: "div", attrs: vnode.attrs}
|
|
},
|
|
}
|
|
var count = 0
|
|
var vnode = {tag: component, attrs: {id: "a"}}
|
|
var updated = {tag: component, attrs: {id: "b"}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
function onbeforeupdate(vnode, old) {
|
|
count++
|
|
|
|
o(old.attrs.id).equals("a")
|
|
o(vnode.attrs.id).equals("b")
|
|
|
|
return old.attrs.id !== vnode.attrs.id
|
|
}
|
|
|
|
o(count).equals(1)
|
|
o(root.firstChild.attributes["id"].nodeValue).equals("b")
|
|
})
|
|
|
|
o("is not called on creation", function() {
|
|
var count = 0
|
|
var vnode = {tag: "div", attrs: {id: "a", onbeforeupdate: onbeforeupdate}}
|
|
var updated = {tag: "div", attrs: {id: "b", onbeforeupdate: onbeforeupdate}}
|
|
|
|
render(root, [vnode])
|
|
|
|
function onbeforeupdate(vnode, old) {
|
|
count++
|
|
return true
|
|
}
|
|
|
|
o(count).equals(0)
|
|
})
|
|
|
|
o("is not called on component creation", function() {
|
|
var component = {
|
|
onbeforeupdate: onbeforeupdate,
|
|
view: function(vnode) {
|
|
return {tag: "div", attrs: vnode.attrs}
|
|
},
|
|
}
|
|
|
|
var count = 0
|
|
var vnode = {tag: "div", attrs: {id: "a"}}
|
|
var updated = {tag: "div", attrs: {id: "b"}}
|
|
|
|
render(root, [vnode])
|
|
|
|
function onbeforeupdate(vnode, old) {
|
|
count++
|
|
return true
|
|
}
|
|
|
|
o(count).equals(0)
|
|
})
|
|
|
|
o("is called only once on update", function() {
|
|
var count = 0
|
|
var vnode = {tag: "div", attrs: {id: "a", onbeforeupdate: onbeforeupdate}}
|
|
var updated = {tag: "div", attrs: {id: "b", onbeforeupdate: onbeforeupdate}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
function onbeforeupdate(vnode, old) {
|
|
count++
|
|
return true
|
|
}
|
|
|
|
o(count).equals(1)
|
|
})
|
|
|
|
o("is called only once on component update", function() {
|
|
var component = {
|
|
onbeforeupdate: onbeforeupdate,
|
|
view: function(vnode) {
|
|
return {tag: "div", attrs: vnode.attrs}
|
|
},
|
|
}
|
|
|
|
var count = 0
|
|
var vnode = {tag: component, attrs: {id: "a"}}
|
|
var updated = {tag: component, attrs: {id: "b"}}
|
|
|
|
render(root, [vnode])
|
|
render(root, [updated])
|
|
|
|
function onbeforeupdate(vnode, old) {
|
|
count++
|
|
return true
|
|
}
|
|
|
|
o(count).equals(1)
|
|
})
|
|
})
|