mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-01-27 17:49:20 +01:00
262ed72348
Some features that we wish to test require HTTPS. Also, Chrome runtime is redirecting HTTP URLs to HTTPS due to HSTS.
105 lines
3.1 KiB
HTML
105 lines
3.1 KiB
HTML
<html>
|
|
<head>
|
|
<title>Server Test</title>
|
|
<script language="JavaScript">
|
|
|
|
// Send a query to the browser process.
|
|
function sendMessage(request, success_callback) {
|
|
// Results in a call to the OnQuery method in server_test.cc
|
|
window.cefQuery({
|
|
request: JSON.stringify(request),
|
|
onSuccess: function(response) {
|
|
success_callback(response.length == 0 ? {} : JSON.parse(response));
|
|
},
|
|
onFailure: function(error_code, error_message) {
|
|
alert("Request failed with error " + error_message + "(" + error_code + ")");
|
|
}
|
|
});
|
|
}
|
|
|
|
function setButtonState(start_enabled, stop_enabled) {
|
|
document.getElementById('start').disabled = !start_enabled;
|
|
document.getElementById('stop').disabled = !stop_enabled;
|
|
document.getElementById('open').disabled = !stop_enabled;
|
|
}
|
|
|
|
function setup() {
|
|
if (location.origin != 'https://tests') {
|
|
document.getElementById('warning').style.display = 'block';
|
|
return;
|
|
}
|
|
|
|
// Query the current server state.
|
|
sendMessage({'action':'query'}, function(response) {
|
|
if (response['result'] == 'success') {
|
|
var running = (response['status'] == 'running')
|
|
setButtonState(!running, running);
|
|
|
|
var port_element = document.getElementById('port');
|
|
port_element.value = response['port'];
|
|
port_element.disabled = false;
|
|
}
|
|
});
|
|
}
|
|
|
|
function startServer() {
|
|
var port = parseInt(document.getElementById('port').value);
|
|
if (port < 1025 || port > 65535) {
|
|
alert('Specify a port number between 1025 and 65535');
|
|
return;
|
|
}
|
|
|
|
setButtonState(false, false);
|
|
|
|
sendMessage({'action':'start', 'port':port}, function(response) {
|
|
if (response['result'] == 'success') {
|
|
setButtonState(false, true);
|
|
} else {
|
|
setButtonState(true, false);
|
|
alert(response['message']);
|
|
}
|
|
});
|
|
}
|
|
|
|
function stopServer() {
|
|
setButtonState(false, false);
|
|
|
|
sendMessage({'action':'stop'}, function(response) {
|
|
if (response['result'] == 'success') {
|
|
setButtonState(true, false);
|
|
} else {
|
|
setButtonState(false, true);
|
|
alert(response['message']);
|
|
}
|
|
});
|
|
}
|
|
|
|
function openServer() {
|
|
var port = document.getElementById('port').value;
|
|
window.open('http://localhost:' + port);
|
|
}
|
|
|
|
</script>
|
|
|
|
</head>
|
|
<body bgcolor="white" onload="setup()">
|
|
<div id="warning" style="display:none;color:red;font-weight:bold;">
|
|
This page can only be run from the https://tests origin.
|
|
</div>
|
|
<p>
|
|
This page starts an HTTP/WebSocket server on localhost with the specified port number.
|
|
After starting the server click the "Open Example" button to open the WebSocket Client test in a popup window.
|
|
</p>
|
|
<p>
|
|
With this example each browser window can create/manage a separate server instance.
|
|
The server will be stopped automatically when the managing browser window is closed.
|
|
</p>
|
|
<form>
|
|
Server port: <input type="text" id="port" value="" disabled="true">
|
|
<br/><input type="button" id="start" onclick="startServer()" value="Start Server" disabled="true">
|
|
<input type="button" id="stop" onclick="stopServer()" value="Stop Server" disabled="true">
|
|
<input type="button" id="open" onclick="openServer()" value="Open Example" disabled="true">
|
|
</form>
|
|
</body>
|
|
</html>
|