mirror of
https://github.com/denoland/deno.git
synced 2025-01-10 08:09:06 -05:00
Fix flaky tests (#4134)
This commit is contained in:
parent
0e37184ca8
commit
3d03d7e83b
2 changed files with 27 additions and 28 deletions
|
@ -67,39 +67,32 @@ fn kill_http_server() {
|
||||||
|
|
||||||
pub fn http_server() -> HttpServerGuard {
|
pub fn http_server() -> HttpServerGuard {
|
||||||
SERVER_COUNT.fetch_add(1, Ordering::SeqCst);
|
SERVER_COUNT.fetch_add(1, Ordering::SeqCst);
|
||||||
|
|
||||||
{
|
{
|
||||||
let mut server_guard = SERVER.lock().unwrap();
|
let mut server_guard = SERVER.lock().unwrap();
|
||||||
if server_guard.is_none() {
|
if server_guard.is_none() {
|
||||||
println!("tools/http_server.py starting...");
|
println!("tools/http_server.py starting...");
|
||||||
let mut child = Command::new("python")
|
let mut child = Command::new("python")
|
||||||
.current_dir(root_path())
|
.current_dir(root_path())
|
||||||
.args(&[
|
.args(&["-u", "tools/http_server.py"])
|
||||||
"-u",
|
|
||||||
"tools/http_server.py",
|
|
||||||
"--certfile",
|
|
||||||
root_path()
|
|
||||||
.join("std/http/testdata/tls/localhost.crt")
|
|
||||||
.to_str()
|
|
||||||
.unwrap(),
|
|
||||||
"--keyfile",
|
|
||||||
root_path()
|
|
||||||
.join("std/http/testdata/tls/localhost.key")
|
|
||||||
.to_str()
|
|
||||||
.unwrap(),
|
|
||||||
])
|
|
||||||
.stdout(Stdio::piped())
|
.stdout(Stdio::piped())
|
||||||
.spawn()
|
.spawn()
|
||||||
.expect("failed to execute child");
|
.expect("failed to execute child");
|
||||||
|
|
||||||
let stdout = child.stdout.as_mut().unwrap();
|
let stdout = child.stdout.as_mut().unwrap();
|
||||||
use std::io::{BufRead, BufReader};
|
use std::io::{BufRead, BufReader};
|
||||||
let mut lines = BufReader::new(stdout).lines();
|
let lines = BufReader::new(stdout).lines();
|
||||||
let line = lines.next().unwrap().unwrap();
|
// Wait for "ready" on stdout. See tools/http_server.py
|
||||||
assert!(line.starts_with("ready"));
|
for maybe_line in lines {
|
||||||
server_guard.replace(child);
|
if let Ok(line) = maybe_line {
|
||||||
|
if line.starts_with("ready") {
|
||||||
|
server_guard.replace(child);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
panic!(maybe_line.unwrap_err());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
HttpServerGuard {}
|
HttpServerGuard {}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,14 +21,11 @@ REDIRECT_PORT = 4546
|
||||||
ANOTHER_REDIRECT_PORT = 4547
|
ANOTHER_REDIRECT_PORT = 4547
|
||||||
DOUBLE_REDIRECTS_PORT = 4548
|
DOUBLE_REDIRECTS_PORT = 4548
|
||||||
INF_REDIRECTS_PORT = 4549
|
INF_REDIRECTS_PORT = 4549
|
||||||
|
|
||||||
HTTPS_PORT = 5545
|
HTTPS_PORT = 5545
|
||||||
|
|
||||||
|
|
||||||
def create_http_arg_parser():
|
def create_http_arg_parser():
|
||||||
parser = argparse.ArgumentParser()
|
parser = argparse.ArgumentParser()
|
||||||
parser.add_argument('--certfile')
|
|
||||||
parser.add_argument('--keyfile')
|
|
||||||
parser.add_argument('--verbose', '-v', action='store_true')
|
parser.add_argument('--verbose', '-v', action='store_true')
|
||||||
return parser
|
return parser
|
||||||
|
|
||||||
|
@ -36,8 +33,8 @@ def create_http_arg_parser():
|
||||||
HttpArgParser = create_http_arg_parser()
|
HttpArgParser = create_http_arg_parser()
|
||||||
|
|
||||||
args, unknown = HttpArgParser.parse_known_args(sys.argv[1:])
|
args, unknown = HttpArgParser.parse_known_args(sys.argv[1:])
|
||||||
CERT_FILE = args.certfile
|
CERT_FILE = os.path.join(root_path, "std/http/testdata/tls/localhost.crt")
|
||||||
KEY_FILE = args.keyfile
|
KEY_FILE = os.path.join(root_path, "std/http/testdata/tls/localhost.key")
|
||||||
QUIET = not args.verbose
|
QUIET = not args.verbose
|
||||||
|
|
||||||
|
|
||||||
|
@ -314,10 +311,19 @@ def start(s):
|
||||||
def spawn():
|
def spawn():
|
||||||
servers = (server(), redirect_server(), another_redirect_server(),
|
servers = (server(), redirect_server(), another_redirect_server(),
|
||||||
double_redirects_server(), https_server())
|
double_redirects_server(), https_server())
|
||||||
while any(not s.thread.is_alive() for s in servers):
|
# In order to wait for each of the servers to be ready, we try connecting to
|
||||||
sleep(0.01)
|
# them with a tcp socket.
|
||||||
|
for running_server in servers:
|
||||||
|
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||||||
|
port = running_server.server.server_address[1]
|
||||||
|
client.connect(("127.0.0.1", port))
|
||||||
|
print "connected", port
|
||||||
|
client.close()
|
||||||
|
assert running_server.thread.is_alive()
|
||||||
|
# The following output "ready" is specificly looked for in cli/test_util.rs
|
||||||
|
# to prevent race conditions.
|
||||||
|
print "ready"
|
||||||
try:
|
try:
|
||||||
print "ready"
|
|
||||||
yield servers
|
yield servers
|
||||||
finally:
|
finally:
|
||||||
for s in servers:
|
for s in servers:
|
||||||
|
|
Loading…
Reference in a new issue