define([ '/bower_components/jquery/dist/jquery.min.js', '/assert/hyperjson.js', // serializing classes as an attribute '/assert/hyperscript.js', // using setAttribute '/common/TextPatcher.js' ], function (jQuery, Hyperjson, Hyperscript, TextPatcher) { var $ = window.jQuery; window.Hyperjson = Hyperjson; window.Hyperscript = Hyperscript; window.TextPatcher = TextPatcher; var assertions = 0; var failed = false; var failedOn; var failMessage; var assert = function (test, msg) { if (test()) { assertions++; } else { failed = true; failedOn = assertions; failMessage = msg; throw new Error(msg || ''); } }; var $body = $('body'); var roundTrip = function (target) { assert(function () { var hjson = Hyperjson.fromDOM(target); var cloned = Hyperjson.callOn(hjson, Hyperscript); var success = cloned.outerHTML === target.outerHTML; if (!success) { window.DEBUG = { error: "Expected equality between A and B", A: target.outerHTML, B: cloned.outerHTML, target: target, diff: TextPatcher.diff(target.outerHTML, cloned.outerHTML) }; console.log(JSON.stringify(window.DEBUG, null, 2)); } return success; }, "Round trip serialization introduced artifacts."); }; [ '#target', '#widget', ].forEach(function (sel) { roundTrip($(sel)[0]); }); var strungJSON = function (orig) { var result; assert(function () { result = JSON.stringify(JSON.parse(orig)); return result === orig; }, "expected result (" + result + ") to equal original (" + orig + ")"); }; [ '{"border":"1","style":{"width":"500px"}}', '{"style":{"width":"500px"},"border":"1"}', ].forEach(function (orig) { strungJSON(orig); }); /* TODO Test how browsers handle weird elements like "_moz-resizing":"true" and anything else you can think of. Start with Hyperjson, turn it into a DOM and come back */ // report successes var swap = function (str, dict) { return str.replace(/\{\{(.*?)\}\}/g, function (all, key) { return dict[key] || all; }); }; var multiline = function (f) { var str; f.toString().replace(/\/\*(.*)\*\\/g, function (all, out) { str = out; }); return str; }; $("body").html(function (i, val) { var dict = { previous: val, passedAssertions: assertions, plural: (assertions === 1? '' : 's'), }; var SUCCESS = swap(multiline(function(){/*