widget.html revision 1809f37c5e32d3366ee0a26377448d74d5fa7ff5
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai #console .yui3-console-entry {
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai padding:2px;
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai min-height:0;
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai #console .yui3-console-entry-fail .yui3-console-entry-cat {
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai background-color:red;
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai #console .yui3-console-entry-pass .yui3-console-entry-cat {
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai background-color:green;
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai #console .yui3-console-entry-perf .yui3-console-entry-cat {
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai background-color:blue;
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai position:static;
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai html, body {
d3c5729464159cab52ada7ff4b6c26b91bd4dcb4Satyen Desai height:100%;
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai<p><input type="button" value="Run Tests" id="btnRun" disabled=true></p>
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai<div id="widgetRenderToContainer" style="height:300px;width:300px"></div>
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai useBrowserConsole:false,
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai filter: (window.location.search.match(/[?&]filter=([^&]+)/) || [])[1] || 'min'
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai }).use('test', 'widget', 'node-event-simulate', 'console', function (Y) {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var suite = new Y.Test.Suite("Widget Tests");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai name : "Core",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testInstantiation" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // Basic API
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testInitState" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("div", w.get("boundingBox").get("tagName").toLowerCase());
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("div", w.get("contentBox").get("tagName").toLowerCase());
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("disabled"), "disabled should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("focused"), "focused should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame("", w.get("height"), "height should be empty string");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame("", w.get("width"), "width should be empty string");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isString(w.get("id"), "id should be a string");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("initialized"), "initialized should be true");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("destroyed"), "destroyed should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("rendered"), "rendered should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("visible"), "visible should be true");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(w.get("tabIndex"), "tabIndex should be null");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testNonRenderedStateUpdate" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // WRITE ONCE
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai id: "foobar",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai boundingBox: Y.Node.create("<span id='bb'></span>"),
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai srcNode: Y.Node.create("<span id='cb'></span>")
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("disabled", true);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("height", 100);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("width", 200);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("visible", false);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("tabIndex", 5);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("span", w.get("boundingBox").get("tagName").toLowerCase());
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("span", w.get("contentBox").get("tagName").toLowerCase());
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("bb", w.get("boundingBox").get("id"));
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("cb", w.get("contentBox").get("id"));
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("disabled"), "disabled should be true");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("focused"), "focused should be false"); // focused is READONLY
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("100", w.get("height"), "height should be 100px");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("200", w.get("width"), "width should be 200px");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("foobar", w.get("id"), "id should be foobar");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("visible"), "visible should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(5, w.get("tabIndex"), "tabIndex should be 5");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testValidationReadonlyWriteonce" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("focused", true);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("rendered", true);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // WRITE ONCE
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("boundingBox", Y.Node.create("<span id='bb'></span>"));
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("contentBox", Y.Node.create("<span id='cb'></span>"));
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("render", true);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("tabIndex", "foo");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // State should be the same as the initial state
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("div", w.get("boundingBox").get("tagName").toLowerCase());
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("div", w.get("contentBox").get("tagName").toLowerCase());
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("disabled"), "disabled should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("focused"), "focused should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame("", w.get("height"), "height should be empty string");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame("", w.get("width"), "width should be empty string");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isString(w.get("id"), "id should be a string");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("initialized"), "initialized should be true");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("destroyed"), "destroyed should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("rendered"), "rendered should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("visible"), "visible should be true");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(w.get("tabIndex"), "tabIndex should be null");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testRender" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai id: "widgetRender"
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bbFromDom = Y.Node.one("#widgetRender");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(bbFromDom), "boundingBox not found in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bbFromDom.get("firstChild").compareTo(w.get("contentBox")), "contentBox not first child of boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bbFromDom.compareTo(Y.Node.one("body").get("firstChild")), "widget not inserted to body");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("rendered"), "Rendered flag not set");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testRenderTo" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai id: "widgetRenderTo"
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.render("#widgetRenderToContainer");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bbFromDom = Y.Node.one("#widgetRenderTo");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bbFromDom.get("parentNode").compareTo(Y.Node.one("#widgetRenderToContainer")), "widget not rendered to container passed to render()");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(bbFromDom), "boundingBox not found in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bbFromDom.get("firstChild").compareTo(w.get("contentBox")), "contentBox not first child of boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("rendered"), "Rendered flag not set");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testBaseClassNames" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = w.get("boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var cb = w.get("contentBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bb.hasClass("yui3-widget"), "bb missing yui3-widget marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(cb.hasClass("yui3-widget-content"), "cb missing yui3-widget-content marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testExtendedClassNames" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai function MyWidget() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai MyWidget.superclass.constructor.apply(this, arguments);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var myWidget = new MyWidget();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = myWidget.get("boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var cb = myWidget.get("contentBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bb.hasClass("yui3-widget"), "bb missing generic yui3-widget marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bb.hasClass("yui3-mywidget"), "bb missing yui3-mywidget marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(cb.hasClass("yui3-mywidget-content"), "cb missing yui3-mywidget-content marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(cb.hasClass("yui3-widget-content"), "cb shouldn't have yui3-widget-content marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testHeight" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai render:"#widgetRenderToContainer"
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = w.get("boundingBox"),
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai cb = w.get("contentBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // Default CSS has no border/padding/margin on BB/CB so this should be fine in all browsers
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(100, bb.get("offsetHeight"), "100 height not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(100, cb.get("offsetHeight"), "100 height not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("height", "200px");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(200, bb.get("offsetHeight"), "200px height not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(200, cb.get("offsetHeight"), "200px height not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("height", "50%");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(150, bb.get("offsetHeight"), "% height not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(150, cb.get("offsetHeight"), "% height not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testWidth" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai render:"#widgetRenderToContainer"
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = w.get("boundingBox"),
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai cb = w.get("contentBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // Default CSS has no border/padding/margin on BB/CB so this should be fine in all browsers
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(100, bb.get("offsetWidth"), "100 width not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(100, cb.get("offsetWidth"), "100 width not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("width", "200px");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(200, bb.get("offsetWidth"), "200px width not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(200, cb.get("offsetWidth"), "200px width not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("width", "50%");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(150, bb.get("offsetWidth"), "% width not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual(150, cb.get("offsetWidth"), "% width not set correctly in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testDisabled" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({render:true});
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = w.get("boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("disabled"), "disabled should be false by default");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(bb.hasClass("yui3-widget-disabled"), "bb should not have a disabled marker class");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("disabled", true);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("disabled"), "disabled should be true");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bb.hasClass("yui3-widget-disabled"), "bb should have a disabled marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w.set("disabled", false);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("disabled"), "disabled should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(bb.hasClass("yui3-widget-disabled"), "bb should not have a disabled marker class");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testDisableEnable" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({render:true});
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = w.get("boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("disabled"), "disabled should be false by default");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(bb.hasClass("yui3-widget-disabled"), "bb should not have a disabled marker class");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("disabled"), "disabled should be true");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bb.hasClass("yui3-widget-disabled"), "bb should have a disabled marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("disabled"), "disabled should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(bb.hasClass("yui3-widget-disabled"), "bb should not have a disabled marker class");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testFocusBlur" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // The focused attribute is read-only, so we test through the public api
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({render:true});
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = w.get("boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // TODO ENH REQUEST: This doesn't seem right. We should focus on render.
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("focused"), "focused should be false by default");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(bb.hasClass("yui3-widget-focused"), "bb should not have a disabled marker class");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("focused"), "focused should be true");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bb.hasClass("yui3-widget-focused"), "bb should have a focused marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("focused"), "focused should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(bb.hasClass("yui3-widget-focused"), "bb should not have a focused marker class");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testTabIndex" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var w = new Y.Widget({render:true});
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = w.get("boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(w.get("tabIndex"), "tabIndex should be null by default");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bb.get("tabIndex") <= 0, "tabIndex should not be set by default"); // default varies across browsers 0 or -1
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame(6, w.get("tabIndex"), "tabIndex should be 6");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // FIXME: See http://yuilibrary.com/projects/yui3/ticket/2531105
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // Y.Assert.areSame(6, bb.get("tabIndex"), "tabIndex should be 6");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame("testId", w.get("id"), "id not set");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame("testId", bb.get("id"), "id not reflected in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("visible"), "visible should be true by default");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(bb.hasClass("yui3-widget-hidden"), "bb should not have a hidden marker class");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areNotEqual("none", bb.getStyle("display"), "widget should not be display:none");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(w.get("visible"), "visible should be false");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(bb.hasClass("yui3-widget-hidden"), "bb should have an hidden marker");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areEqual("none", bb.getStyle("display"), "Default CSS should hide widget using display:none");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("visible"), "visible should be true by default");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(bb.hasClass("yui3-widget-hidden"), "bb should not have a hidden marker class");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areNotEqual("none", bb.getStyle("display"), "widget should not be display:none");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var container = Y.one("#widgetRenderToContainer");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(bb), "bb passed to constructor, not used");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("contentBox").compareTo(bb.get("firstChild")), "Missing contentBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("parentNode").compareTo(container), "boundingBox moved from it's place in the DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var container = Y.one("#widgetRenderToContainer");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("contentBox").compareTo(cb), "cb passed to constructor, not used");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(cb.get("parentNode")), "Missing boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("parentNode").compareTo(container), "contentBox moved from it's place in the DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var container = Y.one("#widgetRenderToContainer");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(bb), "bb passed to constructor, not used");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("contentBox").compareTo(cb), "cb passed to constructor, not used");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(cb.get("parentNode")), "bb not not cb's parent");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("parentNode").compareTo(container), "bb moved from it's place in the DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("firstChild").compareTo(cb), "cb not bb's firstChild");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var container = Y.one("#widgetRenderToContainer");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // NOTE: PE content sits in body, not container
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.one("body").append("<div id='bbTest'></div>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(bb), "bb passed to constructor, not used");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("contentBox").compareTo(bb.get("firstChild")), "Missing contentBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("parentNode").compareTo(container), "boundingBox moved from it's place in the DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var container = Y.one("#widgetRenderToContainer");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.one("body").append("<div id='cbTest'></div>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("contentBox").compareTo(cb), "cb passed to constructor, not used");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(cb.get("parentNode")), "Missing boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("parentNode").compareTo(container), "contentBox moved from it's place in the DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "testBoundingBoxContentBoxRenderTo" : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var container = Y.one("#widgetRenderToContainer");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.one("body").append("<div id='bbTest'></div>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(bb), "bb passed to constructor, not used");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("contentBox").compareTo(cb), "cb passed to constructor, not used");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(cb.get("parentNode")), "bb not not cb's parent");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("parentNode").compareTo(container), "bb moved from it's place in the DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("firstChild").compareTo(cb), "cb not bb's firstChild");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var container = Y.one("#widgetRenderToContainer");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai container.append("<div id='srcNode'><div id='foo'></div></div>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("contentBox").compareTo(sn), "srcNode should end up being cb");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("srcNode").compareTo(sn), "srcNode should still be accessible from srcNode attribute");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").compareTo(sn.get("parentNode")), "Missing boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isTrue(w.get("boundingBox").get("parentNode").compareTo(container), "srcNode moved from it's place in the DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNotNull(w.get("contentBox").one("#foo"), "contents of srcNode not maintained");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai ocb.append("<div><div id='outerContent'>Outer</div></div>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai icb.append("<div><div id='innerContent'>Inner</div></div>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame(o, Y.Widget.getByNode(outerContent), "Couldn't find outer widget from content");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame(i, Y.Widget.getByNode(innerContent), "Couldn't find inner widget from content");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame(o, Y.Widget.getByNode(o.get("contentBox")), "Couldn't find outer widget from outer contentBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame(o, Y.Widget.getByNode(o.get("boundingBox")), "Couldn't find outer widget from outer boundingBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame(i, Y.Widget.getByNode(i.get("contentBox")), "Couldn't find inner widget from inner contentBox");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame(i, Y.Widget.getByNode(i.get("boundingBox")), "Couldn't find inner widget from inner boundingBox");
1809f37c5e32d3366ee0a26377448d74d5fa7ff5Satyen Desai Y.ObjectAssert.ownsNoKeys(w.get("strings"), "No strings should be available by default");
1809f37c5e32d3366ee0a26377448d74d5fa7ff5Satyen Desai Y.Assert.areEqual("one", w.get("strings").stringOne);
1809f37c5e32d3366ee0a26377448d74d5fa7ff5Satyen Desai Y.Assert.areEqual("two", w.get("strings").stringTwo);
1809f37c5e32d3366ee0a26377448d74d5fa7ff5Satyen Desai Y.Assert.areEqual("three", w.get("strings").stringThree);
1809f37c5e32d3366ee0a26377448d74d5fa7ff5Satyen Desai Y.Assert.areEqual("four", w.get("strings").stringFour);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var n = Y.Node.create('<div id="srcNode" class="yui3-widget-loading">Src Node Content</div>');
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.areSame(n, w.get("contentBox"), "srcNode not used as content box");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isFalse(n.hasClass("yui3-widget-loading"), "yui3-widget-loading should have removed");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "getSkinName should return null if not rendered" : function () {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "getSkinName should return name from BB if available": function () {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var bb = Y.Node.create( '<div class="yui3-skin-foo"><div></div></div>' ),
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "getSkinName should return name from body or null": function () {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "getSkinName should return name from ancestor if both ancestor and body are classed": function () {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(Y.Node.one("#foo"), "Bounding box still in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.fail("w.destroy() on a rendered widget threw an exception" + e);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var nref = Y.Node.create('<div id="deep">Foo</div>');
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(Y.Node.one("#foo"), "Bounding box still in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(Y.Node.one("#deep"), "Deep content box still in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(Y.Node.getDOMNode(nref), "Deep content still in Node cache");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.fail("w.destroy(true) on a rendered widget threw an exception" + e);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.fail("w.destroy() on an unrendered widget threw an exception" + e);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai MyWidget.superclass.constructor.apply(this, arguments);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(Y.Node.one("#foo"), "Bounding box still in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.fail("w.destroy() on a single box widget threw an exception" + e);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai MyWidget.superclass.constructor.apply(this, arguments);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var nref = Y.Node.create('<div id="deep_single">Foo</div>');
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(Y.Node.one("#foo"), "Bounding box still in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(Y.Node.one("#deep_single"), "Deep content box still in DOM");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.isNull(Y.Node.getDOMNode(nref), "Deep content still in Node cache");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Assert.fail("w.destroy(true) on a single box widget threw an exception" + e);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai actualEvents = [],
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai expectedEvents = ["widget:click"];
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai cb.append("<p class='et'>Some Content For My Widget</p>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai h = function(e) { actualEvents.push(e.type); };
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.ArrayAssert.itemsAreEqual(expectedEvents, actualEvents);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai actualEvents = [],
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai expectedEvents = ["widget:render",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:renderedChange",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:render",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:mousedown",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:mouseup",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:mouseup",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:mouseup",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:mouseup",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:mouseup",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:mouseup",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai "widget:click"];
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai cb.append("<p class='et'>Some Content For My Widget</p>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai h = function(e) { actualEvents.push(e.type); };
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.ArrayAssert.itemsAreEqual(expectedEvents, actualEvents);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var expectedEvents = ["outerClick", "innerClick", "outerClick"];
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var actualEvents = [];
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai ocb.setContent("<span class='oet'>Outer Content</span>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai icb.setContent("<span class='iet'>Inner Content</span>");
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai inner.after('click', function() {actualEvents.push("innerClick");});
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai outer.after('click', function() {actualEvents.push("outerClick");});
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.ArrayAssert.itemsAreEqual(expectedEvents, actualEvents);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var actualEvents = [],
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai expectedEvents = ["clickOuter", "clickInner", "clickOuter"],
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w1.get('contentBox').append('<div class="w2-container"></div><span class="miouter">Outer</span>');
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai w2.get('contentBox').append('<span class="miinner">Inner</span>');
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Node.one(".miouter").simulate("click"); // only outer, once.
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.Node.one(".miinner").simulate("click"); // inner, bubbled to outer (once each, without JS errors)
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.ArrayAssert.itemsAreEqual(expectedEvents, actualEvents);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // When Widget's are properties of an object it seems to break apart
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // something not passed to the recursive call maybe?
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var a = new Y.Widget();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var b = new Y.Widget();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var c = new Y.Widget();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var o2 = Y.clone(o1);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var o3 = Y.clone(o2);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai testBaseClone : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var a = new Y.Base();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var b = new Y.Base();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var c = new Y.Base();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai // Base works fine
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var a2 = Y.clone(a1);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var a3 = Y.clone(a2);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var b2 = Y.clone(b1);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var b3 = Y.clone(b2);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var c2 = Y.clone(c1);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var c3 = Y.clone(c2);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai testBaseHashClone : function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var a = new Y.Base();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var b = new Y.Base();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var c = new Y.Base();
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var o2 = Y.clone(o1);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var o3 = Y.clone(o2);
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai var console;
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai Y.one("#btnRun").set("disabled", false).on("click", function() {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai if (!console) {
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai console = new Y.Console({
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai id:"console",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai width:"100%",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai height:"90%",
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai verbose : false,
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai printTimeout: 0,
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai newestOnTop : false,
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai entryTemplate: '<pre class="{entry_class} {cat_class} {src_class}">'+
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai '<span class="{entry_cat_class}">{label}</span>'+
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai '<span class="{entry_content_class}">{message}</span>'+
d4a90de3308f343c5d935b5f9b6bcc9f5bc4d05fSatyen Desai }).render();