mithril-vndb/render/tests/test-updateFragment.js
2022-02-12 12:19:35 +01:00

71 lines
1.7 KiB
JavaScript

"use strict"
var o = require("ospec")
var domMock = require("../../test-utils/domMock")
var vdom = require("../../render/render")
var m = require("../../render/hyperscript")
var fragment = require("../../render/fragment")
o.spec("updateFragment", function() {
var $window, root, render
o.beforeEach(function() {
$window = domMock()
root = $window.document.createElement("div")
render = vdom($window)
})
o("updates fragment", function() {
var vnode = fragment(m("a"))
var updated = fragment(m("b"))
render(root, vnode)
render(root, updated)
o(updated.dom).equals(root.firstChild)
o(updated.dom.nodeName).equals("B")
})
o("adds els", function() {
var vnode = fragment()
var updated = fragment(m("a"), m("b"))
render(root, vnode)
render(root, updated)
o(updated.dom).equals(root.firstChild)
o(updated.domSize).equals(2)
o(root.childNodes.length).equals(2)
o(root.childNodes[0].nodeName).equals("A")
o(root.childNodes[1].nodeName).equals("B")
})
o("removes els", function() {
var vnode = fragment(m("a"), m("b"))
var updated = fragment()
render(root, vnode)
render(root, updated)
o(updated.dom).equals(null)
o(updated.domSize).equals(0)
o(root.childNodes.length).equals(0)
})
o("updates from childless fragment", function() {
var vnode = fragment()
var updated = fragment(m("a"))
render(root, vnode)
render(root, updated)
o(updated.dom).equals(root.firstChild)
o(updated.dom.nodeName).equals("A")
})
o("updates to childless fragment", function() {
var vnode = fragment(m("a"))
var updated = fragment()
render(root, vnode)
render(root, updated)
o(updated.dom).equals(null)
o(root.childNodes.length).equals(0)
})
})