mirror of
https://github.com/servo/servo.git
synced 2025-08-06 14:10:11 +01:00
Make reftest build again. Convert to WebDriver
This commit is contained in:
parent
1cfecd4ca8
commit
3a99475fc5
4 changed files with 44 additions and 50 deletions
|
@ -1,23 +0,0 @@
|
|||
// From https://code.google.com/p/phantomjs/wiki/QuickStart
|
||||
|
||||
var page = require('webpage').create(),
|
||||
address, output, size;
|
||||
|
||||
if (phantom.args.length < 2 || phantom.args.length > 3) {
|
||||
console.log('Usage: rasterize.js URL filename');
|
||||
phantom.exit();
|
||||
} else {
|
||||
address = phantom.args[0];
|
||||
output = phantom.args[1];
|
||||
page.viewportSize = { width: 600, height: 600 };
|
||||
page.open(address, function (status) {
|
||||
if (status !== 'success') {
|
||||
console.log('Unable to load the address!');
|
||||
} else {
|
||||
window.setTimeout(function () {
|
||||
page.render(output);
|
||||
phantom.exit();
|
||||
}, 200);
|
||||
}
|
||||
});
|
||||
}
|
14
src/reftest/rasterize.py
Normal file
14
src/reftest/rasterize.py
Normal file
|
@ -0,0 +1,14 @@
|
|||
import sys
|
||||
from selenium import webdriver
|
||||
|
||||
input = sys.argv[1]
|
||||
output = sys.argv[2]
|
||||
|
||||
driver = webdriver.Firefox()
|
||||
|
||||
driver.set_window_size(800, 600)
|
||||
driver.get(file)
|
||||
|
||||
screenshot = driver.get_screenshot_as_file(output)
|
||||
|
||||
driver.quit()
|
|
@ -8,35 +8,35 @@ import path::{connect, basename};
|
|||
import os::list_dir_path;
|
||||
import servo::run_pipeline_png;
|
||||
|
||||
fn main(args: [str]) {
|
||||
fn main(args: ~[~str]) {
|
||||
let config = parse_config(args);
|
||||
let opts = test_options(config);
|
||||
let tests = find_tests(config);
|
||||
install_rasterize_js();
|
||||
install_rasterize_py();
|
||||
run_tests_console(opts, tests);
|
||||
}
|
||||
|
||||
type Config = {
|
||||
source_dir: str,
|
||||
work_dir: str,
|
||||
filter: option<str>
|
||||
};
|
||||
struct Config {
|
||||
source_dir: ~str;
|
||||
work_dir: ~str;
|
||||
filter: option<~str>;
|
||||
}
|
||||
|
||||
fn parse_config(args: [str]) -> Config {
|
||||
fn parse_config(args: ~[~str]) -> Config {
|
||||
let args = args.tail();
|
||||
let opts = [reqopt("source-dir"), reqopt("work-dir")];
|
||||
let match = alt getopts(args, opts) {
|
||||
ok(m) { m }
|
||||
err(f) { fail fail_str(f) }
|
||||
let opts = ~[reqopt(~"source-dir"), reqopt(~"work-dir")];
|
||||
let matches = match getopts(args, opts) {
|
||||
ok(m) => m,
|
||||
err(f) => fail fail_str(f)
|
||||
};
|
||||
|
||||
{
|
||||
source_dir: opt_str(match, "source-dir"),
|
||||
work_dir: opt_str(match, "work-dir"),
|
||||
filter: if match.free.is_empty() {
|
||||
Config {
|
||||
source_dir: opt_str(matches, ~"source-dir"),
|
||||
work_dir: opt_str(matches, ~"work-dir"),
|
||||
filter: if matches.free.is_empty() {
|
||||
none
|
||||
} else {
|
||||
some(match.free.head())
|
||||
some(matches.free.head())
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -49,12 +49,12 @@ fn test_options(config: Config) -> test_opts {
|
|||
}
|
||||
}
|
||||
|
||||
fn find_tests(config: Config) -> [test_desc] {
|
||||
let html_files = list_dir_path(config.source_dir).filter({ |file| file.ends_with(".html") });
|
||||
ret html_files.map({ |file| make_test(config, file) });
|
||||
fn find_tests(config: Config) -> ~[test_desc] {
|
||||
let html_files = list_dir_path(config.source_dir).filter( |file| file.ends_with(".html") );
|
||||
return html_files.map(|file| make_test(config, file) );
|
||||
}
|
||||
|
||||
fn make_test(config: Config, file: str) -> test_desc {
|
||||
fn make_test(config: Config, file: ~str) -> test_desc {
|
||||
{
|
||||
name: file,
|
||||
fn: fn~() { run_test(config, file) },
|
||||
|
@ -63,7 +63,7 @@ fn make_test(config: Config, file: str) -> test_desc {
|
|||
}
|
||||
}
|
||||
|
||||
fn run_test(config: Config, file: str) {
|
||||
fn run_test(config: Config, file: ~str) {
|
||||
let servo_render = render_servo(config, file);
|
||||
let ref_render = render_ref(config, file);
|
||||
if servo_render != ref_render {
|
||||
|
@ -71,20 +71,20 @@ fn run_test(config: Config, file: str) {
|
|||
}
|
||||
}
|
||||
|
||||
type Render = [u8];
|
||||
type Render = ~[u8];
|
||||
|
||||
fn render_servo(config: Config, file: str) -> Render {
|
||||
fn render_servo(config: Config, file: ~str) -> Render {
|
||||
let infile = file;
|
||||
let outfile = connect(config.work_dir, basename(file) + ".png");
|
||||
run_pipeline_png(infile, outfile);
|
||||
fail;
|
||||
}
|
||||
|
||||
fn render_ref(config: Config, file: str) -> Render {
|
||||
fn render_ref(config: Config, file: ~str) -> Render {
|
||||
fail
|
||||
}
|
||||
|
||||
fn install_rasterize_js() { }
|
||||
fn install_rasterize_py() { }
|
||||
|
||||
// This is the script that uses phantom.js to render pages
|
||||
fn rasterize_js() -> str { #include_str("rasterize.js") }
|
||||
fn rasterize_py() -> ~str { #include_str("rasterize.py") }
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue