add selenium tests
authorioguix <ioguix>
Tue, 16 Oct 2007 21:30:26 +0000 (21:30 +0000)
committerioguix <ioguix>
Tue, 16 Oct 2007 21:30:26 +0000 (21:30 +0000)
selenium/domviewer/butmin.gif [new file with mode: 0644]
selenium/domviewer/butplus.gif [new file with mode: 0644]
selenium/domviewer/domviewer.css [new file with mode: 0644]
selenium/domviewer/domviewer.html [new file with mode: 0644]
selenium/domviewer/selenium-domviewer.js [new file with mode: 0644]

diff --git a/selenium/domviewer/butmin.gif b/selenium/domviewer/butmin.gif
new file mode 100644 (file)
index 0000000..7b7cefd
Binary files /dev/null and b/selenium/domviewer/butmin.gif differ
diff --git a/selenium/domviewer/butplus.gif b/selenium/domviewer/butplus.gif
new file mode 100644 (file)
index 0000000..6d68cfa
Binary files /dev/null and b/selenium/domviewer/butplus.gif differ
diff --git a/selenium/domviewer/domviewer.css b/selenium/domviewer/domviewer.css
new file mode 100644 (file)
index 0000000..b64b243
--- /dev/null
@@ -0,0 +1,298 @@
+/******************************************************************************\r
+* Defines default styles for site pages.                                      *\r
+******************************************************************************/\r
+.hidden {\r
+       display: none;\r
+}\r
+\r
+img{\r
+    display: inline;\r
+       border: none;\r
+}\r
+\r
+.box{\r
+       background: #fcfcfc;\r
+    border: 1px solid #000;\r
+       border-color: blue;\r
+    color: #000000;\r
+       margin: 10px auto;\r
+    padding: 3px;\r
+       vertical-align: bottom;\r
+}\r
+a {\r
+  text-decoration: none;\r
+}\r
+\r
+body {\r
+  background-color: #ffffff;\r
+  color: #000000;\r
+  font-family: Arial, Helvetica, sans-serif;\r
+  font-size: 10pt;\r
+}\r
+\r
+h2 {\r
+  font-size: 140%;\r
+}\r
+\r
+h3 {\r
+  font-size: 120%;\r
+}\r
+\r
+h4 {\r
+  font-size: 100%;\r
+}\r
+\r
+pre {\r
+  font-family: Courier New, Courier, monospace;\r
+  font-size: 80%;\r
+}\r
+\r
+td, th {\r
+  font-family: Arial, Helvetica, sans-serif;\r
+  font-size: 10pt;\r
+  text-align: left;\r
+  vertical-align: top;\r
+}\r
+\r
+th {\r
+  font-weight: bold;\r
+  vertical-align: bottom;\r
+}\r
+\r
+ul {\r
+  list-style-type: square;\r
+}\r
+\r
+#demoBox {\r
+  border-color: #000000;\r
+  border-style: solid;\r
+  border-width: 1px;\r
+  padding: 8px;\r
+  width: 24em;\r
+}\r
+\r
+.footer {\r
+  margin-bottom: 0px;\r
+  text-align: center;\r
+}\r
+\r
+/* Boxed table styles */\r
+\r
+table.boxed {\r
+  border-spacing: 2px;\r
+  empty-cells: hide;\r
+}\r
+\r
+td.boxed, th.boxed, th.boxedHeader {\r
+  background-color: #ffffff;\r
+  border-color: #000000;\r
+  border-style: solid;\r
+  border-width: 1px;\r
+  color: #000000;\r
+  padding: 2px;\r
+  padding-left: 8px;\r
+  padding-right: 8px;\r
+}\r
+\r
+th.boxed {\r
+  background-color: #c0c0c0;\r
+}\r
+\r
+th.boxedHeader {\r
+  background-color: #808080;\r
+  color: #ffffff;\r
+}\r
+\r
+a.object {\r
+  color: #0000ff;\r
+}\r
+\r
+li {\r
+  white-space: nowrap;\r
+}\r
+\r
+ul {\r
+  list-style-type: square;\r
+  margin-left: 0px;\r
+  padding-left: 1em;\r
+}\r
+\r
+.boxlevel1{\r
+       background: #FFD700;\r
+}\r
+\r
+.boxlevel2{\r
+       background: #D2691E;\r
+}\r
+\r
+.boxlevel3{\r
+       background: #DCDCDC;\r
+}\r
+\r
+.boxlevel4{\r
+       background: #F5F5F5;\r
+}\r
+\r
+.boxlevel5{\r
+       background: #BEBEBE;\r
+}\r
+\r
+.boxlevel6{\r
+       background: #D3D3D3;\r
+}\r
+\r
+.boxlevel7{\r
+       background: #A9A9A9;\r
+}\r
+\r
+.boxlevel8{\r
+       background: #191970;\r
+}\r
+\r
+.boxlevel9{\r
+       background: #000080;\r
+}\r
+\r
+.boxlevel10{\r
+       background: #6495ED;\r
+}\r
+\r
+.boxlevel11{\r
+       background: #483D8B;\r
+}\r
+\r
+.boxlevel12{\r
+       background: #6A5ACD;\r
+}\r
+\r
+.boxlevel13{\r
+       background: #7B68EE;\r
+}\r
+\r
+.boxlevel14{\r
+       background: #8470FF;\r
+}\r
+\r
+.boxlevel15{\r
+       background: #0000CD;\r
+}\r
+\r
+.boxlevel16{\r
+       background: #4169E1;\r
+}\r
+\r
+.boxlevel17{\r
+       background: #0000FF;\r
+}\r
+\r
+.boxlevel18{\r
+       background: #1E90FF;\r
+}\r
+\r
+.boxlevel19{\r
+       background: #00BFFF;\r
+}\r
+\r
+.boxlevel20{\r
+       background: #87CEEB;\r
+}\r
+\r
+.boxlevel21{\r
+       background: #B0C4DE;\r
+}\r
+\r
+.boxlevel22{\r
+       background: #ADD8E6;\r
+}\r
+\r
+.boxlevel23{\r
+       background: #00CED1;\r
+}\r
+\r
+.boxlevel24{\r
+       background: #48D1CC;\r
+}\r
+\r
+.boxlevel25{\r
+       background: #40E0D0;\r
+}\r
+\r
+.boxlevel26{\r
+       background: #008B8B;\r
+}\r
+\r
+.boxlevel27{\r
+       background: #00FFFF;\r
+}\r
+\r
+.boxlevel28{\r
+       background: #E0FFFF;\r
+}\r
+\r
+.boxlevel29{\r
+       background: #5F9EA0;\r
+}\r
+\r
+.boxlevel30{\r
+       background: #66CDAA;\r
+}\r
+\r
+.boxlevel31{\r
+       background: #7FFFD4;\r
+}\r
+\r
+.boxlevel32{\r
+       background: #006400;\r
+}\r
+\r
+.boxlevel33{\r
+       background: #556B2F;\r
+}\r
+\r
+.boxlevel34{\r
+       background: #8FBC8F;\r
+}\r
+\r
+.boxlevel35{\r
+       background: #2E8B57;\r
+}\r
+\r
+.boxlevel36{\r
+       background: #3CB371;\r
+}\r
+\r
+.boxlevel37{\r
+       background: #20B2AA;\r
+}\r
+\r
+.boxlevel38{\r
+       background: #00FF7F;\r
+}\r
+\r
+.boxlevel39{\r
+       background: #7CFC00;\r
+}\r
+\r
+.boxlevel40{\r
+       background: #90EE90;\r
+}\r
+\r
+.boxlevel41{\r
+       background: #00FF00;\r
+}\r
+\r
+.boxlevel41{\r
+       background: #7FFF00;\r
+}\r
+\r
+.boxlevel42{\r
+       background: #00FA9A;\r
+}\r
+\r
+.boxlevel43{\r
+       background: #ADFF2F;\r
+}\r
+\r
+.boxlevel44{\r
+       background: #32CD32;\r
+}
\ No newline at end of file
diff --git a/selenium/domviewer/domviewer.html b/selenium/domviewer/domviewer.html
new file mode 100644 (file)
index 0000000..9158a50
--- /dev/null
@@ -0,0 +1,16 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+
+<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
+    <head>
+        <title>DOM Viewer</title>
+        <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
+        <link rel="stylesheet" type="text/css" href="domviewer.css"/>
+        <script type="text/javascript" src="selenium-domviewer.js"></script>
+    </head>
+       <body onload="loadDomViewer();">
+               <h3>DOM Viewer</h3>
+               <p> This page is generated using JavaScript. If you see this text, your 
+                       browser doesn't support JavaScript.</p>
+       </body>
+       
+</html>
diff --git a/selenium/domviewer/selenium-domviewer.js b/selenium/domviewer/selenium-domviewer.js
new file mode 100644 (file)
index 0000000..941aab1
--- /dev/null
@@ -0,0 +1,205 @@
+var HIDDEN="hidden";
+var LEVEL = "level";
+var PLUS_SRC="butplus.gif";
+var MIN_SRC="butmin.gif";
+var newRoot;
+var maxColumns=1;
+
+function loadDomViewer() {
+    // See if the rootDocument variable has been set on this window.
+    var rootDocument = window.rootDocument;
+
+    // If not look to the opener for an explicity rootDocument variable, otherwise, use the opener document
+    if (!rootDocument && window.opener) {
+        rootDocument = window.opener.rootDocument || window.opener.document;
+    }
+
+    if (rootDocument) {
+        document.body.innerHTML = displayDOM(rootDocument);
+    }
+    else {
+        document.body.innerHTML = "<b>Must specify rootDocument for window. This can be done by setting the rootDocument variable on this window, or on the opener window for a popup window.</b>";
+    }
+}
+
+
+function displayDOM(root){
+    var str = "";
+    str+="<table>";
+    str += treeTraversal(root,0);
+    // to make table columns work well.
+    str += "<tr>";
+    for (var i=0; i < maxColumns; i++) {
+        str+= "<td>&nbsp;&nbsp;&nbsp;&nbsp;</td>";
+    }
+    str += "</tr>";
+    str += "</table>";
+    return str;
+}
+
+function checkForChildren(element){
+    if(!element.hasChildNodes())
+        return false;
+    
+    var nodes = element.childNodes;
+    var size = nodes.length;
+    var count=0;
+    
+    for(var i=0; i< size; i++){
+        var node = nodes.item(i);
+        //if(node.toString()=="[object Text]"){
+        //this is equalent to the above
+        //but will work with more browsers
+        if(node.nodeType!=1){
+            count++;
+        }
+    }
+    
+    if(count == size)
+        return false;
+    else
+        return true;
+}
+
+function treeTraversal(root, level){
+    var str = "";
+    var nodes= null;
+    var size = null;
+    //it is supposed to show the last node, 
+    //but the last node is always nodeText type
+    //and we don't show it
+    if(!root.hasChildNodes())
+        return "";//displayNode(root,level,false);
+    
+    nodes = root.childNodes;
+    size = nodes.length;
+
+    for(var i=0; i< size; i++){
+        var element = nodes.item(i);
+        //if the node is textNode, don't display
+        if(element.nodeType==1){
+            str+= displayNode(element,level,checkForChildren(element));
+            str+=treeTraversal(element, level+1);      
+        }
+    }
+    return str;
+}
+
+function displayNode(element, level, isLink){
+    nodeContent = getNodeContent(element);
+    columns = Math.round((nodeContent.length / 12) + 0.5);
+    if (columns + level > maxColumns) {
+        maxColumns = columns + level;
+    }
+    var str ="<tr class='"+LEVEL+level+"'>";
+    for (var i=0; i < level; i++)
+        str+= "<td> </td>";
+    str+="<td colspan='"+ columns +"' class='box"+" boxlevel"+level+"' >";
+    if(isLink){
+        str+='<a onclick="hide(this);return false;" href="javascript:void();">';
+        str+='<img src="'+MIN_SRC+'" />';
+    }
+    str += nodeContent;
+    if(isLink)
+        str+="</a></td></tr>";
+    return str;
+}
+
+function getNodeContent(element) {
+
+    str = "";
+    id ="";
+    if (element.id != null && element.id != "") {
+        id = " ID(" + element.id +")";
+    }
+    name ="";
+    if (element.name != null && element.name != "") {
+        name = " NAME(" + element.name + ")";
+    }
+    value ="";
+    if (element.value != null && element.value != "") {
+        value = " VALUE(" + element.value + ")";
+    }
+    href ="";
+    if (element.href != null && element.href != "") {
+        href = " HREF(" + element.href + ")";
+    }
+    clazz = "";
+    if (element.className != null && element.className != "") {
+        clazz = " CLASS(" + element.className + ")";
+    }
+    src = "";
+    if (element.src != null && element.src != "") {
+        src = " SRC(" + element.src + ")";
+    }
+    alt = "";
+    if (element.alt != null && element.alt != "") {
+        alt = " ALT(" + element.alt + ")";
+    }
+    type = "";
+    if (element.type != null && element.type != "") {
+        type = " TYPE(" + element.type + ")";
+    }
+    text ="";
+    if (element.text != null && element.text != "" && element.text != "undefined") {
+        text = " #TEXT(" + trim(element.text) +")";
+    }
+    str+=" <b>"+ element.nodeName + id + alt + type + clazz + name + value + href + src + text + "</b>";
+    return str;
+
+}
+
+function trim(val) {
+    val2 = val.substring(0,40) + "                   ";
+    var spaceChr = String.fromCharCode(32);
+    var length = val2.length;
+    var retVal = "";
+    var ix = length -1;
+
+    while(ix > -1){
+        if(val2.charAt(ix) == spaceChr) {
+        } else {
+            retVal = val2.substring(0, ix +1);
+            break;
+        }
+        ix = ix-1;
+    }
+    if (val.length > 40) {
+        retVal += "...";
+    }
+    return retVal;
+}
+
+function hide(hlink){
+    var isHidden = false;
+    var image = hlink.firstChild;
+    if(image.src.toString().indexOf(MIN_SRC)!=-1){
+        image.src=PLUS_SRC;
+        isHidden=true;
+    }else{
+        image.src=MIN_SRC;
+    }
+    var rowObj= hlink.parentNode.parentNode;
+    var rowLevel = parseInt(rowObj.className.substring(LEVEL.length));
+       
+    var sibling = rowObj.nextSibling;
+    var siblingLevel = sibling.className.substring(LEVEL.length);
+    if(siblingLevel.indexOf(HIDDEN)!=-1){
+        siblingLevel = siblingLevel.substring(0,siblingLevel.length - HIDDEN.length-1);
+    }
+    siblingLevel=parseInt(siblingLevel);
+    while(sibling!=null && rowLevel<siblingLevel){
+        if(isHidden){
+            sibling.className += " "+ HIDDEN;
+        }else if(!isHidden && sibling.className.indexOf(HIDDEN)!=-1){
+            var str = sibling.className;
+            sibling.className=str.substring(0, str.length - HIDDEN.length-1);
+        }
+        sibling = sibling.nextSibling;
+        siblingLevel = parseInt(sibling.className.substring(LEVEL.length));
+    }
+}
+
+function LOG(message) {
+    window.opener.LOG.warn(message);
+}