Merge a21be26f4e into 9916d0e547
This commit is contained in:
commit
b248b45696
|
|
@ -21,5 +21,6 @@
|
||||||
"bin": {
|
"bin": {
|
||||||
"uglifyjs" : "bin/uglifyjs"
|
"uglifyjs" : "bin/uglifyjs"
|
||||||
},
|
},
|
||||||
|
"main": "./tools/node",
|
||||||
"scripts": {"test": "node test/run-tests.js"}
|
"scripts": {"test": "node test/run-tests.js"}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,39 +1,41 @@
|
||||||
#! /usr/bin/env node
|
#! /usr/bin/env node
|
||||||
|
|
||||||
var U = require("../tools/node");
|
// Test the two requires
|
||||||
var path = require("path");
|
["../tools/node", "../"].forEach(function(requireFile) {
|
||||||
var fs = require("fs");
|
var U = require(requireFile);
|
||||||
var assert = require("assert");
|
var path = require("path");
|
||||||
var sys = require("util");
|
var fs = require("fs");
|
||||||
|
var assert = require("assert");
|
||||||
|
var sys = require("util");
|
||||||
|
|
||||||
var tests_dir = path.dirname(module.filename);
|
var tests_dir = path.dirname(module.filename);
|
||||||
|
|
||||||
run_compress_tests();
|
run_compress_tests();
|
||||||
|
|
||||||
/* -----[ utils ]----- */
|
/* -----[ utils ]----- */
|
||||||
|
|
||||||
function tmpl() {
|
function tmpl() {
|
||||||
return U.string_template.apply(this, arguments);
|
return U.string_template.apply(this, arguments);
|
||||||
}
|
}
|
||||||
|
|
||||||
function log() {
|
function log() {
|
||||||
var txt = tmpl.apply(this, arguments);
|
var txt = tmpl.apply(this, arguments);
|
||||||
sys.puts(txt);
|
sys.puts(txt);
|
||||||
}
|
}
|
||||||
|
|
||||||
function log_directory(dir) {
|
function log_directory(dir) {
|
||||||
log("*** Entering [{dir}]", { dir: dir });
|
log("*** Entering [{dir}]", { dir: dir });
|
||||||
}
|
}
|
||||||
|
|
||||||
function log_start_file(file) {
|
function log_start_file(file) {
|
||||||
log("--- {file}", { file: file });
|
log("--- {file}", { file: file });
|
||||||
}
|
}
|
||||||
|
|
||||||
function log_test(name) {
|
function log_test(name) {
|
||||||
log(" Running test [{name}]", { name: name });
|
log(" Running test [{name}]", { name: name });
|
||||||
}
|
}
|
||||||
|
|
||||||
function find_test_files(dir) {
|
function find_test_files(dir) {
|
||||||
var files = fs.readdirSync(dir).filter(function(name){
|
var files = fs.readdirSync(dir).filter(function(name){
|
||||||
return /\.js$/i.test(name);
|
return /\.js$/i.test(name);
|
||||||
});
|
});
|
||||||
|
|
@ -44,22 +46,22 @@ function find_test_files(dir) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
return files;
|
return files;
|
||||||
}
|
}
|
||||||
|
|
||||||
function test_directory(dir) {
|
function test_directory(dir) {
|
||||||
return path.resolve(tests_dir, dir);
|
return path.resolve(tests_dir, dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
function as_toplevel(input) {
|
function as_toplevel(input) {
|
||||||
if (input instanceof U.AST_BlockStatement) input = input.body;
|
if (input instanceof U.AST_BlockStatement) input = input.body;
|
||||||
else if (input instanceof U.AST_Statement) input = [ input ];
|
else if (input instanceof U.AST_Statement) input = [ input ];
|
||||||
else throw new Error("Unsupported input syntax");
|
else throw new Error("Unsupported input syntax");
|
||||||
var toplevel = new U.AST_Toplevel({ body: input });
|
var toplevel = new U.AST_Toplevel({ body: input });
|
||||||
toplevel.figure_out_scope();
|
toplevel.figure_out_scope();
|
||||||
return toplevel;
|
return toplevel;
|
||||||
}
|
}
|
||||||
|
|
||||||
function run_compress_tests() {
|
function run_compress_tests() {
|
||||||
var dir = test_directory("compress");
|
var dir = test_directory("compress");
|
||||||
log_directory("compress");
|
log_directory("compress");
|
||||||
var files = find_test_files(dir);
|
var files = find_test_files(dir);
|
||||||
|
|
@ -93,9 +95,9 @@ function run_compress_tests() {
|
||||||
files.forEach(function(file){
|
files.forEach(function(file){
|
||||||
test_file(file);
|
test_file(file);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function parse_test(file) {
|
function parse_test(file) {
|
||||||
var script = fs.readFileSync(file, "utf8");
|
var script = fs.readFileSync(file, "utf8");
|
||||||
var ast = U.parse(script, {
|
var ast = U.parse(script, {
|
||||||
filename: file
|
filename: file
|
||||||
|
|
@ -154,17 +156,18 @@ function parse_test(file) {
|
||||||
block.walk(tw);
|
block.walk(tw);
|
||||||
return test;
|
return test;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
function make_code(ast, beautify) {
|
function make_code(ast, beautify) {
|
||||||
if (arguments.length == 1) beautify = true;
|
if (arguments.length == 1) beautify = true;
|
||||||
var stream = U.OutputStream({ beautify: beautify });
|
var stream = U.OutputStream({ beautify: beautify });
|
||||||
ast.print(stream);
|
ast.print(stream);
|
||||||
return stream.get();
|
return stream.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
function evaluate(code) {
|
function evaluate(code) {
|
||||||
if (code instanceof U.AST_Node)
|
if (code instanceof U.AST_Node)
|
||||||
code = make_code(code);
|
code = make_code(code);
|
||||||
return new Function("return(" + code + ")")();
|
return new Function("return(" + code + ")")();
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user