mithril
Version:
A framework for building brilliant applications
97 lines (82 loc) • 3.58 kB
JavaScript
var o = require("ospec")
var domMock = require("../../test-utils/domMock")
var vdom = require("../../render/render")
var m = require("../../render/hyperscript")
var trust = require("../../render/trust")
o.spec("createHTML", function() {
var $window, root, render
o.beforeEach(function() {
$window = domMock()
root = $window.document.createElement("div")
render = vdom($window)
})
o("creates HTML", function() {
var vnode = trust("<a></a>")
render(root, vnode)
o(vnode.dom.nodeName).equals("A")
})
o("creates text HTML", function() {
var vnode = trust("a")
render(root, vnode)
o(vnode.dom.nodeValue).equals("a")
})
o("handles empty HTML", function() {
var vnode = trust("")
render(root, vnode)
o(vnode.dom).equals(null)
o(vnode.domSize).equals(0)
})
o("handles multiple children in HTML", function() {
var vnode = trust("<a></a><b></b>")
render(root, vnode)
o(vnode.domSize).equals(2)
o(vnode.dom.nodeName).equals("A")
o(vnode.dom.nextSibling.nodeName).equals("B")
})
o("handles valid html tags", function() {
//FIXME body,head,html,frame,frameset are not supported
//FIXME keygen is broken in Firefox
var tags = ["a", "abbr", "acronym", "address", "applet", "area", "article", "aside", "audio", "b", "base", "basefont", "bdi", "bdo", "big", "blockquote", /*"body",*/ "br", "button", "canvas", "caption", "center", "cite", "code", "col", "colgroup", "datalist", "dd", "del", "details", "dfn", "dialog", "dir", "div", "dl", "dt", "em", "embed", "fieldset", "figcaption", "figure", "font", "footer", "form", /*"frame", "frameset",*/ "h1", "h2", "h3", "h4", "h5", "h6", /*"head",*/ "header", "hr", /*"html",*/ "i", "iframe", "img", "input", "ins", "kbd", /*"keygen", */"label", "legend", "li", "link", "main", "map", "mark", "menu", "menuitem", "meta", "meter", "nav", "noframes", "noscript", "object", "ol", "optgroup", "option", "output", "p", "param", "pre", "progress", "q", "rp", "rt", "ruby", "s", "samp", "script", "section", "select", "small", "source", "span", "strike", "strong", "style", "sub", "summary", "sup", "table", "tbody", "td", "textarea", "tfoot", "th", "thead", "time", "title", "tr", "track", "tt", "u", "ul", "var", "video", "wbr"]
tags.forEach(function(tag) {
var vnode = trust("<" + tag + " />")
render(root, vnode)
o(vnode.dom.nodeName).equals(tag.toUpperCase())
})
})
o("creates SVG", function() {
var vnode = trust("<g></g>")
render(root, m("svg", vnode))
o(vnode.dom.nodeName).equals("g")
o(vnode.dom.namespaceURI).equals("http://www.w3.org/2000/svg")
})
o("creates text SVG", function() {
var vnode = trust("a")
render(root, m("svg", vnode))
o(vnode.dom.nodeValue).equals("a")
})
o("handles empty SVG", function() {
var vnode = trust("")
render(root, m("svg", vnode))
o(vnode.dom).equals(null)
o(vnode.domSize).equals(0)
})
o("handles multiple children in SVG", function() {
var vnode = trust("<g></g><text></text>")
render(root, m("svg", vnode))
o(vnode.domSize).equals(2)
o(vnode.dom.nodeName).equals("g")
o(vnode.dom.namespaceURI).equals("http://www.w3.org/2000/svg")
o(vnode.dom.nextSibling.nodeName).equals("text")
o(vnode.dom.nextSibling.namespaceURI).equals("http://www.w3.org/2000/svg")
})
o("creates the dom correctly with a contenteditable parent", function() {
var div = m("div", {contenteditable: true}, trust("<a></a>"))
render(root, div)
var tags = []
for (var i = 0; i < div.dom.childNodes.length; i++) {
tags.push(div.dom.childNodes[i].nodeName)
}
o(tags).deepEquals(["A"])
})
})