]> git.proxmox.com Git - mirror_novnc.git/blobdiff - tests/vnc_playback.html
Update browser test list
[mirror_novnc.git] / tests / vnc_playback.html
index 5f3af416e20c2c7f57e71cf4e8beb40b96d2adb4..d5f9442806d8c409282fb4fa2a0c0570996a5eab 100644 (file)
@@ -1,14 +1,22 @@
+<!DOCTYPE html>
 <html>
     <head>
         <title>VNC Playback</title>
-        <link rel="stylesheet" href="include/plain.css">
+        <script src="/vendor/browser-es-module-loader/dist/browser-es-module-loader.js"></script>
+        <script type="module" src="./playback.js"></script>
     </head>
     <body>
 
-        Iterations: <input id='iterations' style='width:50' value="3">&nbsp;
+        Iterations: <input id='iterations' style='width:50'>&nbsp;
+        Perftest:<input type='radio' id='mode1' name='mode' checked>&nbsp;
+        Realtime:<input type='radio' id='mode2' name='mode'>&nbsp;&nbsp;
 
-        <input id='startButton' type='button' value='Start' style='width:100px'
-            onclick="start();" disabled>&nbsp;
+        <input id='startButton' type='button' value='Start' style='width:100px' disabled>&nbsp;
+
+        <br><br>
+
+        Results:<br>
+        <textarea id="messages" style="font-size: 9;" cols=80 rows=25></textarea>
 
         <br><br>
 
                     <td><div id="VNC_status">Loading</div></td>
                 </tr></table>
             </div>
-            <canvas id="VNC_canvas" width="640px" height="20px">
-                Canvas not supported.
-            </canvas>
         </div>
 
-        <br>
-        Results:<br>
-        <textarea id="messages" style="font-size: 9;" cols=80 rows=25></textarea>
     </body>
 
     <!--
-    <script type='text/javascript' 
+    <script type='text/javascript'
         src='http://getfirebug.com/releases/lite/1.2/firebug-lite-compressed.js'></script>
     -->
 
-    <script src="include/vnc.js"></script>
-
-    <script>
-        var rfb, fname, test_state, frame_idx, frame_length, iteration,
-            iterations, start_time, packetID, waitTimer;
-
-        function message(str) {
-            console.log(str);
-            cell = $('messages');
-            cell.innerHTML += str + "\n";
-            cell.scrollTop = cell.scrollHeight;
-        }
-
-        fname = (document.location.href.match(
-                 /data=([A-Za-z0-9\._\-]*)/) ||
-                 ['', ''])[1];
-
-        if (fname) {
-            message("Loading " + fname);
-            document.write('<script src="' + fname + '"><\/script>');
-        } else {
-            message("Must specify data=FOO in query string.");
-        }
-
-        // Override send_array
-        send_array = function (arr) {
-            // Stub out send_array
-        }
-
-        updateState = function (rfb, state, oldstate, msg) {
-            switch (state) {
-                case 'failed':
-                case 'fatal':
-                    message("noVNC sent '" + state + "' state during iteration " + iteration);
-                    test_state = 'failed';
-                    break;
-                case 'loaded': 
-                    $('startButton').disabled = false;
-                    break;
-            }
-            if (typeof msg !== 'undefined') {
-                $('VNC_status').innerHTML = msg;
-            }
-        }
-
-        function start () {
-            $('startButton').value = "Running";
-            $('startButton').disabled = true;
-            test_state = 'running';
-
-            iterations = $('iterations').value;
-            iteration = 0;
-            frame_length = VNC_frame_data.length;
-            total_time = 0;
-            start_time = (new Date()).getTime();
-
-            setTimeout(next_iteration, 1);
-        }
-
-        function next_iteration () {
-            var time, iter_time, end_time;
-
-            if (test_state !== 'running') { return; }
-
-            if (iteration !== 0) {
-                rfb.disconnect();
-            }
-            
-            iteration++;
-            if (iteration > iterations) {
-                // Finished with all iterations
-                var end_time = (new Date()).getTime();
-                total_time = end_time - start_time;
-
-                iter_time = parseInt(total_time / iterations, 10);
-                message(iterations + " iterations took " + total_time + "ms, " +
-                        iter_time + "ms per iteration");
-                rfb.get_canvas().stop();   // Shut-off event interception
-                $('startButton').disabled = false;
-                $('startButton').value = "Start";
-                return;
-            }
-
-            frame_idx = 0;
-            rfb.connect('test', 0, "bogus");
-
-            setTimeout(do_packet, 1);
-
-        }
-
-        function do_packet () {
-            var frame;
-            if (test_state !== 'running') { return; }
-
-            frame = VNC_frame_data[frame_idx];
-            while (frame.charAt(0) === "}") {
-                //message("Send frame " + frame_idx);
-                frame_idx ++;
-                frame = VNC_frame_data[frame_idx];
-                if (frame_idx >= frame_length) {
-                    break;
-                }
-            }
-
-
-            //message("Processing frame: " + frame_idx);
-            if (frame) {
-                if (frame === 'EOF') {
-                    //message("Found EOF");
-                } else {
-                    rfb.recv_message({'data' : frame.slice(frame.indexOf('{', 1)+1)});
-                }
-                frame_idx++;
-            }
-
-            if (frame_idx >= frame_length) {
-                next_iteration();
-            } else {
-                setTimeout(do_packet, 1);
-            }
-        }
-
-        window.onload = function() {
-            if (fname) {
-                message("VNC_frame_data.length: " + VNC_frame_data.length);
-                rfb = RFB({'target': 'VNC_canvas',
-                        'updateState': updateState});
-                rfb.testMode(send_array);
-                rfb.init();
-            }
-        }
-    </script>
+    <script type="module" src="./playback-ui.js">
 </html>