Merge pull request #4008 from weswigham/fix-many-linter-errors
Fix as many linter errors as possible
This commit is contained in:
commit
2b8ef5e6fd
22 changed files with 636 additions and 630 deletions
|
@ -139,7 +139,7 @@ namespace ts {
|
||||||
function getDeclarationName(node: Declaration): string {
|
function getDeclarationName(node: Declaration): string {
|
||||||
if (node.name) {
|
if (node.name) {
|
||||||
if (node.kind === SyntaxKind.ModuleDeclaration && node.name.kind === SyntaxKind.StringLiteral) {
|
if (node.kind === SyntaxKind.ModuleDeclaration && node.name.kind === SyntaxKind.StringLiteral) {
|
||||||
return '"' + (<LiteralExpression>node.name).text + '"';
|
return `"${(<LiteralExpression>node.name).text}"`;
|
||||||
}
|
}
|
||||||
if (node.name.kind === SyntaxKind.ComputedPropertyName) {
|
if (node.name.kind === SyntaxKind.ComputedPropertyName) {
|
||||||
let nameExpression = (<ComputedPropertyName>node.name).expression;
|
let nameExpression = (<ComputedPropertyName>node.name).expression;
|
||||||
|
@ -830,7 +830,7 @@ namespace ts {
|
||||||
|
|
||||||
// Note: the node text must be exactly "use strict" or 'use strict'. It is not ok for the
|
// Note: the node text must be exactly "use strict" or 'use strict'. It is not ok for the
|
||||||
// string to contain unicode escapes (as per ES5).
|
// string to contain unicode escapes (as per ES5).
|
||||||
return nodeText === '"use strict"' || nodeText === "'use strict'";
|
return nodeText === "\"use strict\"" || nodeText === "'use strict'";
|
||||||
}
|
}
|
||||||
|
|
||||||
function bindWorker(node: Node) {
|
function bindWorker(node: Node) {
|
||||||
|
@ -930,7 +930,7 @@ namespace ts {
|
||||||
function bindSourceFileIfExternalModule() {
|
function bindSourceFileIfExternalModule() {
|
||||||
setExportContextFlag(file);
|
setExportContextFlag(file);
|
||||||
if (isExternalModule(file)) {
|
if (isExternalModule(file)) {
|
||||||
bindAnonymousDeclaration(file, SymbolFlags.ValueModule, '"' + removeFileExtension(file.fileName) + '"');
|
bindAnonymousDeclaration(file, SymbolFlags.ValueModule, `"${removeFileExtension(file.fileName)}"`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -211,6 +211,9 @@ namespace ts {
|
||||||
let assignableRelation: Map<RelationComparisonResult> = {};
|
let assignableRelation: Map<RelationComparisonResult> = {};
|
||||||
let identityRelation: Map<RelationComparisonResult> = {};
|
let identityRelation: Map<RelationComparisonResult> = {};
|
||||||
|
|
||||||
|
// This is for caching the result of getSymbolDisplayBuilder. Do not access directly.
|
||||||
|
let _displayBuilder: SymbolDisplayBuilder;
|
||||||
|
|
||||||
type TypeSystemEntity = Symbol | Type | Signature;
|
type TypeSystemEntity = Symbol | Type | Signature;
|
||||||
|
|
||||||
const enum TypeSystemPropertyName {
|
const enum TypeSystemPropertyName {
|
||||||
|
@ -965,7 +968,7 @@ namespace ts {
|
||||||
if (!moduleName) return;
|
if (!moduleName) return;
|
||||||
let isRelative = isExternalModuleNameRelative(moduleName);
|
let isRelative = isExternalModuleNameRelative(moduleName);
|
||||||
if (!isRelative) {
|
if (!isRelative) {
|
||||||
let symbol = getSymbol(globals, '"' + moduleName + '"', SymbolFlags.ValueModule);
|
let symbol = getSymbol(globals, "\"" + moduleName + "\"", SymbolFlags.ValueModule);
|
||||||
if (symbol) {
|
if (symbol) {
|
||||||
return symbol;
|
return symbol;
|
||||||
}
|
}
|
||||||
|
@ -1490,8 +1493,6 @@ namespace ts {
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is for caching the result of getSymbolDisplayBuilder. Do not access directly.
|
|
||||||
let _displayBuilder: SymbolDisplayBuilder;
|
|
||||||
function getSymbolDisplayBuilder(): SymbolDisplayBuilder {
|
function getSymbolDisplayBuilder(): SymbolDisplayBuilder {
|
||||||
|
|
||||||
function getNameOfSymbol(symbol: Symbol): string {
|
function getNameOfSymbol(symbol: Symbol): string {
|
||||||
|
@ -3448,7 +3449,7 @@ namespace ts {
|
||||||
// type, a property is considered known if it is known in any constituent type.
|
// type, a property is considered known if it is known in any constituent type.
|
||||||
function isKnownProperty(type: Type, name: string): boolean {
|
function isKnownProperty(type: Type, name: string): boolean {
|
||||||
if (type.flags & TypeFlags.ObjectType && type !== globalObjectType) {
|
if (type.flags & TypeFlags.ObjectType && type !== globalObjectType) {
|
||||||
var resolved = resolveStructuredTypeMembers(type);
|
const resolved = resolveStructuredTypeMembers(type);
|
||||||
return !!(resolved.properties.length === 0 ||
|
return !!(resolved.properties.length === 0 ||
|
||||||
resolved.stringIndexType ||
|
resolved.stringIndexType ||
|
||||||
resolved.numberIndexType ||
|
resolved.numberIndexType ||
|
||||||
|
@ -7355,7 +7356,7 @@ namespace ts {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wasn't found
|
// Wasn't found
|
||||||
error(node, Diagnostics.Property_0_does_not_exist_on_type_1, (<Identifier>node.tagName).text, 'JSX.' + JsxNames.IntrinsicElements);
|
error(node, Diagnostics.Property_0_does_not_exist_on_type_1, (<Identifier>node.tagName).text, "JSX." + JsxNames.IntrinsicElements);
|
||||||
return unknownSymbol;
|
return unknownSymbol;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -7395,7 +7396,7 @@ namespace ts {
|
||||||
function getJsxElementInstanceType(node: JsxOpeningLikeElement) {
|
function getJsxElementInstanceType(node: JsxOpeningLikeElement) {
|
||||||
// There is no such thing as an instance type for a non-class element. This
|
// There is no such thing as an instance type for a non-class element. This
|
||||||
// line shouldn't be hit.
|
// line shouldn't be hit.
|
||||||
Debug.assert(!!(getNodeLinks(node).jsxFlags & JsxFlags.ClassElement), 'Should not call getJsxElementInstanceType on non-class Element');
|
Debug.assert(!!(getNodeLinks(node).jsxFlags & JsxFlags.ClassElement), "Should not call getJsxElementInstanceType on non-class Element");
|
||||||
|
|
||||||
let classSymbol = getJsxElementTagSymbol(node);
|
let classSymbol = getJsxElementTagSymbol(node);
|
||||||
if (classSymbol === unknownSymbol) {
|
if (classSymbol === unknownSymbol) {
|
||||||
|
@ -7575,7 +7576,7 @@ namespace ts {
|
||||||
// be marked as 'used' so we don't incorrectly elide its import. And if there
|
// be marked as 'used' so we don't incorrectly elide its import. And if there
|
||||||
// is no 'React' symbol in scope, we should issue an error.
|
// is no 'React' symbol in scope, we should issue an error.
|
||||||
if (compilerOptions.jsx === JsxEmit.React) {
|
if (compilerOptions.jsx === JsxEmit.React) {
|
||||||
let reactSym = resolveName(node.tagName, 'React', SymbolFlags.Value, Diagnostics.Cannot_find_name_0, 'React');
|
let reactSym = resolveName(node.tagName, "React", SymbolFlags.Value, Diagnostics.Cannot_find_name_0, "React");
|
||||||
if (reactSym) {
|
if (reactSym) {
|
||||||
getSymbolLinks(reactSym).referenced = true;
|
getSymbolLinks(reactSym).referenced = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -335,7 +335,7 @@ namespace ts {
|
||||||
* @param fileName The path to the config file
|
* @param fileName The path to the config file
|
||||||
*/
|
*/
|
||||||
export function readConfigFile(fileName: string): { config?: any; error?: Diagnostic } {
|
export function readConfigFile(fileName: string): { config?: any; error?: Diagnostic } {
|
||||||
let text = '';
|
let text = "";
|
||||||
try {
|
try {
|
||||||
text = sys.readFile(fileName);
|
text = sys.readFile(fileName);
|
||||||
}
|
}
|
||||||
|
@ -423,7 +423,7 @@ namespace ts {
|
||||||
fileNames = map(<string[]>json["files"], s => combinePaths(basePath, s));
|
fileNames = map(<string[]>json["files"], s => combinePaths(basePath, s));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
errors.push(createCompilerDiagnostic(Diagnostics.Compiler_option_0_requires_a_value_of_type_1, 'files', 'Array'));
|
errors.push(createCompilerDiagnostic(Diagnostics.Compiler_option_0_requires_a_value_of_type_1, "files", "Array"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
|
@ -219,10 +219,10 @@ namespace ts {
|
||||||
export function reduceLeft<T, U>(array: T[], f: (a: U, x: T) => U, initial: U): U;
|
export function reduceLeft<T, U>(array: T[], f: (a: U, x: T) => U, initial: U): U;
|
||||||
export function reduceLeft<T, U>(array: T[], f: (a: U, x: T) => U, initial?: U): U {
|
export function reduceLeft<T, U>(array: T[], f: (a: U, x: T) => U, initial?: U): U {
|
||||||
if (array) {
|
if (array) {
|
||||||
var count = array.length;
|
const count = array.length;
|
||||||
if (count > 0) {
|
if (count > 0) {
|
||||||
var pos = 0;
|
let pos = 0;
|
||||||
var result = arguments.length <= 2 ? array[pos++] : initial;
|
let result = arguments.length <= 2 ? array[pos++] : initial;
|
||||||
while (pos < count) {
|
while (pos < count) {
|
||||||
result = f(<U>result, array[pos++]);
|
result = f(<U>result, array[pos++]);
|
||||||
}
|
}
|
||||||
|
@ -236,9 +236,9 @@ namespace ts {
|
||||||
export function reduceRight<T, U>(array: T[], f: (a: U, x: T) => U, initial: U): U;
|
export function reduceRight<T, U>(array: T[], f: (a: U, x: T) => U, initial: U): U;
|
||||||
export function reduceRight<T, U>(array: T[], f: (a: U, x: T) => U, initial?: U): U {
|
export function reduceRight<T, U>(array: T[], f: (a: U, x: T) => U, initial?: U): U {
|
||||||
if (array) {
|
if (array) {
|
||||||
var pos = array.length - 1;
|
let pos = array.length - 1;
|
||||||
if (pos >= 0) {
|
if (pos >= 0) {
|
||||||
var result = arguments.length <= 2 ? array[pos--] : initial;
|
let result = arguments.length <= 2 ? array[pos--] : initial;
|
||||||
while (pos >= 0) {
|
while (pos >= 0) {
|
||||||
result = f(<U>result, array[pos--]);
|
result = f(<U>result, array[pos--]);
|
||||||
}
|
}
|
||||||
|
@ -523,7 +523,7 @@ namespace ts {
|
||||||
if (path.lastIndexOf("file:///", 0) === 0) {
|
if (path.lastIndexOf("file:///", 0) === 0) {
|
||||||
return "file:///".length;
|
return "file:///".length;
|
||||||
}
|
}
|
||||||
let idx = path.indexOf('://');
|
let idx = path.indexOf("://");
|
||||||
if (idx !== -1) {
|
if (idx !== -1) {
|
||||||
return idx + "://".length;
|
return idx + "://".length;
|
||||||
}
|
}
|
||||||
|
|
|
@ -380,7 +380,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
function base64VLQFormatEncode(inValue: number) {
|
function base64VLQFormatEncode(inValue: number) {
|
||||||
function base64FormatEncode(inValue: number) {
|
function base64FormatEncode(inValue: number) {
|
||||||
if (inValue < 64) {
|
if (inValue < 64) {
|
||||||
return 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.charAt(inValue);
|
return "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".charAt(inValue);
|
||||||
}
|
}
|
||||||
throw TypeError(inValue + ": not a 64 based value");
|
throw TypeError(inValue + ": not a 64 based value");
|
||||||
}
|
}
|
||||||
|
@ -895,7 +895,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
// Any template literal or string literal with an extended escape
|
// Any template literal or string literal with an extended escape
|
||||||
// (e.g. "\u{0067}") will need to be downleveled as a escaped string literal.
|
// (e.g. "\u{0067}") will need to be downleveled as a escaped string literal.
|
||||||
if (languageVersion < ScriptTarget.ES6 && (isTemplateLiteralKind(node.kind) || node.hasExtendedUnicodeEscape)) {
|
if (languageVersion < ScriptTarget.ES6 && (isTemplateLiteralKind(node.kind) || node.hasExtendedUnicodeEscape)) {
|
||||||
return getQuotedEscapedLiteralText('"', node.text, '"');
|
return getQuotedEscapedLiteralText("\"", node.text, "\"");
|
||||||
}
|
}
|
||||||
|
|
||||||
// If we don't need to downlevel and we can reach the original source text using
|
// If we don't need to downlevel and we can reach the original source text using
|
||||||
|
@ -908,15 +908,15 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
// or an escaped quoted form of the original text if it's string-like.
|
// or an escaped quoted form of the original text if it's string-like.
|
||||||
switch (node.kind) {
|
switch (node.kind) {
|
||||||
case SyntaxKind.StringLiteral:
|
case SyntaxKind.StringLiteral:
|
||||||
return getQuotedEscapedLiteralText('"', node.text, '"');
|
return getQuotedEscapedLiteralText("\"", node.text, "\"");
|
||||||
case SyntaxKind.NoSubstitutionTemplateLiteral:
|
case SyntaxKind.NoSubstitutionTemplateLiteral:
|
||||||
return getQuotedEscapedLiteralText('`', node.text, '`');
|
return getQuotedEscapedLiteralText("`", node.text, "`");
|
||||||
case SyntaxKind.TemplateHead:
|
case SyntaxKind.TemplateHead:
|
||||||
return getQuotedEscapedLiteralText('`', node.text, '${');
|
return getQuotedEscapedLiteralText("`", node.text, "${");
|
||||||
case SyntaxKind.TemplateMiddle:
|
case SyntaxKind.TemplateMiddle:
|
||||||
return getQuotedEscapedLiteralText('}', node.text, '${');
|
return getQuotedEscapedLiteralText("}", node.text, "${");
|
||||||
case SyntaxKind.TemplateTail:
|
case SyntaxKind.TemplateTail:
|
||||||
return getQuotedEscapedLiteralText('}', node.text, '`');
|
return getQuotedEscapedLiteralText("}", node.text, "`");
|
||||||
case SyntaxKind.NumericLiteral:
|
case SyntaxKind.NumericLiteral:
|
||||||
return node.text;
|
return node.text;
|
||||||
}
|
}
|
||||||
|
@ -947,7 +947,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
text = text.replace(/\r\n?/g, "\n");
|
text = text.replace(/\r\n?/g, "\n");
|
||||||
text = escapeString(text);
|
text = escapeString(text);
|
||||||
|
|
||||||
write('"' + text + '"');
|
write(`"${text}"`);
|
||||||
}
|
}
|
||||||
|
|
||||||
function emitDownlevelTaggedTemplateArray(node: TaggedTemplateExpression, literalEmitter: (literal: LiteralExpression) => void) {
|
function emitDownlevelTaggedTemplateArray(node: TaggedTemplateExpression, literalEmitter: (literal: LiteralExpression) => void) {
|
||||||
|
@ -1134,9 +1134,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
/// 'Div' for upper-cased or dotted names
|
/// 'Div' for upper-cased or dotted names
|
||||||
function emitTagName(name: Identifier|QualifiedName) {
|
function emitTagName(name: Identifier|QualifiedName) {
|
||||||
if (name.kind === SyntaxKind.Identifier && isIntrinsicJsxName((<Identifier>name).text)) {
|
if (name.kind === SyntaxKind.Identifier && isIntrinsicJsxName((<Identifier>name).text)) {
|
||||||
write('"');
|
write("\"");
|
||||||
emit(name);
|
emit(name);
|
||||||
write('"');
|
write("\"");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
emit(name);
|
emit(name);
|
||||||
|
@ -1148,9 +1148,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
/// about keywords, just non-identifier characters
|
/// about keywords, just non-identifier characters
|
||||||
function emitAttributeName(name: Identifier) {
|
function emitAttributeName(name: Identifier) {
|
||||||
if (/[A-Za-z_]+[\w*]/.test(name.text)) {
|
if (/[A-Za-z_]+[\w*]/.test(name.text)) {
|
||||||
write('"');
|
write("\"");
|
||||||
emit(name);
|
emit(name);
|
||||||
write('"');
|
write("\"");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
emit(name);
|
emit(name);
|
||||||
|
@ -1249,9 +1249,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
if (children[i].kind === SyntaxKind.JsxText) {
|
if (children[i].kind === SyntaxKind.JsxText) {
|
||||||
let text = getTextToEmit(<JsxText>children[i]);
|
let text = getTextToEmit(<JsxText>children[i]);
|
||||||
if (text !== undefined) {
|
if (text !== undefined) {
|
||||||
write(', "');
|
write(", \"");
|
||||||
write(text);
|
write(text);
|
||||||
write('"');
|
write("\"");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -1491,7 +1491,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
if (declaration.kind === SyntaxKind.ImportClause) {
|
if (declaration.kind === SyntaxKind.ImportClause) {
|
||||||
// Identifier references default import
|
// Identifier references default import
|
||||||
write(getGeneratedNameForNode(<ImportDeclaration>declaration.parent));
|
write(getGeneratedNameForNode(<ImportDeclaration>declaration.parent));
|
||||||
write(languageVersion === ScriptTarget.ES3 ? '["default"]' : ".default");
|
write(languageVersion === ScriptTarget.ES3 ? "[\"default\"]" : ".default");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if (declaration.kind === SyntaxKind.ImportSpecifier) {
|
else if (declaration.kind === SyntaxKind.ImportSpecifier) {
|
||||||
|
@ -4270,11 +4270,12 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
emitDetachedComments(ctor.body.statements);
|
emitDetachedComments(ctor.body.statements);
|
||||||
}
|
}
|
||||||
emitCaptureThisForNodeIfNecessary(node);
|
emitCaptureThisForNodeIfNecessary(node);
|
||||||
|
let superCall: ExpressionStatement;
|
||||||
if (ctor) {
|
if (ctor) {
|
||||||
emitDefaultValueAssignments(ctor);
|
emitDefaultValueAssignments(ctor);
|
||||||
emitRestParameter(ctor);
|
emitRestParameter(ctor);
|
||||||
if (baseTypeElement) {
|
if (baseTypeElement) {
|
||||||
var superCall = findInitialSuperCall(ctor);
|
superCall = findInitialSuperCall(ctor);
|
||||||
if (superCall) {
|
if (superCall) {
|
||||||
writeLine();
|
writeLine();
|
||||||
emit(superCall);
|
emit(superCall);
|
||||||
|
@ -4951,7 +4952,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
let temp = createAndRecordTempVariable(TempFlags.Auto);
|
let temp = createAndRecordTempVariable(TempFlags.Auto);
|
||||||
write("(typeof (");
|
write("(typeof (");
|
||||||
emitNodeWithoutSourceMap(temp);
|
emitNodeWithoutSourceMap(temp);
|
||||||
write(" = ")
|
write(" = ");
|
||||||
emitEntityNameAsExpression(typeName, /*useFallback*/ true);
|
emitEntityNameAsExpression(typeName, /*useFallback*/ true);
|
||||||
write(") === 'function' && ");
|
write(") === 'function' && ");
|
||||||
emitNodeWithoutSourceMap(temp);
|
emitNodeWithoutSourceMap(temp);
|
||||||
|
@ -5010,7 +5011,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
//
|
//
|
||||||
// For the rules on serializing the type of each parameter declaration, see `serializeTypeOfDeclaration`.
|
// For the rules on serializing the type of each parameter declaration, see `serializeTypeOfDeclaration`.
|
||||||
if (node) {
|
if (node) {
|
||||||
var valueDeclaration: FunctionLikeDeclaration;
|
let valueDeclaration: FunctionLikeDeclaration;
|
||||||
if (node.kind === SyntaxKind.ClassDeclaration) {
|
if (node.kind === SyntaxKind.ClassDeclaration) {
|
||||||
valueDeclaration = getFirstConstructorWithBody(<ClassDeclaration>node);
|
valueDeclaration = getFirstConstructorWithBody(<ClassDeclaration>node);
|
||||||
}
|
}
|
||||||
|
@ -5019,8 +5020,8 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
}
|
}
|
||||||
|
|
||||||
if (valueDeclaration) {
|
if (valueDeclaration) {
|
||||||
var parameters = valueDeclaration.parameters;
|
const parameters = valueDeclaration.parameters;
|
||||||
var parameterCount = parameters.length;
|
const parameterCount = parameters.length;
|
||||||
if (parameterCount > 0) {
|
if (parameterCount > 0) {
|
||||||
for (var i = 0; i < parameterCount; i++) {
|
for (var i = 0; i < parameterCount; i++) {
|
||||||
if (i > 0) {
|
if (i > 0) {
|
||||||
|
@ -5028,7 +5029,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parameters[i].dotDotDotToken) {
|
if (parameters[i].dotDotDotToken) {
|
||||||
var parameterType = parameters[i].type;
|
let parameterType = parameters[i].type;
|
||||||
if (parameterType.kind === SyntaxKind.ArrayType) {
|
if (parameterType.kind === SyntaxKind.ArrayType) {
|
||||||
parameterType = (<ArrayTypeNode>parameterType).elementType;
|
parameterType = (<ArrayTypeNode>parameterType).elementType;
|
||||||
}
|
}
|
||||||
|
@ -5840,7 +5841,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
writeLine();
|
writeLine();
|
||||||
write("}");
|
write("}");
|
||||||
writeLine();
|
writeLine();
|
||||||
write(`${exportFunctionForFile}(exports);`)
|
write(`${exportFunctionForFile}(exports);`);
|
||||||
decreaseIndent();
|
decreaseIndent();
|
||||||
writeLine();
|
writeLine();
|
||||||
write("}");
|
write("}");
|
||||||
|
@ -6188,7 +6189,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
// exports_(reexports);
|
// exports_(reexports);
|
||||||
let reexportsVariableName = makeUniqueName("reexports");
|
let reexportsVariableName = makeUniqueName("reexports");
|
||||||
writeLine();
|
writeLine();
|
||||||
write(`var ${reexportsVariableName} = {};`)
|
write(`var ${reexportsVariableName} = {};`);
|
||||||
writeLine();
|
writeLine();
|
||||||
for (let e of (<ExportDeclaration>importNode).exportClause.elements) {
|
for (let e of (<ExportDeclaration>importNode).exportClause.elements) {
|
||||||
write(`${reexportsVariableName}["`);
|
write(`${reexportsVariableName}["`);
|
||||||
|
@ -6454,7 +6455,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
if (isLineBreak(c)) {
|
if (isLineBreak(c)) {
|
||||||
if (firstNonWhitespace !== -1 && (lastNonWhitespace - firstNonWhitespace + 1 > 0)) {
|
if (firstNonWhitespace !== -1 && (lastNonWhitespace - firstNonWhitespace + 1 > 0)) {
|
||||||
let part = text.substr(firstNonWhitespace, lastNonWhitespace - firstNonWhitespace + 1);
|
let part = text.substr(firstNonWhitespace, lastNonWhitespace - firstNonWhitespace + 1);
|
||||||
result = (result ? result + '" + \' \' + "' : '') + part;
|
result = (result ? result + "\" + ' ' + \"" : "") + part;
|
||||||
}
|
}
|
||||||
firstNonWhitespace = -1;
|
firstNonWhitespace = -1;
|
||||||
}
|
}
|
||||||
|
@ -6467,7 +6468,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
}
|
}
|
||||||
if (firstNonWhitespace !== -1) {
|
if (firstNonWhitespace !== -1) {
|
||||||
let part = text.substr(firstNonWhitespace);
|
let part = text.substr(firstNonWhitespace);
|
||||||
result = (result ? result + '" + \' \' + "' : '') + part;
|
result = (result ? result + "\" + ' ' + \"" : "") + part;
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
@ -6492,9 +6493,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
function emitJsxText(node: JsxText) {
|
function emitJsxText(node: JsxText) {
|
||||||
switch (compilerOptions.jsx) {
|
switch (compilerOptions.jsx) {
|
||||||
case JsxEmit.React:
|
case JsxEmit.React:
|
||||||
write('"');
|
write("\"");
|
||||||
write(trimReactWhitespace(node));
|
write(trimReactWhitespace(node));
|
||||||
write('"');
|
write("\"");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case JsxEmit.Preserve:
|
case JsxEmit.Preserve:
|
||||||
|
@ -6509,9 +6510,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, Promi
|
||||||
switch (compilerOptions.jsx) {
|
switch (compilerOptions.jsx) {
|
||||||
case JsxEmit.Preserve:
|
case JsxEmit.Preserve:
|
||||||
default:
|
default:
|
||||||
write('{');
|
write("{");
|
||||||
emit(node.expression);
|
emit(node.expression);
|
||||||
write('}');
|
write("}");
|
||||||
break;
|
break;
|
||||||
case JsxEmit.React:
|
case JsxEmit.React:
|
||||||
emit(node.expression);
|
emit(node.expression);
|
||||||
|
|
|
@ -3148,7 +3148,7 @@ namespace ts {
|
||||||
}
|
}
|
||||||
|
|
||||||
function parseAwaitExpression() {
|
function parseAwaitExpression() {
|
||||||
var node = <AwaitExpression>createNode(SyntaxKind.AwaitExpression);
|
const node = <AwaitExpression>createNode(SyntaxKind.AwaitExpression);
|
||||||
nextToken();
|
nextToken();
|
||||||
node.expression = parseUnaryExpressionOrHigher();
|
node.expression = parseUnaryExpressionOrHigher();
|
||||||
return finishNode(node);
|
return finishNode(node);
|
||||||
|
@ -3340,7 +3340,7 @@ namespace ts {
|
||||||
case SyntaxKind.LessThanToken:
|
case SyntaxKind.LessThanToken:
|
||||||
return parseJsxElementOrSelfClosingElement();
|
return parseJsxElementOrSelfClosingElement();
|
||||||
}
|
}
|
||||||
Debug.fail('Unknown JSX child kind ' + token);
|
Debug.fail("Unknown JSX child kind " + token);
|
||||||
}
|
}
|
||||||
|
|
||||||
function parseJsxChildren(openingTagName: EntityName): NodeArray<JsxChild> {
|
function parseJsxChildren(openingTagName: EntityName): NodeArray<JsxChild> {
|
||||||
|
@ -5140,7 +5140,7 @@ namespace ts {
|
||||||
// the 'from' keyword can be parsed as a named export when the export clause is unterminated (i.e. `export { from "moduleName";`)
|
// the 'from' keyword can be parsed as a named export when the export clause is unterminated (i.e. `export { from "moduleName";`)
|
||||||
// If we don't have a 'from' keyword, see if we have a string literal such that ASI won't take effect.
|
// If we don't have a 'from' keyword, see if we have a string literal such that ASI won't take effect.
|
||||||
if (token === SyntaxKind.FromKeyword || (token === SyntaxKind.StringLiteral && !scanner.hasPrecedingLineBreak())) {
|
if (token === SyntaxKind.FromKeyword || (token === SyntaxKind.StringLiteral && !scanner.hasPrecedingLineBreak())) {
|
||||||
parseExpected(SyntaxKind.FromKeyword)
|
parseExpected(SyntaxKind.FromKeyword);
|
||||||
node.moduleSpecifier = parseModuleSpecifier();
|
node.moduleSpecifier = parseModuleSpecifier();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6011,7 +6011,7 @@ namespace ts {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
function visitNode(node: IncrementalNode) {
|
function visitNode(node: IncrementalNode) {
|
||||||
let text = '';
|
let text = "";
|
||||||
if (aggressiveChecks && shouldCheckNode(node)) {
|
if (aggressiveChecks && shouldCheckNode(node)) {
|
||||||
text = oldText.substring(node.pos, node.end);
|
text = oldText.substring(node.pos, node.end);
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,7 +31,7 @@ namespace ts {
|
||||||
declare var __filename: string;
|
declare var __filename: string;
|
||||||
declare var Buffer: {
|
declare var Buffer: {
|
||||||
new (str: string, encoding?: string): any;
|
new (str: string, encoding?: string): any;
|
||||||
}
|
};
|
||||||
|
|
||||||
declare class Enumerator {
|
declare class Enumerator {
|
||||||
public atEnd(): boolean;
|
public atEnd(): boolean;
|
||||||
|
@ -188,13 +188,13 @@ namespace ts {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
function getNodeSystem(): System {
|
function getNodeSystem(): System {
|
||||||
var _fs = require("fs");
|
const _fs = require("fs");
|
||||||
var _path = require("path");
|
const _path = require("path");
|
||||||
var _os = require('os');
|
const _os = require("os");
|
||||||
|
|
||||||
var platform: string = _os.platform();
|
const platform: string = _os.platform();
|
||||||
// win32\win64 are case insensitive platforms, MacOS (darwin) by default is also case insensitive
|
// win32\win64 are case insensitive platforms, MacOS (darwin) by default is also case insensitive
|
||||||
var useCaseSensitiveFileNames = platform !== "win32" && platform !== "win64" && platform !== "darwin";
|
const useCaseSensitiveFileNames = platform !== "win32" && platform !== "win64" && platform !== "darwin";
|
||||||
|
|
||||||
function readFile(fileName: string, encoding?: string): string {
|
function readFile(fileName: string, encoding?: string): string {
|
||||||
if (!_fs.existsSync(fileName)) {
|
if (!_fs.existsSync(fileName)) {
|
||||||
|
@ -228,7 +228,7 @@ namespace ts {
|
||||||
function writeFile(fileName: string, data: string, writeByteOrderMark?: boolean): void {
|
function writeFile(fileName: string, data: string, writeByteOrderMark?: boolean): void {
|
||||||
// If a BOM is required, emit one
|
// If a BOM is required, emit one
|
||||||
if (writeByteOrderMark) {
|
if (writeByteOrderMark) {
|
||||||
data = '\uFEFF' + data;
|
data = "\uFEFF" + data;
|
||||||
}
|
}
|
||||||
|
|
||||||
_fs.writeFileSync(fileName, data, "utf8");
|
_fs.writeFileSync(fileName, data, "utf8");
|
||||||
|
@ -271,10 +271,10 @@ namespace ts {
|
||||||
newLine: _os.EOL,
|
newLine: _os.EOL,
|
||||||
useCaseSensitiveFileNames: useCaseSensitiveFileNames,
|
useCaseSensitiveFileNames: useCaseSensitiveFileNames,
|
||||||
write(s: string): void {
|
write(s: string): void {
|
||||||
var buffer = new Buffer(s, 'utf8');
|
const buffer = new Buffer(s, "utf8");
|
||||||
var offset: number = 0;
|
let offset: number = 0;
|
||||||
var toWrite: number = buffer.length;
|
let toWrite: number = buffer.length;
|
||||||
var written = 0;
|
let written = 0;
|
||||||
// 1 is a standard descriptor for stdout
|
// 1 is a standard descriptor for stdout
|
||||||
while ((written = _fs.writeSync(1, buffer, offset, toWrite)) < toWrite) {
|
while ((written = _fs.writeSync(1, buffer, offset, toWrite)) < toWrite) {
|
||||||
offset += written;
|
offset += written;
|
||||||
|
@ -297,7 +297,7 @@ namespace ts {
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(fileName);
|
callback(fileName);
|
||||||
};
|
}
|
||||||
},
|
},
|
||||||
resolvePath: function (path: string): string {
|
resolvePath: function (path: string): string {
|
||||||
return _path.resolve(path);
|
return _path.resolve(path);
|
||||||
|
|
|
@ -1866,7 +1866,7 @@ namespace ts {
|
||||||
|
|
||||||
function writeTrimmedCurrentLine(pos: number, nextLineStart: number) {
|
function writeTrimmedCurrentLine(pos: number, nextLineStart: number) {
|
||||||
let end = Math.min(comment.end, nextLineStart - 1);
|
let end = Math.min(comment.end, nextLineStart - 1);
|
||||||
let currentLineText = currentSourceFile.text.substring(pos, end).replace(/^\s+|\s+$/g, '');
|
let currentLineText = currentSourceFile.text.substring(pos, end).replace(/^\s+|\s+$/g, "");
|
||||||
if (currentLineText) {
|
if (currentLineText) {
|
||||||
// trimmed forward and ending spaces text
|
// trimmed forward and ending spaces text
|
||||||
writer.write(currentLineText);
|
writer.write(currentLineText);
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/// <reference path='harness.ts' />
|
/// <reference path="harness.ts" />
|
||||||
/// <reference path='runnerbase.ts' />
|
/// <reference path="runnerbase.ts" />
|
||||||
/// <reference path='typeWriter.ts' />
|
/// <reference path="typeWriter.ts" />
|
||||||
|
|
||||||
const enum CompilerTestType {
|
const enum CompilerTestType {
|
||||||
Conformance,
|
Conformance,
|
||||||
|
@ -9,7 +9,7 @@ const enum CompilerTestType {
|
||||||
}
|
}
|
||||||
|
|
||||||
class CompilerBaselineRunner extends RunnerBase {
|
class CompilerBaselineRunner extends RunnerBase {
|
||||||
private basePath = 'tests/cases';
|
private basePath = "tests/cases";
|
||||||
private testSuiteName: string;
|
private testSuiteName: string;
|
||||||
private errors: boolean;
|
private errors: boolean;
|
||||||
private emit: boolean;
|
private emit: boolean;
|
||||||
|
@ -25,21 +25,21 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
this.decl = true;
|
this.decl = true;
|
||||||
this.output = true;
|
this.output = true;
|
||||||
if (testType === CompilerTestType.Conformance) {
|
if (testType === CompilerTestType.Conformance) {
|
||||||
this.testSuiteName = 'conformance';
|
this.testSuiteName = "conformance";
|
||||||
}
|
}
|
||||||
else if (testType === CompilerTestType.Regressions) {
|
else if (testType === CompilerTestType.Regressions) {
|
||||||
this.testSuiteName = 'compiler';
|
this.testSuiteName = "compiler";
|
||||||
}
|
}
|
||||||
else if (testType === CompilerTestType.Test262) {
|
else if (testType === CompilerTestType.Test262) {
|
||||||
this.testSuiteName = 'test262';
|
this.testSuiteName = "test262";
|
||||||
} else {
|
} else {
|
||||||
this.testSuiteName = 'compiler'; // default to this for historical reasons
|
this.testSuiteName = "compiler"; // default to this for historical reasons
|
||||||
}
|
}
|
||||||
this.basePath += '/' + this.testSuiteName;
|
this.basePath += "/" + this.testSuiteName;
|
||||||
}
|
}
|
||||||
|
|
||||||
public checkTestCodeOutput(fileName: string) {
|
public checkTestCodeOutput(fileName: string) {
|
||||||
describe('compiler tests for ' + fileName, () => {
|
describe("compiler tests for " + fileName, () => {
|
||||||
// Mocha holds onto the closure environment of the describe callback even after the test is done.
|
// Mocha holds onto the closure environment of the describe callback even after the test is done.
|
||||||
// Everything declared here should be cleared out in the "after" callback.
|
// Everything declared here should be cleared out in the "after" callback.
|
||||||
let justName: string;
|
let justName: string;
|
||||||
|
@ -64,14 +64,14 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
let createNewInstance = false;
|
let createNewInstance = false;
|
||||||
|
|
||||||
before(() => {
|
before(() => {
|
||||||
justName = fileName.replace(/^.*[\\\/]/, ''); // strips the fileName from the path.
|
justName = fileName.replace(/^.*[\\\/]/, ""); // strips the fileName from the path.
|
||||||
content = Harness.IO.readFile(fileName);
|
content = Harness.IO.readFile(fileName);
|
||||||
testCaseContent = Harness.TestCaseParser.makeUnitsFromTest(content, fileName);
|
testCaseContent = Harness.TestCaseParser.makeUnitsFromTest(content, fileName);
|
||||||
units = testCaseContent.testUnitData;
|
units = testCaseContent.testUnitData;
|
||||||
tcSettings = testCaseContent.settings;
|
tcSettings = testCaseContent.settings;
|
||||||
createNewInstance = false;
|
createNewInstance = false;
|
||||||
lastUnit = units[units.length - 1];
|
lastUnit = units[units.length - 1];
|
||||||
rootDir = lastUnit.originalFilePath.indexOf('conformance') === -1 ? 'tests/cases/compiler/' : lastUnit.originalFilePath.substring(0, lastUnit.originalFilePath.lastIndexOf('/')) + '/';
|
rootDir = lastUnit.originalFilePath.indexOf("conformance") === -1 ? "tests/cases/compiler/" : lastUnit.originalFilePath.substring(0, lastUnit.originalFilePath.lastIndexOf("/")) + "/";
|
||||||
harnessCompiler = Harness.Compiler.getCompiler();
|
harnessCompiler = Harness.Compiler.getCompiler();
|
||||||
// We need to assemble the list of input files for the compiler and other related files on the 'filesystem' (ie in a multi-file test)
|
// We need to assemble the list of input files for the compiler and other related files on the 'filesystem' (ie in a multi-file test)
|
||||||
// If the last file in a test uses require or a triple slash reference we'll assume all other files will be brought in via references,
|
// If the last file in a test uses require or a triple slash reference we'll assume all other files will be brought in via references,
|
||||||
|
@ -106,7 +106,7 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
eventually to remove this limitation. */
|
eventually to remove this limitation. */
|
||||||
for (let i = 0; i < tcSettings.length; ++i) {
|
for (let i = 0; i < tcSettings.length; ++i) {
|
||||||
// noImplicitAny is passed to getCompiler, but target is just passed in the settings blob to setCompilerSettings
|
// noImplicitAny is passed to getCompiler, but target is just passed in the settings blob to setCompilerSettings
|
||||||
if (!createNewInstance && (tcSettings[i].flag == "noimplicitany" || tcSettings[i].flag === 'target')) {
|
if (!createNewInstance && (tcSettings[i].flag == "noimplicitany" || tcSettings[i].flag === "target")) {
|
||||||
harnessCompiler = Harness.Compiler.getCompiler();
|
harnessCompiler = Harness.Compiler.getCompiler();
|
||||||
harnessCompiler.setCompilerSettings(tcSettings);
|
harnessCompiler.setCompilerSettings(tcSettings);
|
||||||
createNewInstance = true;
|
createNewInstance = true;
|
||||||
|
@ -148,9 +148,9 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
// check errors
|
// check errors
|
||||||
it('Correct errors for ' + fileName, () => {
|
it("Correct errors for " + fileName, () => {
|
||||||
if (this.errors) {
|
if (this.errors) {
|
||||||
Harness.Baseline.runBaseline('Correct errors for ' + fileName, justName.replace(/\.tsx?$/, '.errors.txt'), (): string => {
|
Harness.Baseline.runBaseline("Correct errors for " + fileName, justName.replace(/\.tsx?$/, ".errors.txt"), (): string => {
|
||||||
if (result.errors.length === 0) return null;
|
if (result.errors.length === 0) return null;
|
||||||
return getErrorBaseline(toBeCompiled, otherFiles, result);
|
return getErrorBaseline(toBeCompiled, otherFiles, result);
|
||||||
});
|
});
|
||||||
|
@ -158,12 +158,12 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Source maps?
|
// Source maps?
|
||||||
it('Correct sourcemap content for ' + fileName, () => {
|
it("Correct sourcemap content for " + fileName, () => {
|
||||||
if (options.sourceMap || options.inlineSourceMap) {
|
if (options.sourceMap || options.inlineSourceMap) {
|
||||||
Harness.Baseline.runBaseline('Correct sourcemap content for ' + fileName, justName.replace(/\.tsx?$/, '.sourcemap.txt'), () => {
|
Harness.Baseline.runBaseline("Correct sourcemap content for " + fileName, justName.replace(/\.tsx?$/, ".sourcemap.txt"), () => {
|
||||||
let record = result.getSourceMapRecord();
|
let record = result.getSourceMapRecord();
|
||||||
if (options.noEmitOnError && result.errors.length !== 0 && record === undefined) {
|
if (options.noEmitOnError && result.errors.length !== 0 && record === undefined) {
|
||||||
// Because of the noEmitOnError option no files are created. We need to return null because baselining isn't required.
|
// Because of the noEmitOnError option no files are created. We need to return null because baselining isn"t required.
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return record;
|
return record;
|
||||||
|
@ -171,35 +171,35 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Correct JS output for ' + fileName, () => {
|
it("Correct JS output for " + fileName, () => {
|
||||||
if (!ts.fileExtensionIs(lastUnit.name, '.d.ts') && this.emit) {
|
if (!ts.fileExtensionIs(lastUnit.name, ".d.ts") && this.emit) {
|
||||||
if (result.files.length === 0 && result.errors.length === 0) {
|
if (result.files.length === 0 && result.errors.length === 0) {
|
||||||
throw new Error('Expected at least one js file to be emitted or at least one error to be created.');
|
throw new Error("Expected at least one js file to be emitted or at least one error to be created.");
|
||||||
}
|
}
|
||||||
|
|
||||||
// check js output
|
// check js output
|
||||||
Harness.Baseline.runBaseline('Correct JS output for ' + fileName, justName.replace(/\.tsx?/, '.js'), () => {
|
Harness.Baseline.runBaseline("Correct JS output for " + fileName, justName.replace(/\.tsx?/, ".js"), () => {
|
||||||
let tsCode = '';
|
let tsCode = "";
|
||||||
let tsSources = otherFiles.concat(toBeCompiled);
|
let tsSources = otherFiles.concat(toBeCompiled);
|
||||||
if (tsSources.length > 1) {
|
if (tsSources.length > 1) {
|
||||||
tsCode += '//// [' + fileName + '] ////\r\n\r\n';
|
tsCode += "//// [" + fileName + "] ////\r\n\r\n";
|
||||||
}
|
}
|
||||||
for (let i = 0; i < tsSources.length; i++) {
|
for (let i = 0; i < tsSources.length; i++) {
|
||||||
tsCode += '//// [' + Harness.Path.getFileName(tsSources[i].unitName) + ']\r\n';
|
tsCode += "//// [" + Harness.Path.getFileName(tsSources[i].unitName) + "]\r\n";
|
||||||
tsCode += tsSources[i].content + (i < (tsSources.length - 1) ? '\r\n' : '');
|
tsCode += tsSources[i].content + (i < (tsSources.length - 1) ? "\r\n" : "");
|
||||||
}
|
}
|
||||||
|
|
||||||
let jsCode = '';
|
let jsCode = "";
|
||||||
for (let i = 0; i < result.files.length; i++) {
|
for (let i = 0; i < result.files.length; i++) {
|
||||||
jsCode += '//// [' + Harness.Path.getFileName(result.files[i].fileName) + ']\r\n';
|
jsCode += "//// [" + Harness.Path.getFileName(result.files[i].fileName) + "]\r\n";
|
||||||
jsCode += getByteOrderMarkText(result.files[i]);
|
jsCode += getByteOrderMarkText(result.files[i]);
|
||||||
jsCode += result.files[i].code;
|
jsCode += result.files[i].code;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result.declFilesCode.length > 0) {
|
if (result.declFilesCode.length > 0) {
|
||||||
jsCode += '\r\n\r\n';
|
jsCode += "\r\n\r\n";
|
||||||
for (let i = 0; i < result.declFilesCode.length; i++) {
|
for (let i = 0; i < result.declFilesCode.length; i++) {
|
||||||
jsCode += '//// [' + Harness.Path.getFileName(result.declFilesCode[i].fileName) + ']\r\n';
|
jsCode += "//// [" + Harness.Path.getFileName(result.declFilesCode[i].fileName) + "]\r\n";
|
||||||
jsCode += getByteOrderMarkText(result.declFilesCode[i]);
|
jsCode += getByteOrderMarkText(result.declFilesCode[i]);
|
||||||
jsCode += result.declFilesCode[i].code;
|
jsCode += result.declFilesCode[i].code;
|
||||||
}
|
}
|
||||||
|
@ -210,13 +210,13 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
}, options);
|
}, options);
|
||||||
|
|
||||||
if (declFileCompilationResult && declFileCompilationResult.declResult.errors.length) {
|
if (declFileCompilationResult && declFileCompilationResult.declResult.errors.length) {
|
||||||
jsCode += '\r\n\r\n//// [DtsFileErrors]\r\n';
|
jsCode += "\r\n\r\n//// [DtsFileErrors]\r\n";
|
||||||
jsCode += '\r\n\r\n';
|
jsCode += "\r\n\r\n";
|
||||||
jsCode += getErrorBaseline(declFileCompilationResult.declInputFiles, declFileCompilationResult.declOtherFiles, declFileCompilationResult.declResult);
|
jsCode += getErrorBaseline(declFileCompilationResult.declInputFiles, declFileCompilationResult.declOtherFiles, declFileCompilationResult.declResult);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (jsCode.length > 0) {
|
if (jsCode.length > 0) {
|
||||||
return tsCode + '\r\n\r\n' + jsCode;
|
return tsCode + "\r\n\r\n" + jsCode;
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -224,28 +224,28 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Correct Sourcemap output for ' + fileName, () => {
|
it("Correct Sourcemap output for " + fileName, () => {
|
||||||
if (options.inlineSourceMap) {
|
if (options.inlineSourceMap) {
|
||||||
if (result.sourceMaps.length > 0) {
|
if (result.sourceMaps.length > 0) {
|
||||||
throw new Error('No sourcemap files should be generated if inlineSourceMaps was set.');
|
throw new Error("No sourcemap files should be generated if inlineSourceMaps was set.");
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
else if (options.sourceMap) {
|
else if (options.sourceMap) {
|
||||||
if (result.sourceMaps.length !== result.files.length) {
|
if (result.sourceMaps.length !== result.files.length) {
|
||||||
throw new Error('Number of sourcemap files should be same as js files.');
|
throw new Error("Number of sourcemap files should be same as js files.");
|
||||||
}
|
}
|
||||||
|
|
||||||
Harness.Baseline.runBaseline('Correct Sourcemap output for ' + fileName, justName.replace(/\.tsx?/, '.js.map'), () => {
|
Harness.Baseline.runBaseline("Correct Sourcemap output for " + fileName, justName.replace(/\.tsx?/, ".js.map"), () => {
|
||||||
if (options.noEmitOnError && result.errors.length !== 0 && result.sourceMaps.length === 0) {
|
if (options.noEmitOnError && result.errors.length !== 0 && result.sourceMaps.length === 0) {
|
||||||
// We need to return null here or the runBaseLine will actually create a empty file.
|
// We need to return null here or the runBaseLine will actually create a empty file.
|
||||||
// Baselining isn't required here because there is no output.
|
// Baselining isn't required here because there is no output.
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
let sourceMapCode = '';
|
let sourceMapCode = "";
|
||||||
for (let i = 0; i < result.sourceMaps.length; i++) {
|
for (let i = 0; i < result.sourceMaps.length; i++) {
|
||||||
sourceMapCode += '//// [' + Harness.Path.getFileName(result.sourceMaps[i].fileName) + ']\r\n';
|
sourceMapCode += "//// [" + Harness.Path.getFileName(result.sourceMaps[i].fileName) + "]\r\n";
|
||||||
sourceMapCode += getByteOrderMarkText(result.sourceMaps[i]);
|
sourceMapCode += getByteOrderMarkText(result.sourceMaps[i]);
|
||||||
sourceMapCode += result.sourceMaps[i].code;
|
sourceMapCode += result.sourceMaps[i].code;
|
||||||
}
|
}
|
||||||
|
@ -255,7 +255,7 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Correct type/symbol baselines for ' + fileName, () => {
|
it("Correct type/symbol baselines for " + fileName, () => {
|
||||||
if (fileName.indexOf("APISample") >= 0) {
|
if (fileName.indexOf("APISample") >= 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -317,15 +317,15 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
let fullBaseLine = generateBaseLine(fullResults, isSymbolBaseLine);
|
let fullBaseLine = generateBaseLine(fullResults, isSymbolBaseLine);
|
||||||
let pullBaseLine = generateBaseLine(pullResults, isSymbolBaseLine);
|
let pullBaseLine = generateBaseLine(pullResults, isSymbolBaseLine);
|
||||||
|
|
||||||
let fullExtension = isSymbolBaseLine ? '.symbols' : '.types';
|
let fullExtension = isSymbolBaseLine ? ".symbols" : ".types";
|
||||||
let pullExtension = isSymbolBaseLine ? '.symbols.pull' : '.types.pull';
|
let pullExtension = isSymbolBaseLine ? ".symbols.pull" : ".types.pull";
|
||||||
|
|
||||||
if (fullBaseLine !== pullBaseLine) {
|
if (fullBaseLine !== pullBaseLine) {
|
||||||
Harness.Baseline.runBaseline('Correct full information for ' + fileName, justName.replace(/\.tsx?/, fullExtension), () => fullBaseLine);
|
Harness.Baseline.runBaseline("Correct full information for " + fileName, justName.replace(/\.tsx?/, fullExtension), () => fullBaseLine);
|
||||||
Harness.Baseline.runBaseline('Correct pull information for ' + fileName, justName.replace(/\.tsx?/, pullExtension), () => pullBaseLine);
|
Harness.Baseline.runBaseline("Correct pull information for " + fileName, justName.replace(/\.tsx?/, pullExtension), () => pullBaseLine);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Harness.Baseline.runBaseline('Correct information for ' + fileName, justName.replace(/\.tsx?/, fullExtension), () => fullBaseLine);
|
Harness.Baseline.runBaseline("Correct information for " + fileName, justName.replace(/\.tsx?/, fullExtension), () => fullBaseLine);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -334,7 +334,7 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
let typeMap: { [fileName: string]: { [lineNum: number]: string[]; } } = {};
|
let typeMap: { [fileName: string]: { [lineNum: number]: string[]; } } = {};
|
||||||
|
|
||||||
allFiles.forEach(file => {
|
allFiles.forEach(file => {
|
||||||
let codeLines = file.content.split('\n');
|
let codeLines = file.content.split("\n");
|
||||||
typeWriterResults[file.unitName].forEach(result => {
|
typeWriterResults[file.unitName].forEach(result => {
|
||||||
if (isSymbolBaseline && !result.symbol) {
|
if (isSymbolBaseline && !result.symbol) {
|
||||||
return;
|
return;
|
||||||
|
@ -354,30 +354,30 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
typeMap[file.unitName][result.line] = typeInfo;
|
typeMap[file.unitName][result.line] = typeInfo;
|
||||||
});
|
});
|
||||||
|
|
||||||
typeLines.push('=== ' + file.unitName + ' ===\r\n');
|
typeLines.push("=== " + file.unitName + " ===\r\n");
|
||||||
for (let i = 0; i < codeLines.length; i++) {
|
for (let i = 0; i < codeLines.length; i++) {
|
||||||
let currentCodeLine = codeLines[i];
|
let currentCodeLine = codeLines[i];
|
||||||
typeLines.push(currentCodeLine + '\r\n');
|
typeLines.push(currentCodeLine + "\r\n");
|
||||||
if (typeMap[file.unitName]) {
|
if (typeMap[file.unitName]) {
|
||||||
let typeInfo = typeMap[file.unitName][i];
|
let typeInfo = typeMap[file.unitName][i];
|
||||||
if (typeInfo) {
|
if (typeInfo) {
|
||||||
typeInfo.forEach(ty => {
|
typeInfo.forEach(ty => {
|
||||||
typeLines.push('>' + ty + '\r\n');
|
typeLines.push(">" + ty + "\r\n");
|
||||||
});
|
});
|
||||||
if (i + 1 < codeLines.length && (codeLines[i + 1].match(/^\s*[{|}]\s*$/) || codeLines[i + 1].trim() === '')) {
|
if (i + 1 < codeLines.length && (codeLines[i + 1].match(/^\s*[{|}]\s*$/) || codeLines[i + 1].trim() === "")) {
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
typeLines.push('\r\n');
|
typeLines.push("\r\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
typeLines.push('No type information for this code.');
|
typeLines.push("No type information for this code.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
return typeLines.join('');
|
return typeLines.join("");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -385,7 +385,7 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public initializeTests() {
|
public initializeTests() {
|
||||||
describe(this.testSuiteName + ' tests', () => {
|
describe(this.testSuiteName + " tests", () => {
|
||||||
describe("Setup compiler for compiler baselines", () => {
|
describe("Setup compiler for compiler baselines", () => {
|
||||||
let harnessCompiler = Harness.Compiler.getCompiler();
|
let harnessCompiler = Harness.Compiler.getCompiler();
|
||||||
this.parseOptions();
|
this.parseOptions();
|
||||||
|
@ -416,23 +416,23 @@ class CompilerBaselineRunner extends RunnerBase {
|
||||||
this.decl = false;
|
this.decl = false;
|
||||||
this.output = false;
|
this.output = false;
|
||||||
|
|
||||||
let opts = this.options.split(',');
|
let opts = this.options.split(",");
|
||||||
for (let i = 0; i < opts.length; i++) {
|
for (let i = 0; i < opts.length; i++) {
|
||||||
switch (opts[i]) {
|
switch (opts[i]) {
|
||||||
case 'error':
|
case "error":
|
||||||
this.errors = true;
|
this.errors = true;
|
||||||
break;
|
break;
|
||||||
case 'emit':
|
case "emit":
|
||||||
this.emit = true;
|
this.emit = true;
|
||||||
break;
|
break;
|
||||||
case 'decl':
|
case "decl":
|
||||||
this.decl = true;
|
this.decl = true;
|
||||||
break;
|
break;
|
||||||
case 'output':
|
case "output":
|
||||||
this.output = true;
|
this.output = true;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new Error('unsupported flag');
|
throw new Error("unsupported flag");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,6 +1,6 @@
|
||||||
///<reference path='fourslash.ts' />
|
///<reference path="fourslash.ts" />
|
||||||
///<reference path='harness.ts'/>
|
///<reference path="harness.ts"/>
|
||||||
///<reference path='runnerbase.ts' />
|
///<reference path="runnerbase.ts" />
|
||||||
|
|
||||||
const enum FourSlashTestType {
|
const enum FourSlashTestType {
|
||||||
Native,
|
Native,
|
||||||
|
@ -16,16 +16,16 @@ class FourSlashRunner extends RunnerBase {
|
||||||
super();
|
super();
|
||||||
switch (testType) {
|
switch (testType) {
|
||||||
case FourSlashTestType.Native:
|
case FourSlashTestType.Native:
|
||||||
this.basePath = 'tests/cases/fourslash';
|
this.basePath = "tests/cases/fourslash";
|
||||||
this.testSuiteName = 'fourslash';
|
this.testSuiteName = "fourslash";
|
||||||
break;
|
break;
|
||||||
case FourSlashTestType.Shims:
|
case FourSlashTestType.Shims:
|
||||||
this.basePath = 'tests/cases/fourslash/shims';
|
this.basePath = "tests/cases/fourslash/shims";
|
||||||
this.testSuiteName = 'fourslash-shims';
|
this.testSuiteName = "fourslash-shims";
|
||||||
break;
|
break;
|
||||||
case FourSlashTestType.Server:
|
case FourSlashTestType.Server:
|
||||||
this.basePath = 'tests/cases/fourslash/server';
|
this.basePath = "tests/cases/fourslash/server";
|
||||||
this.testSuiteName = 'fourslash-server';
|
this.testSuiteName = "fourslash-server";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -35,25 +35,25 @@ class FourSlashRunner extends RunnerBase {
|
||||||
this.tests = this.enumerateFiles(this.basePath, /\.ts/i, { recursive: false });
|
this.tests = this.enumerateFiles(this.basePath, /\.ts/i, { recursive: false });
|
||||||
}
|
}
|
||||||
|
|
||||||
describe(this.testSuiteName + ' tests', () => {
|
describe(this.testSuiteName + " tests", () => {
|
||||||
this.tests.forEach((fn: string) => {
|
this.tests.forEach((fn: string) => {
|
||||||
describe(fn, () => {
|
describe(fn, () => {
|
||||||
fn = ts.normalizeSlashes(fn);
|
fn = ts.normalizeSlashes(fn);
|
||||||
let justName = fn.replace(/^.*[\\\/]/, '');
|
let justName = fn.replace(/^.*[\\\/]/, "");
|
||||||
|
|
||||||
// Convert to relative path
|
// Convert to relative path
|
||||||
let testIndex = fn.indexOf('tests/');
|
let testIndex = fn.indexOf("tests/");
|
||||||
if (testIndex >= 0) fn = fn.substr(testIndex);
|
if (testIndex >= 0) fn = fn.substr(testIndex);
|
||||||
|
|
||||||
if (justName && !justName.match(/fourslash\.ts$/i) && !justName.match(/\.d\.ts$/i)) {
|
if (justName && !justName.match(/fourslash\.ts$/i) && !justName.match(/\.d\.ts$/i)) {
|
||||||
it(this.testSuiteName + ' test ' + justName + ' runs correctly', () => {
|
it(this.testSuiteName + " test " + justName + " runs correctly", () => {
|
||||||
FourSlash.runFourSlashTest(this.basePath, this.testType, fn);
|
FourSlash.runFourSlashTest(this.basePath, this.testType, fn);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('Generate Tao XML', () => {
|
describe("Generate Tao XML", () => {
|
||||||
let invalidReasons: any = {};
|
let invalidReasons: any = {};
|
||||||
FourSlash.xmlData.forEach(xml => {
|
FourSlash.xmlData.forEach(xml => {
|
||||||
if (xml.invalidReason !== null) {
|
if (xml.invalidReason !== null) {
|
||||||
|
@ -69,37 +69,37 @@ class FourSlashRunner extends RunnerBase {
|
||||||
invalidReport.sort((lhs, rhs) => lhs.count > rhs.count ? -1 : lhs.count === rhs.count ? 0 : 1);
|
invalidReport.sort((lhs, rhs) => lhs.count > rhs.count ? -1 : lhs.count === rhs.count ? 0 : 1);
|
||||||
|
|
||||||
let lines: string[] = [];
|
let lines: string[] = [];
|
||||||
lines.push('<!-- Blocked Test Report');
|
lines.push("<!-- Blocked Test Report");
|
||||||
invalidReport.forEach((reasonAndCount) => {
|
invalidReport.forEach((reasonAndCount) => {
|
||||||
lines.push(reasonAndCount.count + ' tests blocked by ' + reasonAndCount.reason);
|
lines.push(reasonAndCount.count + " tests blocked by " + reasonAndCount.reason);
|
||||||
});
|
});
|
||||||
lines.push('-->');
|
lines.push("-->");
|
||||||
lines.push('<TaoTest xmlns="http://microsoft.com/schemas/VSLanguages/TAO">');
|
lines.push("<TaoTest xmlns=\"http://microsoft.com/schemas/VSLanguages/TAO\">");
|
||||||
lines.push(' <InitTest>');
|
lines.push(" <InitTest>");
|
||||||
lines.push(' <StartTarget />');
|
lines.push(" <StartTarget />");
|
||||||
lines.push(' </InitTest>');
|
lines.push(" </InitTest>");
|
||||||
lines.push(' <ScenarioList>');
|
lines.push(" <ScenarioList>");
|
||||||
FourSlash.xmlData.forEach(xml => {
|
FourSlash.xmlData.forEach(xml => {
|
||||||
if (xml.invalidReason !== null) {
|
if (xml.invalidReason !== null) {
|
||||||
lines.push('<!-- Skipped ' + xml.originalName + ', reason: ' + xml.invalidReason + ' -->');
|
lines.push("<!-- Skipped " + xml.originalName + ", reason: " + xml.invalidReason + " -->");
|
||||||
} else {
|
} else {
|
||||||
lines.push(' <Scenario Name="' + xml.originalName + '">');
|
lines.push(" <Scenario Name=\"" + xml.originalName + "\">");
|
||||||
xml.actions.forEach(action => {
|
xml.actions.forEach(action => {
|
||||||
lines.push(' ' + action);
|
lines.push(" " + action);
|
||||||
});
|
});
|
||||||
lines.push(' </Scenario>');
|
lines.push(" </Scenario>");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
lines.push(' </ScenarioList>');
|
lines.push(" </ScenarioList>");
|
||||||
lines.push(' <CleanupScenario>');
|
lines.push(" <CleanupScenario>");
|
||||||
lines.push(' <CloseAllDocuments />');
|
lines.push(" <CloseAllDocuments />");
|
||||||
lines.push(' <CleanupCreatedFiles />');
|
lines.push(" <CleanupCreatedFiles />");
|
||||||
lines.push(' </CleanupScenario>');
|
lines.push(" </CleanupScenario>");
|
||||||
lines.push(' <CleanupTest>');
|
lines.push(" <CleanupTest>");
|
||||||
lines.push(' <CloseTarget />');
|
lines.push(" <CloseTarget />");
|
||||||
lines.push(' </CleanupTest>');
|
lines.push(" </CleanupTest>");
|
||||||
lines.push('</TaoTest>');
|
lines.push("</TaoTest>");
|
||||||
Harness.IO.writeFile('built/local/fourslash.xml', lines.join('\r\n'));
|
Harness.IO.writeFile("built/local/fourslash.xml", lines.join("\r\n"));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -108,6 +108,6 @@ class FourSlashRunner extends RunnerBase {
|
||||||
class GeneratedFourslashRunner extends FourSlashRunner {
|
class GeneratedFourslashRunner extends FourSlashRunner {
|
||||||
constructor(testType: FourSlashTestType) {
|
constructor(testType: FourSlashTestType) {
|
||||||
super(testType);
|
super(testType);
|
||||||
this.basePath += '/generated/';
|
this.basePath += "/generated/";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,24 +14,27 @@
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
//
|
//
|
||||||
|
|
||||||
/// <reference path='..\services\services.ts' />
|
/// <reference path="..\services\services.ts" />
|
||||||
/// <reference path='..\services\shims.ts' />
|
/// <reference path="..\services\shims.ts" />
|
||||||
/// <reference path='..\server\session.ts' />
|
/// <reference path="..\server\session.ts" />
|
||||||
/// <reference path='..\server\client.ts' />
|
/// <reference path="..\server\client.ts" />
|
||||||
/// <reference path='..\server\node.d.ts' />
|
/// <reference path="..\server\node.d.ts" />
|
||||||
/// <reference path='external\mocha.d.ts'/>
|
/// <reference path="external\mocha.d.ts"/>
|
||||||
/// <reference path='external\chai.d.ts'/>
|
/// <reference path="external\chai.d.ts"/>
|
||||||
/// <reference path='sourceMapRecorder.ts'/>
|
/// <reference path="sourceMapRecorder.ts"/>
|
||||||
/// <reference path='runnerbase.ts'/>
|
/// <reference path="runnerbase.ts"/>
|
||||||
|
|
||||||
var Buffer: BufferConstructor = require('buffer').Buffer;
|
// Block scoped definitions work poorly for global variables, temporarily enable var
|
||||||
|
/* tslint:disable:no-var-keyword */
|
||||||
|
var Buffer: BufferConstructor = require("buffer").Buffer;
|
||||||
|
|
||||||
// this will work in the browser via browserify
|
// this will work in the browser via browserify
|
||||||
var _chai: typeof chai = require('chai');
|
var _chai: typeof chai = require("chai");
|
||||||
var assert: typeof _chai.assert = _chai.assert;
|
var assert: typeof _chai.assert = _chai.assert;
|
||||||
var expect: typeof _chai.expect = _chai.expect;
|
var expect: typeof _chai.expect = _chai.expect;
|
||||||
declare var __dirname: string; // Node-specific
|
declare var __dirname: string; // Node-specific
|
||||||
var global = <any>Function("return this").call(null);
|
var global = <any>Function("return this").call(null);
|
||||||
|
/* tslint:enable:no-var-keyword */
|
||||||
|
|
||||||
module Utils {
|
module Utils {
|
||||||
// Setup some globals based on the current environment
|
// Setup some globals based on the current environment
|
||||||
|
@ -63,7 +66,7 @@ module Utils {
|
||||||
eval(fileContents);
|
eval(fileContents);
|
||||||
break;
|
break;
|
||||||
case ExecutionEnvironment.Node:
|
case ExecutionEnvironment.Node:
|
||||||
let vm = require('vm');
|
let vm = require("vm");
|
||||||
if (nodeContext) {
|
if (nodeContext) {
|
||||||
vm.runInNewContext(fileContents, nodeContext, fileName);
|
vm.runInNewContext(fileContents, nodeContext, fileName);
|
||||||
} else {
|
} else {
|
||||||
|
@ -71,7 +74,7 @@ module Utils {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new Error('Unknown context');
|
throw new Error("Unknown context");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -80,9 +83,9 @@ module Utils {
|
||||||
// Split up the input file by line
|
// Split up the input file by line
|
||||||
// Note: IE JS engine incorrectly handles consecutive delimiters here when using RegExp split, so
|
// Note: IE JS engine incorrectly handles consecutive delimiters here when using RegExp split, so
|
||||||
// we have to use string-based splitting instead and try to figure out the delimiting chars
|
// we have to use string-based splitting instead and try to figure out the delimiting chars
|
||||||
let lines = content.split('\r\n');
|
let lines = content.split("\r\n");
|
||||||
if (lines.length === 1) {
|
if (lines.length === 1) {
|
||||||
lines = content.split('\n');
|
lines = content.split("\n");
|
||||||
|
|
||||||
if (lines.length === 1) {
|
if (lines.length === 1) {
|
||||||
lines = content.split("\r");
|
lines = content.split("\r");
|
||||||
|
@ -93,7 +96,7 @@ module Utils {
|
||||||
|
|
||||||
/** Reads a file under /tests */
|
/** Reads a file under /tests */
|
||||||
export function readTestFile(path: string) {
|
export function readTestFile(path: string) {
|
||||||
if (path.indexOf('tests') < 0) {
|
if (path.indexOf("tests") < 0) {
|
||||||
path = "tests/" + path;
|
path = "tests/" + path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -388,7 +391,7 @@ module Utils {
|
||||||
|
|
||||||
module Harness.Path {
|
module Harness.Path {
|
||||||
export function getFileName(fullPath: string) {
|
export function getFileName(fullPath: string) {
|
||||||
return fullPath.replace(/^.*[\\\/]/, '');
|
return fullPath.replace(/^.*[\\\/]/, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
export function filePath(fullPath: string) {
|
export function filePath(fullPath: string) {
|
||||||
|
@ -412,6 +415,7 @@ module Harness {
|
||||||
log(text: string): void;
|
log(text: string): void;
|
||||||
getMemoryUsage?(): number;
|
getMemoryUsage?(): number;
|
||||||
}
|
}
|
||||||
|
export var IO: IO;
|
||||||
|
|
||||||
module IOImpl {
|
module IOImpl {
|
||||||
declare class Enumerator {
|
declare class Enumerator {
|
||||||
|
@ -484,8 +488,8 @@ module Harness {
|
||||||
declare let require: any;
|
declare let require: any;
|
||||||
let fs: any, pathModule: any;
|
let fs: any, pathModule: any;
|
||||||
if (require) {
|
if (require) {
|
||||||
fs = require('fs');
|
fs = require("fs");
|
||||||
pathModule = require('path');
|
pathModule = require("path");
|
||||||
} else {
|
} else {
|
||||||
fs = pathModule = {};
|
fs = pathModule = {};
|
||||||
}
|
}
|
||||||
|
@ -559,8 +563,8 @@ module Harness {
|
||||||
let serverRoot = "http://localhost:8888/";
|
let serverRoot = "http://localhost:8888/";
|
||||||
|
|
||||||
// Unused?
|
// Unused?
|
||||||
let newLine = '\r\n';
|
let newLine = "\r\n";
|
||||||
let currentDirectory = () => '';
|
let currentDirectory = () => "";
|
||||||
let supportsCodePage = () => false;
|
let supportsCodePage = () => false;
|
||||||
|
|
||||||
module Http {
|
module Http {
|
||||||
|
@ -606,9 +610,9 @@ module Harness {
|
||||||
export function writeToServerSync(url: string, action: string, contents?: string): XHRResponse {
|
export function writeToServerSync(url: string, action: string, contents?: string): XHRResponse {
|
||||||
let xhr = new XMLHttpRequest();
|
let xhr = new XMLHttpRequest();
|
||||||
try {
|
try {
|
||||||
let actionMsg = '?action=' + action;
|
let actionMsg = "?action=" + action;
|
||||||
xhr.open('POST', url + actionMsg, false);
|
xhr.open("POST", url + actionMsg, false);
|
||||||
xhr.setRequestHeader('Access-Control-Allow-Origin', '*');
|
xhr.setRequestHeader("Access-Control-Allow-Origin", "*");
|
||||||
xhr.send(contents);
|
xhr.send(contents);
|
||||||
}
|
}
|
||||||
catch (e) {
|
catch (e) {
|
||||||
|
@ -624,7 +628,7 @@ module Harness {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function deleteFile(path: string) {
|
export function deleteFile(path: string) {
|
||||||
Http.writeToServerSync(serverRoot + path, 'DELETE', null);
|
Http.writeToServerSync(serverRoot + path, "DELETE", null);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function directoryExists(path: string): boolean {
|
export function directoryExists(path: string): boolean {
|
||||||
|
@ -637,15 +641,15 @@ module Harness {
|
||||||
if (dirPath.match(/localhost:\d+$/) || dirPath.match(/localhost:\d+\/$/)) {
|
if (dirPath.match(/localhost:\d+$/) || dirPath.match(/localhost:\d+\/$/)) {
|
||||||
dirPath = null;
|
dirPath = null;
|
||||||
// path + fileName
|
// path + fileName
|
||||||
} else if (dirPath.indexOf('.') === -1) {
|
} else if (dirPath.indexOf(".") === -1) {
|
||||||
dirPath = dirPath.substring(0, dirPath.lastIndexOf('/'));
|
dirPath = dirPath.substring(0, dirPath.lastIndexOf("/"));
|
||||||
// path
|
// path
|
||||||
} else {
|
} else {
|
||||||
// strip any trailing slash
|
// strip any trailing slash
|
||||||
if (dirPath.match(/.*\/$/)) {
|
if (dirPath.match(/.*\/$/)) {
|
||||||
dirPath = dirPath.substring(0, dirPath.length - 2);
|
dirPath = dirPath.substring(0, dirPath.length - 2);
|
||||||
}
|
}
|
||||||
dirPath = dirPath.substring(0, dirPath.lastIndexOf('/'));
|
dirPath = dirPath.substring(0, dirPath.lastIndexOf("/"));
|
||||||
}
|
}
|
||||||
|
|
||||||
return dirPath;
|
return dirPath;
|
||||||
|
@ -660,7 +664,7 @@ module Harness {
|
||||||
export function _listFilesImpl(path: string, spec?: RegExp, options?: any) {
|
export function _listFilesImpl(path: string, spec?: RegExp, options?: any) {
|
||||||
let response = Http.getFileFromServerSync(serverRoot + path);
|
let response = Http.getFileFromServerSync(serverRoot + path);
|
||||||
if (response.status === 200) {
|
if (response.status === 200) {
|
||||||
let results = response.responseText.split(',');
|
let results = response.responseText.split(",");
|
||||||
if (spec) {
|
if (spec) {
|
||||||
return results.filter(file => spec.test(file));
|
return results.filter(file => spec.test(file));
|
||||||
} else {
|
} else {
|
||||||
|
@ -668,7 +672,7 @@ module Harness {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return [''];
|
return [""];
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
export let listFiles = Utils.memoize(_listFilesImpl);
|
export let listFiles = Utils.memoize(_listFilesImpl);
|
||||||
|
@ -685,12 +689,11 @@ module Harness {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function writeFile(path: string, contents: string) {
|
export function writeFile(path: string, contents: string) {
|
||||||
Http.writeToServerSync(serverRoot + path, 'WRITE', contents);
|
Http.writeToServerSync(serverRoot + path, "WRITE", contents);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export var IO: IO;
|
|
||||||
switch (Utils.getExecutionEnvironment()) {
|
switch (Utils.getExecutionEnvironment()) {
|
||||||
case Utils.ExecutionEnvironment.CScript:
|
case Utils.ExecutionEnvironment.CScript:
|
||||||
IO = IOImpl.CScript;
|
IO = IOImpl.CScript;
|
||||||
|
@ -722,7 +725,7 @@ module Harness {
|
||||||
tcServicesFileName = "built/local/typescriptServices.js";
|
tcServicesFileName = "built/local/typescriptServices.js";
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new Error('Unknown context');
|
throw new Error("Unknown context");
|
||||||
}
|
}
|
||||||
export let tcServicesFile = IO.readFile(tcServicesFileName);
|
export let tcServicesFile = IO.readFile(tcServicesFileName);
|
||||||
|
|
||||||
|
@ -745,12 +748,12 @@ module Harness {
|
||||||
|
|
||||||
public Write(str: string) {
|
public Write(str: string) {
|
||||||
// out of memory usage concerns avoid using + or += if we're going to do any manipulation of this string later
|
// out of memory usage concerns avoid using + or += if we're going to do any manipulation of this string later
|
||||||
this.currentLine = [(this.currentLine || ''), str].join('');
|
this.currentLine = [(this.currentLine || ""), str].join("");
|
||||||
}
|
}
|
||||||
|
|
||||||
public WriteLine(str: string) {
|
public WriteLine(str: string) {
|
||||||
// out of memory usage concerns avoid using + or += if we're going to do any manipulation of this string later
|
// out of memory usage concerns avoid using + or += if we're going to do any manipulation of this string later
|
||||||
this.lines.push([(this.currentLine || ''), str].join(''));
|
this.lines.push([(this.currentLine || ""), str].join(""));
|
||||||
this.currentLine = undefined;
|
this.currentLine = undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -799,7 +802,7 @@ module Harness {
|
||||||
if (this.fileCollection.hasOwnProperty(p)) {
|
if (this.fileCollection.hasOwnProperty(p)) {
|
||||||
let current = <Harness.Compiler.WriterAggregator>this.fileCollection[p];
|
let current = <Harness.Compiler.WriterAggregator>this.fileCollection[p];
|
||||||
if (current.lines.length > 0) {
|
if (current.lines.length > 0) {
|
||||||
if (p.indexOf('.d.ts') !== -1) { current.lines.unshift(['////[', Path.getFileName(p), ']'].join('')); }
|
if (p.indexOf(".d.ts") !== -1) { current.lines.unshift(["////[", Path.getFileName(p), "]"].join("")); }
|
||||||
result.push({ fileName: p, file: this.fileCollection[p] });
|
result.push({ fileName: p, file: this.fileCollection[p] });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -828,12 +831,12 @@ module Harness {
|
||||||
const carriageReturnLineFeed = "\r\n";
|
const carriageReturnLineFeed = "\r\n";
|
||||||
const lineFeed = "\n";
|
const lineFeed = "\n";
|
||||||
|
|
||||||
export let defaultLibFileName = 'lib.d.ts';
|
export let defaultLibFileName = "lib.d.ts";
|
||||||
export let defaultLibSourceFile = createSourceFileAndAssertInvariants(defaultLibFileName, IO.readFile(libFolder + 'lib.core.d.ts'), /*languageVersion*/ ts.ScriptTarget.Latest);
|
export let defaultLibSourceFile = createSourceFileAndAssertInvariants(defaultLibFileName, IO.readFile(libFolder + "lib.core.d.ts"), /*languageVersion*/ ts.ScriptTarget.Latest);
|
||||||
export let defaultES6LibSourceFile = createSourceFileAndAssertInvariants(defaultLibFileName, IO.readFile(libFolder + 'lib.core.es6.d.ts'), /*languageVersion*/ ts.ScriptTarget.Latest);
|
export let defaultES6LibSourceFile = createSourceFileAndAssertInvariants(defaultLibFileName, IO.readFile(libFolder + "lib.core.es6.d.ts"), /*languageVersion*/ ts.ScriptTarget.Latest);
|
||||||
|
|
||||||
// Cache these between executions so we don't have to re-parse them for every test
|
// Cache these between executions so we don't have to re-parse them for every test
|
||||||
export let fourslashFileName = 'fourslash.ts';
|
export let fourslashFileName = "fourslash.ts";
|
||||||
export let fourslashSourceFile: ts.SourceFile;
|
export let fourslashSourceFile: ts.SourceFile;
|
||||||
|
|
||||||
export function getCanonicalFileName(fileName: string): string {
|
export function getCanonicalFileName(fileName: string): string {
|
||||||
|
@ -883,7 +886,7 @@ module Harness {
|
||||||
return Object.prototype.hasOwnProperty.call(filemap, getCanonicalFileName(canonicalAbsolutePath)) ? filemap[canonicalAbsolutePath] : undefined;
|
return Object.prototype.hasOwnProperty.call(filemap, getCanonicalFileName(canonicalAbsolutePath)) ? filemap[canonicalAbsolutePath] : undefined;
|
||||||
}
|
}
|
||||||
else if (fn === fourslashFileName) {
|
else if (fn === fourslashFileName) {
|
||||||
let tsFn = 'tests/cases/fourslash/' + fourslashFileName;
|
let tsFn = "tests/cases/fourslash/" + fourslashFileName;
|
||||||
fourslashSourceFile = fourslashSourceFile || createSourceFileAndAssertInvariants(tsFn, Harness.IO.readFile(tsFn), scriptTarget);
|
fourslashSourceFile = fourslashSourceFile || createSourceFileAndAssertInvariants(tsFn, Harness.IO.readFile(tsFn), scriptTarget);
|
||||||
return fourslashSourceFile;
|
return fourslashSourceFile;
|
||||||
}
|
}
|
||||||
|
@ -974,7 +977,7 @@ module Harness {
|
||||||
settingsCallback(null);
|
settingsCallback(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
let newLine = '\r\n';
|
let newLine = "\r\n";
|
||||||
options.skipDefaultLibCheck = true;
|
options.skipDefaultLibCheck = true;
|
||||||
|
|
||||||
// Files from built\local that are requested by test "@includeBuiltFiles" to be in the context.
|
// Files from built\local that are requested by test "@includeBuiltFiles" to be in the context.
|
||||||
|
@ -1011,19 +1014,19 @@ module Harness {
|
||||||
// "fileName", "comments", "declaration", "module", "nolib", "sourcemap", "target", "out", "outdir", "noimplicitany", "noresolve"
|
// "fileName", "comments", "declaration", "module", "nolib", "sourcemap", "target", "out", "outdir", "noimplicitany", "noresolve"
|
||||||
case "module":
|
case "module":
|
||||||
case "modulegentarget":
|
case "modulegentarget":
|
||||||
if (typeof setting.value === 'string') {
|
if (typeof setting.value === "string") {
|
||||||
if (setting.value.toLowerCase() === 'amd') {
|
if (setting.value.toLowerCase() === "amd") {
|
||||||
options.module = ts.ModuleKind.AMD;
|
options.module = ts.ModuleKind.AMD;
|
||||||
} else if (setting.value.toLowerCase() === 'umd') {
|
} else if (setting.value.toLowerCase() === "umd") {
|
||||||
options.module = ts.ModuleKind.UMD;
|
options.module = ts.ModuleKind.UMD;
|
||||||
} else if (setting.value.toLowerCase() === 'commonjs') {
|
} else if (setting.value.toLowerCase() === "commonjs") {
|
||||||
options.module = ts.ModuleKind.CommonJS;
|
options.module = ts.ModuleKind.CommonJS;
|
||||||
} else if (setting.value.toLowerCase() === 'system') {
|
} else if (setting.value.toLowerCase() === "system") {
|
||||||
options.module = ts.ModuleKind.System;
|
options.module = ts.ModuleKind.System;
|
||||||
} else if (setting.value.toLowerCase() === 'unspecified') {
|
} else if (setting.value.toLowerCase() === "unspecified") {
|
||||||
options.module = ts.ModuleKind.None;
|
options.module = ts.ModuleKind.None;
|
||||||
} else {
|
} else {
|
||||||
throw new Error('Unknown module type ' + setting.value);
|
throw new Error("Unknown module type " + setting.value);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
options.module = <any>setting.value;
|
options.module = <any>setting.value;
|
||||||
|
@ -1031,152 +1034,152 @@ module Harness {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "target":
|
case "target":
|
||||||
case 'codegentarget':
|
case "codegentarget":
|
||||||
if (typeof setting.value === 'string') {
|
if (typeof setting.value === "string") {
|
||||||
if (setting.value.toLowerCase() === 'es3') {
|
if (setting.value.toLowerCase() === "es3") {
|
||||||
options.target = ts.ScriptTarget.ES3;
|
options.target = ts.ScriptTarget.ES3;
|
||||||
} else if (setting.value.toLowerCase() === 'es5') {
|
} else if (setting.value.toLowerCase() === "es5") {
|
||||||
options.target = ts.ScriptTarget.ES5;
|
options.target = ts.ScriptTarget.ES5;
|
||||||
} else if (setting.value.toLowerCase() === 'es6') {
|
} else if (setting.value.toLowerCase() === "es6") {
|
||||||
options.target = ts.ScriptTarget.ES6;
|
options.target = ts.ScriptTarget.ES6;
|
||||||
} else {
|
} else {
|
||||||
throw new Error('Unknown compile target ' + setting.value);
|
throw new Error("Unknown compile target " + setting.value);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
options.target = <any>setting.value;
|
options.target = <any>setting.value;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'experimentaldecorators':
|
case "experimentaldecorators":
|
||||||
options.experimentalDecorators = setting.value === 'true';
|
options.experimentalDecorators = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'emitdecoratormetadata':
|
case "emitdecoratormetadata":
|
||||||
options.emitDecoratorMetadata = setting.value === 'true';
|
options.emitDecoratorMetadata = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'experimentalasyncfunctions':
|
case "experimentalasyncfunctions":
|
||||||
options.experimentalAsyncFunctions = setting.value === 'true';
|
options.experimentalAsyncFunctions = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'noemithelpers':
|
case "noemithelpers":
|
||||||
options.noEmitHelpers = setting.value === 'true';
|
options.noEmitHelpers = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'noemitonerror':
|
case "noemitonerror":
|
||||||
options.noEmitOnError = setting.value === 'true';
|
options.noEmitOnError = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'noresolve':
|
case "noresolve":
|
||||||
options.noResolve = setting.value === 'true';
|
options.noResolve = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'noimplicitany':
|
case "noimplicitany":
|
||||||
options.noImplicitAny = setting.value === 'true';
|
options.noImplicitAny = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'nolib':
|
case "nolib":
|
||||||
options.noLib = setting.value === 'true';
|
options.noLib = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'out':
|
case "out":
|
||||||
case 'outfileoption':
|
case "outfileoption":
|
||||||
options.out = setting.value;
|
options.out = setting.value;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'outdiroption':
|
case "outdiroption":
|
||||||
case 'outdir':
|
case "outdir":
|
||||||
options.outDir = setting.value;
|
options.outDir = setting.value;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'skipdefaultlibcheck':
|
case "skipdefaultlibcheck":
|
||||||
options.skipDefaultLibCheck = setting.value === "true";
|
options.skipDefaultLibCheck = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'sourceroot':
|
case "sourceroot":
|
||||||
options.sourceRoot = setting.value;
|
options.sourceRoot = setting.value;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'maproot':
|
case "maproot":
|
||||||
options.mapRoot = setting.value;
|
options.mapRoot = setting.value;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'sourcemap':
|
case "sourcemap":
|
||||||
options.sourceMap = setting.value === 'true';
|
options.sourceMap = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'declaration':
|
case "declaration":
|
||||||
options.declaration = setting.value === 'true';
|
options.declaration = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'newline':
|
case "newline":
|
||||||
if (setting.value.toLowerCase() === 'crlf') {
|
if (setting.value.toLowerCase() === "crlf") {
|
||||||
options.newLine = ts.NewLineKind.CarriageReturnLineFeed;
|
options.newLine = ts.NewLineKind.CarriageReturnLineFeed;
|
||||||
}
|
}
|
||||||
else if (setting.value.toLowerCase() === 'lf') {
|
else if (setting.value.toLowerCase() === "lf") {
|
||||||
options.newLine = ts.NewLineKind.LineFeed;
|
options.newLine = ts.NewLineKind.LineFeed;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
throw new Error('Unknown option for newLine: ' + setting.value);
|
throw new Error("Unknown option for newLine: " + setting.value);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'comments':
|
case "comments":
|
||||||
options.removeComments = setting.value === 'false';
|
options.removeComments = setting.value === "false";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'stripinternal':
|
case "stripinternal":
|
||||||
options.stripInternal = setting.value === 'true';
|
options.stripInternal = setting.value === "true";
|
||||||
|
|
||||||
case 'usecasesensitivefilenames':
|
case "usecasesensitivefilenames":
|
||||||
useCaseSensitiveFileNames = setting.value === 'true';
|
useCaseSensitiveFileNames = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'filename':
|
case "filename":
|
||||||
// Not supported yet
|
// Not supported yet
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'emitbom':
|
case "emitbom":
|
||||||
options.emitBOM = setting.value === 'true';
|
options.emitBOM = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'errortruncation':
|
case "errortruncation":
|
||||||
options.noErrorTruncation = setting.value === 'false';
|
options.noErrorTruncation = setting.value === "false";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'preserveconstenums':
|
case "preserveconstenums":
|
||||||
options.preserveConstEnums = setting.value === 'true';
|
options.preserveConstEnums = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'isolatedmodules':
|
case "isolatedmodules":
|
||||||
options.isolatedModules = setting.value === 'true';
|
options.isolatedModules = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'suppressimplicitanyindexerrors':
|
case "suppressimplicitanyindexerrors":
|
||||||
options.suppressImplicitAnyIndexErrors = setting.value === 'true';
|
options.suppressImplicitAnyIndexErrors = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'includebuiltfile':
|
case "includebuiltfile":
|
||||||
let builtFileName = libFolder + setting.value;
|
let builtFileName = libFolder + setting.value;
|
||||||
includeBuiltFiles.push({ unitName: builtFileName, content: normalizeLineEndings(IO.readFile(builtFileName), newLine) });
|
includeBuiltFiles.push({ unitName: builtFileName, content: normalizeLineEndings(IO.readFile(builtFileName), newLine) });
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'inlinesourcemap':
|
case "inlinesourcemap":
|
||||||
options.inlineSourceMap = setting.value === 'true';
|
options.inlineSourceMap = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'inlinesources':
|
case "inlinesources":
|
||||||
options.inlineSources = setting.value === 'true';
|
options.inlineSources = setting.value === "true";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'jsx':
|
case "jsx":
|
||||||
options.jsx = setting.value.toLowerCase() === 'react' ? ts.JsxEmit.React :
|
options.jsx = setting.value.toLowerCase() === "react" ? ts.JsxEmit.React :
|
||||||
setting.value.toLowerCase() === 'preserve' ? ts.JsxEmit.Preserve :
|
setting.value.toLowerCase() === "preserve" ? ts.JsxEmit.Preserve :
|
||||||
ts.JsxEmit.None;
|
ts.JsxEmit.None;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
throw new Error('Unsupported compiler setting ' + setting.flag);
|
throw new Error("Unsupported compiler setting " + setting.flag);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1189,7 +1192,7 @@ module Harness {
|
||||||
// Current directory is needed for rwcRunner to be able to use currentDirectory defined in json file
|
// Current directory is needed for rwcRunner to be able to use currentDirectory defined in json file
|
||||||
currentDirectory?: string) {
|
currentDirectory?: string) {
|
||||||
if (options.declaration && result.errors.length === 0 && result.declFilesCode.length !== result.files.length) {
|
if (options.declaration && result.errors.length === 0 && result.declFilesCode.length !== result.files.length) {
|
||||||
throw new Error('There were no errors and declFiles generated did not match number of js files generated');
|
throw new Error("There were no errors and declFiles generated did not match number of js files generated");
|
||||||
}
|
}
|
||||||
|
|
||||||
let declInputFiles: { unitName: string; content: string }[] = [];
|
let declInputFiles: { unitName: string; content: string }[] = [];
|
||||||
|
@ -1250,8 +1253,8 @@ module Harness {
|
||||||
}
|
}
|
||||||
|
|
||||||
function normalizeLineEndings(text: string, lineEnding: string): string {
|
function normalizeLineEndings(text: string, lineEnding: string): string {
|
||||||
let normalized = text.replace(/\r\n?/g, '\n');
|
let normalized = text.replace(/\r\n?/g, "\n");
|
||||||
if (lineEnding !== '\n') {
|
if (lineEnding !== "\n") {
|
||||||
normalized = normalized.replace(/\n/g, lineEnding);
|
normalized = normalized.replace(/\n/g, lineEnding);
|
||||||
}
|
}
|
||||||
return normalized;
|
return normalized;
|
||||||
|
@ -1282,10 +1285,10 @@ module Harness {
|
||||||
let message = ts.flattenDiagnosticMessageText(error.messageText, ts.sys.newLine);
|
let message = ts.flattenDiagnosticMessageText(error.messageText, ts.sys.newLine);
|
||||||
|
|
||||||
let errLines = RunnerBase.removeFullPaths(message)
|
let errLines = RunnerBase.removeFullPaths(message)
|
||||||
.split('\n')
|
.split("\n")
|
||||||
.map(s => s.length > 0 && s.charAt(s.length - 1) === '\r' ? s.substr(0, s.length - 1) : s)
|
.map(s => s.length > 0 && s.charAt(s.length - 1) === "\r" ? s.substr(0, s.length - 1) : s)
|
||||||
.filter(s => s.length > 0)
|
.filter(s => s.length > 0)
|
||||||
.map(s => '!!! ' + ts.DiagnosticCategory[error.category].toLowerCase() + " TS" + error.code + ": " + s);
|
.map(s => "!!! " + ts.DiagnosticCategory[error.category].toLowerCase() + " TS" + error.code + ": " + s);
|
||||||
errLines.forEach(e => outputLines.push(e));
|
errLines.forEach(e => outputLines.push(e));
|
||||||
|
|
||||||
totalErrorsReported++;
|
totalErrorsReported++;
|
||||||
|
@ -1305,7 +1308,7 @@ module Harness {
|
||||||
|
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
outputLines.push('==== ' + inputFile.unitName + ' (' + fileErrors.length + ' errors) ====');
|
outputLines.push("==== " + inputFile.unitName + " (" + fileErrors.length + " errors) ====");
|
||||||
|
|
||||||
// Make sure we emit something for every error
|
// Make sure we emit something for every error
|
||||||
let markedErrorCount = 0;
|
let markedErrorCount = 0;
|
||||||
|
@ -1314,13 +1317,13 @@ module Harness {
|
||||||
// we have to string-based splitting instead and try to figure out the delimiting chars
|
// we have to string-based splitting instead and try to figure out the delimiting chars
|
||||||
|
|
||||||
let lineStarts = ts.computeLineStarts(inputFile.content);
|
let lineStarts = ts.computeLineStarts(inputFile.content);
|
||||||
let lines = inputFile.content.split('\n');
|
let lines = inputFile.content.split("\n");
|
||||||
if (lines.length === 1) {
|
if (lines.length === 1) {
|
||||||
lines = lines[0].split("\r");
|
lines = lines[0].split("\r");
|
||||||
}
|
}
|
||||||
|
|
||||||
lines.forEach((line, lineIndex) => {
|
lines.forEach((line, lineIndex) => {
|
||||||
if (line.length > 0 && line.charAt(line.length - 1) === '\r') {
|
if (line.length > 0 && line.charAt(line.length - 1) === "\r") {
|
||||||
line = line.substr(0, line.length - 1);
|
line = line.substr(0, line.length - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1333,7 +1336,7 @@ module Harness {
|
||||||
nextLineStart = lineStarts[lineIndex + 1];
|
nextLineStart = lineStarts[lineIndex + 1];
|
||||||
}
|
}
|
||||||
// Emit this line from the original file
|
// Emit this line from the original file
|
||||||
outputLines.push(' ' + line);
|
outputLines.push(" " + line);
|
||||||
fileErrors.forEach(err => {
|
fileErrors.forEach(err => {
|
||||||
// Does any error start or continue on to this line? Emit squiggles
|
// Does any error start or continue on to this line? Emit squiggles
|
||||||
let end = ts.textSpanEnd(err);
|
let end = ts.textSpanEnd(err);
|
||||||
|
@ -1345,7 +1348,7 @@ module Harness {
|
||||||
// Calculate the start of the squiggle
|
// Calculate the start of the squiggle
|
||||||
let squiggleStart = Math.max(0, relativeOffset);
|
let squiggleStart = Math.max(0, relativeOffset);
|
||||||
// TODO/REVIEW: this doesn't work quite right in the browser if a multi file test has files whose names are just the right length relative to one another
|
// TODO/REVIEW: this doesn't work quite right in the browser if a multi file test has files whose names are just the right length relative to one another
|
||||||
outputLines.push(' ' + line.substr(0, squiggleStart).replace(/[^\s]/g, ' ') + new Array(Math.min(length, line.length - squiggleStart) + 1).join('~'));
|
outputLines.push(" " + line.substr(0, squiggleStart).replace(/[^\s]/g, " ") + new Array(Math.min(length, line.length - squiggleStart) + 1).join("~"));
|
||||||
|
|
||||||
// If the error ended here, or we're at the end of the file, emit its message
|
// If the error ended here, or we're at the end of the file, emit its message
|
||||||
if ((lineIndex === lines.length - 1) || nextLineStart > end) {
|
if ((lineIndex === lines.length - 1) || nextLineStart > end) {
|
||||||
|
@ -1360,7 +1363,7 @@ module Harness {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify we didn't miss any errors in this file
|
// Verify we didn't miss any errors in this file
|
||||||
assert.equal(markedErrorCount, fileErrors.length, 'count of errors in ' + inputFile.unitName);
|
assert.equal(markedErrorCount, fileErrors.length, "count of errors in " + inputFile.unitName);
|
||||||
});
|
});
|
||||||
|
|
||||||
let numLibraryDiagnostics = ts.countWhere(diagnostics, diagnostic => {
|
let numLibraryDiagnostics = ts.countWhere(diagnostics, diagnostic => {
|
||||||
|
@ -1373,10 +1376,10 @@ module Harness {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify we didn't miss any errors in total
|
// Verify we didn't miss any errors in total
|
||||||
assert.equal(totalErrorsReported + numLibraryDiagnostics + numTest262HarnessDiagnostics, diagnostics.length, 'total number of errors');
|
assert.equal(totalErrorsReported + numLibraryDiagnostics + numTest262HarnessDiagnostics, diagnostics.length, "total number of errors");
|
||||||
|
|
||||||
return minimalDiagnosticsToString(diagnostics) +
|
return minimalDiagnosticsToString(diagnostics) +
|
||||||
ts.sys.newLine + ts.sys.newLine + outputLines.join('\r\n');
|
ts.sys.newLine + ts.sys.newLine + outputLines.join("\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
export function collateOutputs(outputFiles: Harness.Compiler.GeneratedFile[]): string {
|
export function collateOutputs(outputFiles: Harness.Compiler.GeneratedFile[]): string {
|
||||||
|
@ -1384,15 +1387,15 @@ module Harness {
|
||||||
outputFiles.sort((a, b) => cleanName(a.fileName).localeCompare(cleanName(b.fileName)));
|
outputFiles.sort((a, b) => cleanName(a.fileName).localeCompare(cleanName(b.fileName)));
|
||||||
|
|
||||||
// Emit them
|
// Emit them
|
||||||
let result = '';
|
let result = "";
|
||||||
for (let outputFile of outputFiles) {
|
for (let outputFile of outputFiles) {
|
||||||
// Some extra spacing if this isn't the first file
|
// Some extra spacing if this isn't the first file
|
||||||
if (result.length) {
|
if (result.length) {
|
||||||
result += '\r\n\r\n';
|
result += "\r\n\r\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
// FileName header + content
|
// FileName header + content
|
||||||
result += '/*====== ' + outputFile.fileName + ' ======*/\r\n';
|
result += "/*====== " + outputFile.fileName + " ======*/\r\n";
|
||||||
|
|
||||||
result += outputFile.code;
|
result += outputFile.code;
|
||||||
}
|
}
|
||||||
|
@ -1400,7 +1403,7 @@ module Harness {
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
function cleanName(fn: string) {
|
function cleanName(fn: string) {
|
||||||
let lastSlash = ts.normalizeSlashes(fn).lastIndexOf('/');
|
let lastSlash = ts.normalizeSlashes(fn).lastIndexOf("/");
|
||||||
return fn.substr(lastSlash + 1).toLowerCase();
|
return fn.substr(lastSlash + 1).toLowerCase();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1418,7 +1421,7 @@ module Harness {
|
||||||
// This does not need to exist strictly speaking, but many tests will need to be updated if it's removed
|
// This does not need to exist strictly speaking, but many tests will need to be updated if it's removed
|
||||||
export function compileString(code: string, unitName: string, callback: (result: CompilerResult) => void) {
|
export function compileString(code: string, unitName: string, callback: (result: CompilerResult) => void) {
|
||||||
// NEWTODO: Re-implement 'compileString'
|
// NEWTODO: Re-implement 'compileString'
|
||||||
throw new Error('compileString NYI');
|
throw new Error("compileString NYI");
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface GeneratedFile {
|
export interface GeneratedFile {
|
||||||
|
@ -1432,26 +1435,26 @@ module Harness {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isTS(fileName: string) {
|
export function isTS(fileName: string) {
|
||||||
return stringEndsWith(fileName, '.ts');
|
return stringEndsWith(fileName, ".ts");
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isTSX(fileName: string) {
|
export function isTSX(fileName: string) {
|
||||||
return stringEndsWith(fileName, '.tsx');
|
return stringEndsWith(fileName, ".tsx");
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isDTS(fileName: string) {
|
export function isDTS(fileName: string) {
|
||||||
return stringEndsWith(fileName, '.d.ts');
|
return stringEndsWith(fileName, ".d.ts");
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isJS(fileName: string) {
|
export function isJS(fileName: string) {
|
||||||
return stringEndsWith(fileName, '.js');
|
return stringEndsWith(fileName, ".js");
|
||||||
}
|
}
|
||||||
export function isJSX(fileName: string) {
|
export function isJSX(fileName: string) {
|
||||||
return stringEndsWith(fileName, '.jsx');
|
return stringEndsWith(fileName, ".jsx");
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isJSMap(fileName: string) {
|
export function isJSMap(fileName: string) {
|
||||||
return stringEndsWith(fileName, '.js.map') || stringEndsWith(fileName, '.jsx.map');
|
return stringEndsWith(fileName, ".js.map") || stringEndsWith(fileName, ".jsx.map");
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Contains the code and errors of a compilation and some helper methods to check its status. */
|
/** Contains the code and errors of a compilation and some helper methods to check its status. */
|
||||||
|
@ -1478,7 +1481,7 @@ module Harness {
|
||||||
this.sourceMaps.push(emittedFile);
|
this.sourceMaps.push(emittedFile);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
throw new Error('Unrecognized file extension for file ' + emittedFile.fileName);
|
throw new Error("Unrecognized file extension for file " + emittedFile.fileName);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1587,10 +1590,10 @@ module Harness {
|
||||||
// Subfile content line
|
// Subfile content line
|
||||||
// Append to the current subfile content, inserting a newline needed
|
// Append to the current subfile content, inserting a newline needed
|
||||||
if (currentFileContent === null) {
|
if (currentFileContent === null) {
|
||||||
currentFileContent = '';
|
currentFileContent = "";
|
||||||
} else {
|
} else {
|
||||||
// End-of-line
|
// End-of-line
|
||||||
currentFileContent = currentFileContent + '\n';
|
currentFileContent = currentFileContent + "\n";
|
||||||
}
|
}
|
||||||
currentFileContent = currentFileContent + line;
|
currentFileContent = currentFileContent + line;
|
||||||
}
|
}
|
||||||
|
@ -1601,7 +1604,7 @@ module Harness {
|
||||||
|
|
||||||
// EOF, push whatever remains
|
// EOF, push whatever remains
|
||||||
let newTestFile2 = {
|
let newTestFile2 = {
|
||||||
content: currentFileContent || '',
|
content: currentFileContent || "",
|
||||||
name: currentFileName,
|
name: currentFileName,
|
||||||
fileOptions: currentFileOptions,
|
fileOptions: currentFileOptions,
|
||||||
originalFilePath: fileName,
|
originalFilePath: fileName,
|
||||||
|
@ -1623,27 +1626,27 @@ module Harness {
|
||||||
|
|
||||||
export function localPath(fileName: string, baselineFolder?: string, subfolder?: string) {
|
export function localPath(fileName: string, baselineFolder?: string, subfolder?: string) {
|
||||||
if (baselineFolder === undefined) {
|
if (baselineFolder === undefined) {
|
||||||
return baselinePath(fileName, 'local', 'tests/baselines', subfolder);
|
return baselinePath(fileName, "local", "tests/baselines", subfolder);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return baselinePath(fileName, 'local', baselineFolder, subfolder);
|
return baselinePath(fileName, "local", baselineFolder, subfolder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function referencePath(fileName: string, baselineFolder?: string, subfolder?: string) {
|
function referencePath(fileName: string, baselineFolder?: string, subfolder?: string) {
|
||||||
if (baselineFolder === undefined) {
|
if (baselineFolder === undefined) {
|
||||||
return baselinePath(fileName, 'reference', 'tests/baselines', subfolder);
|
return baselinePath(fileName, "reference", "tests/baselines", subfolder);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return baselinePath(fileName, 'reference', baselineFolder, subfolder);
|
return baselinePath(fileName, "reference", baselineFolder, subfolder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function baselinePath(fileName: string, type: string, baselineFolder: string, subfolder?: string) {
|
function baselinePath(fileName: string, type: string, baselineFolder: string, subfolder?: string) {
|
||||||
if (subfolder !== undefined) {
|
if (subfolder !== undefined) {
|
||||||
return Harness.userSpecifiedRoot + baselineFolder + '/' + subfolder + '/' + type + '/' + fileName;
|
return Harness.userSpecifiedRoot + baselineFolder + "/" + subfolder + "/" + type + "/" + fileName;
|
||||||
} else {
|
} else {
|
||||||
return Harness.userSpecifiedRoot + baselineFolder + '/' + type + '/' + fileName;
|
return Harness.userSpecifiedRoot + baselineFolder + "/" + type + "/" + fileName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1677,7 +1680,7 @@ module Harness {
|
||||||
let actual = generateContent();
|
let actual = generateContent();
|
||||||
|
|
||||||
if (actual === undefined) {
|
if (actual === undefined) {
|
||||||
throw new Error('The generated content was "undefined". Return "null" if no baselining is required."');
|
throw new Error("The generated content was \"undefined\". Return \"null\" if no baselining is required.\"");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Store the content in the 'local' folder so we
|
// Store the content in the 'local' folder so we
|
||||||
|
@ -1700,10 +1703,10 @@ module Harness {
|
||||||
let refFileName = referencePath(relativeFileName, opts && opts.Baselinefolder, opts && opts.Subfolder);
|
let refFileName = referencePath(relativeFileName, opts && opts.Baselinefolder, opts && opts.Subfolder);
|
||||||
|
|
||||||
if (actual === null) {
|
if (actual === null) {
|
||||||
actual = '<no content>';
|
actual = "<no content>";
|
||||||
}
|
}
|
||||||
|
|
||||||
let expected = '<no content>';
|
let expected = "<no content>";
|
||||||
if (IO.fileExists(refFileName)) {
|
if (IO.fileExists(refFileName)) {
|
||||||
expected = IO.readFile(refFileName);
|
expected = IO.readFile(refFileName);
|
||||||
}
|
}
|
||||||
|
@ -1712,10 +1715,10 @@ module Harness {
|
||||||
}
|
}
|
||||||
|
|
||||||
function writeComparison(expected: string, actual: string, relativeFileName: string, actualFileName: string, descriptionForDescribe: string) {
|
function writeComparison(expected: string, actual: string, relativeFileName: string, actualFileName: string, descriptionForDescribe: string) {
|
||||||
let encoded_actual = (new Buffer(actual)).toString('utf8');
|
let encoded_actual = (new Buffer(actual)).toString("utf8");
|
||||||
if (expected != encoded_actual) {
|
if (expected != encoded_actual) {
|
||||||
// Overwrite & issue error
|
// Overwrite & issue error
|
||||||
let errMsg = 'The baseline file ' + relativeFileName + ' has changed';
|
let errMsg = "The baseline file " + relativeFileName + " has changed";
|
||||||
throw new Error(errMsg);
|
throw new Error(errMsg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1744,7 +1747,7 @@ module Harness {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isLibraryFile(filePath: string): boolean {
|
export function isLibraryFile(filePath: string): boolean {
|
||||||
return (Path.getFileName(filePath) === 'lib.d.ts') || (Path.getFileName(filePath) === 'lib.core.d.ts');
|
return (Path.getFileName(filePath) === "lib.d.ts") || (Path.getFileName(filePath) === "lib.core.d.ts");
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isBuiltFile(filePath: string): boolean {
|
export function isBuiltFile(filePath: string): boolean {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/// <reference path='..\services\services.ts' />
|
/// <reference path="..\services\services.ts" />
|
||||||
/// <reference path='..\services\shims.ts' />
|
/// <reference path="..\services\shims.ts" />
|
||||||
/// <reference path='..\server\client.ts' />
|
/// <reference path="..\server\client.ts" />
|
||||||
/// <reference path='harness.ts' />
|
/// <reference path="harness.ts" />
|
||||||
|
|
||||||
module Harness.LanguageService {
|
module Harness.LanguageService {
|
||||||
export class ScriptInfo {
|
export class ScriptInfo {
|
||||||
|
@ -242,7 +242,7 @@ module Harness.LanguageService {
|
||||||
throw new Error("NYI");
|
throw new Error("NYI");
|
||||||
}
|
}
|
||||||
getClassificationsForLine(text: string, lexState: ts.EndOfLineState, classifyKeywordsInGenerics?: boolean): ts.ClassificationResult {
|
getClassificationsForLine(text: string, lexState: ts.EndOfLineState, classifyKeywordsInGenerics?: boolean): ts.ClassificationResult {
|
||||||
let result = this.shim.getClassificationsForLine(text, lexState, classifyKeywordsInGenerics).split('\n');
|
let result = this.shim.getClassificationsForLine(text, lexState, classifyKeywordsInGenerics).split("\n");
|
||||||
let entries: ts.ClassificationInfo[] = [];
|
let entries: ts.ClassificationInfo[] = [];
|
||||||
let i = 0;
|
let i = 0;
|
||||||
let position = 0;
|
let position = 0;
|
||||||
|
|
|
@ -73,7 +73,7 @@ interface PlaybackControl {
|
||||||
module Playback {
|
module Playback {
|
||||||
let recordLog: IOLog = undefined;
|
let recordLog: IOLog = undefined;
|
||||||
let replayLog: IOLog = undefined;
|
let replayLog: IOLog = undefined;
|
||||||
let recordLogFileNameBase = '';
|
let recordLogFileNameBase = "";
|
||||||
|
|
||||||
interface Memoized<T> {
|
interface Memoized<T> {
|
||||||
(s: string): T;
|
(s: string): T;
|
||||||
|
@ -99,7 +99,7 @@ module Playback {
|
||||||
return {
|
return {
|
||||||
timestamp: (new Date()).toString(),
|
timestamp: (new Date()).toString(),
|
||||||
arguments: [],
|
arguments: [],
|
||||||
currentDirectory: '',
|
currentDirectory: "",
|
||||||
filesRead: [],
|
filesRead: [],
|
||||||
filesWritten: [],
|
filesWritten: [],
|
||||||
filesDeleted: [],
|
filesDeleted: [],
|
||||||
|
@ -110,7 +110,7 @@ module Playback {
|
||||||
dirExists: [],
|
dirExists: [],
|
||||||
dirsCreated: [],
|
dirsCreated: [],
|
||||||
pathsResolved: [],
|
pathsResolved: [],
|
||||||
executingPath: ''
|
executingPath: ""
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ module Playback {
|
||||||
if (defaultValue !== undefined) {
|
if (defaultValue !== undefined) {
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
} else {
|
} else {
|
||||||
throw new Error('No matching result in log array for: ' + JSON.stringify(expectedFields));
|
throw new Error("No matching result in log array for: " + JSON.stringify(expectedFields));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return results[0].result;
|
return results[0].result;
|
||||||
|
@ -195,7 +195,7 @@ module Playback {
|
||||||
}
|
}
|
||||||
// If we got here, we didn't find a match
|
// If we got here, we didn't find a match
|
||||||
if (defaultValue === undefined) {
|
if (defaultValue === undefined) {
|
||||||
throw new Error('No matching result in log array for path: ' + expectedPath);
|
throw new Error("No matching result in log array for path: " + expectedPath);
|
||||||
} else {
|
} else {
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
}
|
}
|
||||||
|
@ -203,7 +203,7 @@ module Playback {
|
||||||
|
|
||||||
let pathEquivCache: any = {};
|
let pathEquivCache: any = {};
|
||||||
function pathsAreEquivalent(left: string, right: string, wrapper: { resolvePath(s: string): string }) {
|
function pathsAreEquivalent(left: string, right: string, wrapper: { resolvePath(s: string): string }) {
|
||||||
let key = left + '-~~-' + right;
|
let key = left + "-~~-" + right;
|
||||||
function areSame(a: string, b: string) {
|
function areSame(a: string, b: string) {
|
||||||
return ts.normalizeSlashes(a).toLowerCase() === ts.normalizeSlashes(b).toLowerCase();
|
return ts.normalizeSlashes(a).toLowerCase() === ts.normalizeSlashes(b).toLowerCase();
|
||||||
}
|
}
|
||||||
|
@ -233,14 +233,14 @@ module Playback {
|
||||||
wrapper.endRecord = () => {
|
wrapper.endRecord = () => {
|
||||||
if (recordLog !== undefined) {
|
if (recordLog !== undefined) {
|
||||||
let i = 0;
|
let i = 0;
|
||||||
let fn = () => recordLogFileNameBase + i + '.json';
|
let fn = () => recordLogFileNameBase + i + ".json";
|
||||||
while (underlying.fileExists(fn())) i++;
|
while (underlying.fileExists(fn())) i++;
|
||||||
underlying.writeFile(fn(), JSON.stringify(recordLog));
|
underlying.writeFile(fn(), JSON.stringify(recordLog));
|
||||||
recordLog = undefined;
|
recordLog = undefined;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
Object.defineProperty(wrapper, 'args', {
|
Object.defineProperty(wrapper, "args", {
|
||||||
get() {
|
get() {
|
||||||
if (replayLog !== undefined) {
|
if (replayLog !== undefined) {
|
||||||
return replayLog.arguments;
|
return replayLog.arguments;
|
||||||
|
@ -276,7 +276,7 @@ module Playback {
|
||||||
|
|
||||||
wrapper.getCurrentDirectory = () => {
|
wrapper.getCurrentDirectory = () => {
|
||||||
if (replayLog !== undefined) {
|
if (replayLog !== undefined) {
|
||||||
return replayLog.currentDirectory || '';
|
return replayLog.currentDirectory || "";
|
||||||
} else if (recordLog !== undefined) {
|
} else if (recordLog !== undefined) {
|
||||||
return recordLog.currentDirectory = underlying.getCurrentDirectory();
|
return recordLog.currentDirectory = underlying.getCurrentDirectory();
|
||||||
} else {
|
} else {
|
||||||
|
@ -286,7 +286,7 @@ module Playback {
|
||||||
|
|
||||||
wrapper.resolvePath = recordReplay(wrapper.resolvePath, underlying)(
|
wrapper.resolvePath = recordReplay(wrapper.resolvePath, underlying)(
|
||||||
(path) => callAndRecord(underlying.resolvePath(path), recordLog.pathsResolved, { path: path }),
|
(path) => callAndRecord(underlying.resolvePath(path), recordLog.pathsResolved, { path: path }),
|
||||||
memoize((path) => findResultByFields(replayLog.pathsResolved, { path: path }, !ts.isRootedDiskPath(ts.normalizeSlashes(path)) && replayLog.currentDirectory ? replayLog.currentDirectory + '/' + path : ts.normalizeSlashes(path))));
|
memoize((path) => findResultByFields(replayLog.pathsResolved, { path: path }, !ts.isRootedDiskPath(ts.normalizeSlashes(path)) && replayLog.currentDirectory ? replayLog.currentDirectory + "/" + path : ts.normalizeSlashes(path))));
|
||||||
|
|
||||||
wrapper.readFile = recordReplay(wrapper.readFile, underlying)(
|
wrapper.readFile = recordReplay(wrapper.readFile, underlying)(
|
||||||
(path) => {
|
(path) => {
|
||||||
|
@ -299,7 +299,7 @@ module Playback {
|
||||||
|
|
||||||
wrapper.writeFile = recordReplay(wrapper.writeFile, underlying)(
|
wrapper.writeFile = recordReplay(wrapper.writeFile, underlying)(
|
||||||
(path, contents) => callAndRecord(underlying.writeFile(path, contents), recordLog.filesWritten, { path: path, contents: contents, bom: false }),
|
(path, contents) => callAndRecord(underlying.writeFile(path, contents), recordLog.filesWritten, { path: path, contents: contents, bom: false }),
|
||||||
(path, contents) => noOpReplay('writeFile'));
|
(path, contents) => noOpReplay("writeFile"));
|
||||||
|
|
||||||
wrapper.exit = (exitCode) => {
|
wrapper.exit = (exitCode) => {
|
||||||
if (recordLog !== undefined) {
|
if (recordLog !== undefined) {
|
||||||
|
|
|
@ -74,7 +74,7 @@ class ProjectRunner extends RunnerBase {
|
||||||
catch (e) {
|
catch (e) {
|
||||||
assert(false, "Testcase: " + testCaseFileName + " does not contain valid json format: " + e.message);
|
assert(false, "Testcase: " + testCaseFileName + " does not contain valid json format: " + e.message);
|
||||||
}
|
}
|
||||||
let testCaseJustName = testCaseFileName.replace(/^.*[\\\/]/, '').replace(/\.json/, "");
|
let testCaseJustName = testCaseFileName.replace(/^.*[\\\/]/, "").replace(/\.json/, "");
|
||||||
|
|
||||||
function moduleNameToString(moduleKind: ts.ModuleKind) {
|
function moduleNameToString(moduleKind: ts.ModuleKind) {
|
||||||
return moduleKind === ts.ModuleKind.AMD
|
return moduleKind === ts.ModuleKind.AMD
|
||||||
|
@ -331,9 +331,9 @@ class ProjectRunner extends RunnerBase {
|
||||||
return Harness.Compiler.getErrorBaseline(inputFiles, compilerResult.errors);
|
return Harness.Compiler.getErrorBaseline(inputFiles, compilerResult.errors);
|
||||||
}
|
}
|
||||||
|
|
||||||
let name = 'Compiling project for ' + testCase.scenario + ': testcase ' + testCaseFileName;
|
let name = "Compiling project for " + testCase.scenario + ": testcase " + testCaseFileName;
|
||||||
|
|
||||||
describe('Projects tests', () => {
|
describe("Projects tests", () => {
|
||||||
describe(name, () => {
|
describe(name, () => {
|
||||||
function verifyCompilerResults(moduleKind: ts.ModuleKind) {
|
function verifyCompilerResults(moduleKind: ts.ModuleKind) {
|
||||||
let compilerResult: BatchCompileProjectTestCaseResult;
|
let compilerResult: BatchCompileProjectTestCaseResult;
|
||||||
|
@ -367,27 +367,27 @@ class ProjectRunner extends RunnerBase {
|
||||||
compilerResult = batchCompilerProjectTestCase(moduleKind);
|
compilerResult = batchCompilerProjectTestCase(moduleKind);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Resolution information of (' + moduleNameToString(moduleKind) + '): ' + testCaseFileName, () => {
|
it("Resolution information of (" + moduleNameToString(moduleKind) + "): " + testCaseFileName, () => {
|
||||||
Harness.Baseline.runBaseline('Resolution information of (' + moduleNameToString(compilerResult.moduleKind) + '): ' + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + testCaseJustName + '.json', () => {
|
Harness.Baseline.runBaseline("Resolution information of (" + moduleNameToString(compilerResult.moduleKind) + "): " + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + testCaseJustName + ".json", () => {
|
||||||
return JSON.stringify(getCompilerResolutionInfo(), undefined, " ");
|
return JSON.stringify(getCompilerResolutionInfo(), undefined, " ");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
it('Errors for (' + moduleNameToString(moduleKind) + '): ' + testCaseFileName, () => {
|
it("Errors for (" + moduleNameToString(moduleKind) + "): " + testCaseFileName, () => {
|
||||||
if (compilerResult.errors.length) {
|
if (compilerResult.errors.length) {
|
||||||
Harness.Baseline.runBaseline('Errors for (' + moduleNameToString(compilerResult.moduleKind) + '): ' + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + testCaseJustName + '.errors.txt', () => {
|
Harness.Baseline.runBaseline("Errors for (" + moduleNameToString(compilerResult.moduleKind) + "): " + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + testCaseJustName + ".errors.txt", () => {
|
||||||
return getErrorsBaseline(compilerResult);
|
return getErrorsBaseline(compilerResult);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
it('Baseline of emitted result (' + moduleNameToString(moduleKind) + '): ' + testCaseFileName, () => {
|
it("Baseline of emitted result (" + moduleNameToString(moduleKind) + "): " + testCaseFileName, () => {
|
||||||
if (testCase.baselineCheck) {
|
if (testCase.baselineCheck) {
|
||||||
ts.forEach(compilerResult.outputFiles, outputFile => {
|
ts.forEach(compilerResult.outputFiles, outputFile => {
|
||||||
|
|
||||||
Harness.Baseline.runBaseline('Baseline of emitted result (' + moduleNameToString(compilerResult.moduleKind) + '): ' + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + outputFile.fileName, () => {
|
Harness.Baseline.runBaseline("Baseline of emitted result (" + moduleNameToString(compilerResult.moduleKind) + "): " + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + outputFile.fileName, () => {
|
||||||
try {
|
try {
|
||||||
return ts.sys.readFile(getProjectOutputFolder(outputFile.fileName, compilerResult.moduleKind));
|
return ts.sys.readFile(getProjectOutputFolder(outputFile.fileName, compilerResult.moduleKind));
|
||||||
}
|
}
|
||||||
|
@ -400,9 +400,9 @@ class ProjectRunner extends RunnerBase {
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
it('SourceMapRecord for (' + moduleNameToString(moduleKind) + '): ' + testCaseFileName, () => {
|
it("SourceMapRecord for (" + moduleNameToString(moduleKind) + "): " + testCaseFileName, () => {
|
||||||
if (compilerResult.sourceMapData) {
|
if (compilerResult.sourceMapData) {
|
||||||
Harness.Baseline.runBaseline('SourceMapRecord for (' + moduleNameToString(compilerResult.moduleKind) + '): ' + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + testCaseJustName + '.sourcemap.txt', () => {
|
Harness.Baseline.runBaseline("SourceMapRecord for (" + moduleNameToString(compilerResult.moduleKind) + "): " + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + testCaseJustName + ".sourcemap.txt", () => {
|
||||||
return Harness.SourceMapRecoder.getSourceMapRecord(compilerResult.sourceMapData, compilerResult.program,
|
return Harness.SourceMapRecoder.getSourceMapRecord(compilerResult.sourceMapData, compilerResult.program,
|
||||||
ts.filter(compilerResult.outputFiles, outputFile => Harness.Compiler.isJS(outputFile.emittedFileName)));
|
ts.filter(compilerResult.outputFiles, outputFile => Harness.Compiler.isJS(outputFile.emittedFileName)));
|
||||||
});
|
});
|
||||||
|
@ -411,11 +411,11 @@ class ProjectRunner extends RunnerBase {
|
||||||
|
|
||||||
// Verify that all the generated .d.ts files compile
|
// Verify that all the generated .d.ts files compile
|
||||||
|
|
||||||
it('Errors in generated Dts files for (' + moduleNameToString(moduleKind) + '): ' + testCaseFileName, () => {
|
it("Errors in generated Dts files for (" + moduleNameToString(moduleKind) + "): " + testCaseFileName, () => {
|
||||||
if (!compilerResult.errors.length && testCase.declaration) {
|
if (!compilerResult.errors.length && testCase.declaration) {
|
||||||
let dTsCompileResult = compileCompileDTsFiles(compilerResult);
|
let dTsCompileResult = compileCompileDTsFiles(compilerResult);
|
||||||
if (dTsCompileResult.errors.length) {
|
if (dTsCompileResult.errors.length) {
|
||||||
Harness.Baseline.runBaseline('Errors in generated Dts files for (' + moduleNameToString(compilerResult.moduleKind) + '): ' + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + testCaseJustName + '.dts.errors.txt', () => {
|
Harness.Baseline.runBaseline("Errors in generated Dts files for (" + moduleNameToString(compilerResult.moduleKind) + "): " + testCaseFileName, getBaselineFolder(compilerResult.moduleKind) + testCaseJustName + ".dts.errors.txt", () => {
|
||||||
return getErrorsBaseline(dTsCompileResult);
|
return getErrorsBaseline(dTsCompileResult);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,12 +13,12 @@
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
//
|
//
|
||||||
|
|
||||||
/// <reference path='test262Runner.ts' />
|
/// <reference path="test262Runner.ts" />
|
||||||
/// <reference path='compilerRunner.ts' />
|
/// <reference path="compilerRunner.ts" />
|
||||||
/// <reference path='fourslashRunner.ts' />
|
/// <reference path="fourslashRunner.ts" />
|
||||||
/// <reference path='projectsRunner.ts' />
|
/// <reference path="projectsRunner.ts" />
|
||||||
/// <reference path='rwcRunner.ts' />
|
/// <reference path="rwcRunner.ts" />
|
||||||
/// <reference path='harness.ts' />
|
/// <reference path="harness.ts" />
|
||||||
|
|
||||||
let runners: RunnerBase[] = [];
|
let runners: RunnerBase[] = [];
|
||||||
let iterations: number = 1;
|
let iterations: number = 1;
|
||||||
|
@ -32,13 +32,13 @@ function runTests(runners: RunnerBase[]) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// users can define tests to run in mytest.config that will override cmd line args, otherwise use cmd line args (test.config), otherwise no options
|
// users can define tests to run in mytest.config that will override cmd line args, otherwise use cmd line args (test.config), otherwise no options
|
||||||
let mytestconfig = 'mytest.config';
|
let mytestconfig = "mytest.config";
|
||||||
let testconfig = 'test.config';
|
let testconfig = "test.config";
|
||||||
let testConfigFile =
|
let testConfigFile =
|
||||||
Harness.IO.fileExists(mytestconfig) ? Harness.IO.readFile(mytestconfig) :
|
Harness.IO.fileExists(mytestconfig) ? Harness.IO.readFile(mytestconfig) :
|
||||||
(Harness.IO.fileExists(testconfig) ? Harness.IO.readFile(testconfig) : '');
|
(Harness.IO.fileExists(testconfig) ? Harness.IO.readFile(testconfig) : "");
|
||||||
|
|
||||||
if (testConfigFile !== '') {
|
if (testConfigFile !== "") {
|
||||||
let testConfig = JSON.parse(testConfigFile);
|
let testConfig = JSON.parse(testConfigFile);
|
||||||
if (testConfig.light) {
|
if (testConfig.light) {
|
||||||
Harness.lightMode = true;
|
Harness.lightMode = true;
|
||||||
|
@ -51,33 +51,33 @@ if (testConfigFile !== '') {
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (option) {
|
switch (option) {
|
||||||
case 'compiler':
|
case "compiler":
|
||||||
runners.push(new CompilerBaselineRunner(CompilerTestType.Conformance));
|
runners.push(new CompilerBaselineRunner(CompilerTestType.Conformance));
|
||||||
runners.push(new CompilerBaselineRunner(CompilerTestType.Regressions));
|
runners.push(new CompilerBaselineRunner(CompilerTestType.Regressions));
|
||||||
runners.push(new ProjectRunner());
|
runners.push(new ProjectRunner());
|
||||||
break;
|
break;
|
||||||
case 'conformance':
|
case "conformance":
|
||||||
runners.push(new CompilerBaselineRunner(CompilerTestType.Conformance));
|
runners.push(new CompilerBaselineRunner(CompilerTestType.Conformance));
|
||||||
break;
|
break;
|
||||||
case 'project':
|
case "project":
|
||||||
runners.push(new ProjectRunner());
|
runners.push(new ProjectRunner());
|
||||||
break;
|
break;
|
||||||
case 'fourslash':
|
case "fourslash":
|
||||||
runners.push(new FourSlashRunner(FourSlashTestType.Native));
|
runners.push(new FourSlashRunner(FourSlashTestType.Native));
|
||||||
break;
|
break;
|
||||||
case 'fourslash-shims':
|
case "fourslash-shims":
|
||||||
runners.push(new FourSlashRunner(FourSlashTestType.Shims));
|
runners.push(new FourSlashRunner(FourSlashTestType.Shims));
|
||||||
break;
|
break;
|
||||||
case 'fourslash-server':
|
case "fourslash-server":
|
||||||
runners.push(new FourSlashRunner(FourSlashTestType.Server));
|
runners.push(new FourSlashRunner(FourSlashTestType.Server));
|
||||||
break;
|
break;
|
||||||
case 'fourslash-generated':
|
case "fourslash-generated":
|
||||||
runners.push(new GeneratedFourslashRunner(FourSlashTestType.Native));
|
runners.push(new GeneratedFourslashRunner(FourSlashTestType.Native));
|
||||||
break;
|
break;
|
||||||
case 'rwc':
|
case "rwc":
|
||||||
runners.push(new RWCRunner());
|
runners.push(new RWCRunner());
|
||||||
break;
|
break;
|
||||||
case 'test262':
|
case "test262":
|
||||||
runners.push(new Test262BaselineRunner());
|
runners.push(new Test262BaselineRunner());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -102,6 +102,6 @@ if (runners.length === 0) {
|
||||||
// runners.push(new GeneratedFourslashRunner());
|
// runners.push(new GeneratedFourslashRunner());
|
||||||
}
|
}
|
||||||
|
|
||||||
ts.sys.newLine = '\r\n';
|
ts.sys.newLine = "\r\n";
|
||||||
|
|
||||||
runTests(runners);
|
runTests(runners);
|
||||||
|
|
|
@ -33,7 +33,7 @@ abstract class RunnerBase {
|
||||||
|
|
||||||
// when running in the browser the 'full path' is the host name, shows up in error baselines
|
// when running in the browser the 'full path' is the host name, shows up in error baselines
|
||||||
let localHost = /http:\/localhost:\d+/g;
|
let localHost = /http:\/localhost:\d+/g;
|
||||||
fixedPath = fixedPath.replace(localHost, '');
|
fixedPath = fixedPath.replace(localHost, "");
|
||||||
return fixedPath;
|
return fixedPath;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
/// <reference path='harness.ts'/>
|
/// <reference path="harness.ts"/>
|
||||||
/// <reference path='runnerbase.ts' />
|
/// <reference path="runnerbase.ts" />
|
||||||
/// <reference path='loggedIO.ts' />
|
/// <reference path="loggedIO.ts" />
|
||||||
/// <reference path='..\compiler\commandLineParser.ts'/>
|
/// <reference path="..\compiler\commandLineParser.ts"/>
|
||||||
|
|
||||||
module RWC {
|
module RWC {
|
||||||
function runWithIOLog(ioLog: IOLog, fn: () => void) {
|
function runWithIOLog(ioLog: IOLog, fn: () => void) {
|
||||||
|
@ -26,8 +26,8 @@ module RWC {
|
||||||
let compilerResult: Harness.Compiler.CompilerResult;
|
let compilerResult: Harness.Compiler.CompilerResult;
|
||||||
let compilerOptions: ts.CompilerOptions;
|
let compilerOptions: ts.CompilerOptions;
|
||||||
let baselineOpts: Harness.Baseline.BaselineOptions = {
|
let baselineOpts: Harness.Baseline.BaselineOptions = {
|
||||||
Subfolder: 'rwc',
|
Subfolder: "rwc",
|
||||||
Baselinefolder: 'internal/baselines'
|
Baselinefolder: "internal/baselines"
|
||||||
};
|
};
|
||||||
let baseName = /(.*)\/(.*).json/.exec(ts.normalizeSlashes(jsonPath))[2];
|
let baseName = /(.*)\/(.*).json/.exec(ts.normalizeSlashes(jsonPath))[2];
|
||||||
let currentDirectory: string;
|
let currentDirectory: string;
|
||||||
|
@ -49,7 +49,7 @@ module RWC {
|
||||||
useCustomLibraryFile = undefined;
|
useCustomLibraryFile = undefined;
|
||||||
});
|
});
|
||||||
|
|
||||||
it('can compile', () => {
|
it("can compile", () => {
|
||||||
let harnessCompiler = Harness.Compiler.getCompiler();
|
let harnessCompiler = Harness.Compiler.getCompiler();
|
||||||
let opts: ts.ParsedCommandLine;
|
let opts: ts.ParsedCommandLine;
|
||||||
|
|
||||||
|
@ -74,10 +74,11 @@ module RWC {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Add files to compilation
|
// Add files to compilation
|
||||||
|
let isInInputList = (resolvedPath: string) => (inputFile: { unitName: string; content: string; }) => inputFile.unitName === resolvedPath;
|
||||||
for (let fileRead of ioLog.filesRead) {
|
for (let fileRead of ioLog.filesRead) {
|
||||||
// Check if the file is already added into the set of input files.
|
// Check if the file is already added into the set of input files.
|
||||||
var resolvedPath = ts.normalizeSlashes(ts.sys.resolvePath(fileRead.path));
|
const resolvedPath = ts.normalizeSlashes(ts.sys.resolvePath(fileRead.path));
|
||||||
let inInputList = ts.forEach(inputFiles, inputFile => inputFile.unitName === resolvedPath);
|
let inInputList = ts.forEach(inputFiles, isInInputList(resolvedPath));
|
||||||
|
|
||||||
if (!Harness.isLibraryFile(fileRead.path)) {
|
if (!Harness.isLibraryFile(fileRead.path)) {
|
||||||
if (inInputList) {
|
if (inInputList) {
|
||||||
|
@ -130,14 +131,14 @@ module RWC {
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
it('has the expected emitted code', () => {
|
it("has the expected emitted code", () => {
|
||||||
Harness.Baseline.runBaseline('has the expected emitted code', baseName + '.output.js', () => {
|
Harness.Baseline.runBaseline("has the expected emitted code", baseName + ".output.js", () => {
|
||||||
return Harness.Compiler.collateOutputs(compilerResult.files);
|
return Harness.Compiler.collateOutputs(compilerResult.files);
|
||||||
}, false, baselineOpts);
|
}, false, baselineOpts);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('has the expected declaration file content', () => {
|
it("has the expected declaration file content", () => {
|
||||||
Harness.Baseline.runBaseline('has the expected declaration file content', baseName + '.d.ts', () => {
|
Harness.Baseline.runBaseline("has the expected declaration file content", baseName + ".d.ts", () => {
|
||||||
if (!compilerResult.declFilesCode.length) {
|
if (!compilerResult.declFilesCode.length) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -146,8 +147,8 @@ module RWC {
|
||||||
}, false, baselineOpts);
|
}, false, baselineOpts);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('has the expected source maps', () => {
|
it("has the expected source maps", () => {
|
||||||
Harness.Baseline.runBaseline('has the expected source maps', baseName + '.map', () => {
|
Harness.Baseline.runBaseline("has the expected source maps", baseName + ".map", () => {
|
||||||
if (!compilerResult.sourceMaps.length) {
|
if (!compilerResult.sourceMaps.length) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -156,16 +157,16 @@ module RWC {
|
||||||
}, false, baselineOpts);
|
}, false, baselineOpts);
|
||||||
});
|
});
|
||||||
|
|
||||||
/*it('has correct source map record', () => {
|
/*it("has correct source map record", () => {
|
||||||
if (compilerOptions.sourceMap) {
|
if (compilerOptions.sourceMap) {
|
||||||
Harness.Baseline.runBaseline('has correct source map record', baseName + '.sourcemap.txt', () => {
|
Harness.Baseline.runBaseline("has correct source map record", baseName + ".sourcemap.txt", () => {
|
||||||
return compilerResult.getSourceMapRecord();
|
return compilerResult.getSourceMapRecord();
|
||||||
}, false, baselineOpts);
|
}, false, baselineOpts);
|
||||||
}
|
}
|
||||||
});*/
|
});*/
|
||||||
|
|
||||||
it('has the expected errors', () => {
|
it("has the expected errors", () => {
|
||||||
Harness.Baseline.runBaseline('has the expected errors', baseName + '.errors.txt', () => {
|
Harness.Baseline.runBaseline("has the expected errors", baseName + ".errors.txt", () => {
|
||||||
if (compilerResult.errors.length === 0) {
|
if (compilerResult.errors.length === 0) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -176,9 +177,9 @@ module RWC {
|
||||||
|
|
||||||
// Ideally, a generated declaration file will have no errors. But we allow generated
|
// Ideally, a generated declaration file will have no errors. But we allow generated
|
||||||
// declaration file errors as part of the baseline.
|
// declaration file errors as part of the baseline.
|
||||||
it('has the expected errors in generated declaration files', () => {
|
it("has the expected errors in generated declaration files", () => {
|
||||||
if (compilerOptions.declaration && !compilerResult.errors.length) {
|
if (compilerOptions.declaration && !compilerResult.errors.length) {
|
||||||
Harness.Baseline.runBaseline('has the expected errors in generated declaration files', baseName + '.dts.errors.txt', () => {
|
Harness.Baseline.runBaseline("has the expected errors in generated declaration files", baseName + ".dts.errors.txt", () => {
|
||||||
let declFileCompilationResult = Harness.Compiler.getCompiler().compileDeclarationFiles(inputFiles, otherFiles, compilerResult,
|
let declFileCompilationResult = Harness.Compiler.getCompiler().compileDeclarationFiles(inputFiles, otherFiles, compilerResult,
|
||||||
/*settingscallback*/ undefined, compilerOptions, currentDirectory);
|
/*settingscallback*/ undefined, compilerOptions, currentDirectory);
|
||||||
if (declFileCompilationResult.declResult.errors.length === 0) {
|
if (declFileCompilationResult.declResult.errors.length === 0) {
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
//
|
//
|
||||||
|
|
||||||
///<reference path='harness.ts'/>
|
///<reference path="harness.ts"/>
|
||||||
|
|
||||||
module Harness.SourceMapRecoder {
|
module Harness.SourceMapRecoder {
|
||||||
|
|
||||||
|
@ -50,11 +50,11 @@ module Harness.SourceMapRecoder {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sourceMapMappings.charAt(decodingIndex) == ',') {
|
if (sourceMapMappings.charAt(decodingIndex) == ",") {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sourceMapMappings.charAt(decodingIndex) == ';') {
|
if (sourceMapMappings.charAt(decodingIndex) == ";") {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -117,7 +117,7 @@ module Harness.SourceMapRecoder {
|
||||||
}
|
}
|
||||||
|
|
||||||
while (decodingIndex < sourceMapMappings.length) {
|
while (decodingIndex < sourceMapMappings.length) {
|
||||||
if (sourceMapMappings.charAt(decodingIndex) == ';') {
|
if (sourceMapMappings.charAt(decodingIndex) == ";") {
|
||||||
// New line
|
// New line
|
||||||
decodeOfEncodedMapping.emittedLine++;
|
decodeOfEncodedMapping.emittedLine++;
|
||||||
decodeOfEncodedMapping.emittedColumn = 1;
|
decodeOfEncodedMapping.emittedColumn = 1;
|
||||||
|
@ -125,7 +125,7 @@ module Harness.SourceMapRecoder {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sourceMapMappings.charAt(decodingIndex) == ',') {
|
if (sourceMapMappings.charAt(decodingIndex) == ",") {
|
||||||
// Next entry is on same line - no action needed
|
// Next entry is on same line - no action needed
|
||||||
decodingIndex++;
|
decodingIndex++;
|
||||||
continue;
|
continue;
|
||||||
|
@ -459,6 +459,6 @@ module Harness.SourceMapRecoder {
|
||||||
SourceMapSpanWriter.close(); // If the last spans werent emitted, emit them
|
SourceMapSpanWriter.close(); // If the last spans werent emitted, emit them
|
||||||
}
|
}
|
||||||
sourceMapRecoder.Close();
|
sourceMapRecoder.Close();
|
||||||
return sourceMapRecoder.lines.join('\r\n');
|
return sourceMapRecoder.lines.join("\r\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
/// <reference path='harness.ts' />
|
/// <reference path="harness.ts" />
|
||||||
/// <reference path='runnerbase.ts' />
|
/// <reference path="runnerbase.ts" />
|
||||||
|
|
||||||
class Test262BaselineRunner extends RunnerBase {
|
class Test262BaselineRunner extends RunnerBase {
|
||||||
private static basePath = 'internal/cases/test262';
|
private static basePath = "internal/cases/test262";
|
||||||
private static helpersFilePath = 'tests/cases/test262-harness/helpers.d.ts';
|
private static helpersFilePath = "tests/cases/test262-harness/helpers.d.ts";
|
||||||
private static helperFile = {
|
private static helperFile = {
|
||||||
unitName: Test262BaselineRunner.helpersFilePath,
|
unitName: Test262BaselineRunner.helpersFilePath,
|
||||||
content: Harness.IO.readFile(Test262BaselineRunner.helpersFilePath)
|
content: Harness.IO.readFile(Test262BaselineRunner.helpersFilePath)
|
||||||
|
@ -15,8 +15,8 @@ class Test262BaselineRunner extends RunnerBase {
|
||||||
module: ts.ModuleKind.CommonJS
|
module: ts.ModuleKind.CommonJS
|
||||||
};
|
};
|
||||||
private static baselineOptions: Harness.Baseline.BaselineOptions = {
|
private static baselineOptions: Harness.Baseline.BaselineOptions = {
|
||||||
Subfolder: 'test262',
|
Subfolder: "test262",
|
||||||
Baselinefolder: 'internal/baselines'
|
Baselinefolder: "internal/baselines"
|
||||||
};
|
};
|
||||||
|
|
||||||
private static getTestFilePath(filename: string): string {
|
private static getTestFilePath(filename: string): string {
|
||||||
|
@ -24,7 +24,7 @@ class Test262BaselineRunner extends RunnerBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
private runTest(filePath: string) {
|
private runTest(filePath: string) {
|
||||||
describe('test262 test for ' + filePath, () => {
|
describe("test262 test for " + filePath, () => {
|
||||||
// Mocha holds onto the closure environment of the describe callback even after the test is done.
|
// Mocha holds onto the closure environment of the describe callback even after the test is done.
|
||||||
// Everything declared here should be cleared out in the "after" callback.
|
// Everything declared here should be cleared out in the "after" callback.
|
||||||
let testState: {
|
let testState: {
|
||||||
|
@ -36,7 +36,7 @@ class Test262BaselineRunner extends RunnerBase {
|
||||||
|
|
||||||
before(() => {
|
before(() => {
|
||||||
let content = Harness.IO.readFile(filePath);
|
let content = Harness.IO.readFile(filePath);
|
||||||
let testFilename = ts.removeFileExtension(filePath).replace(/\//g, '_') + ".test";
|
let testFilename = ts.removeFileExtension(filePath).replace(/\//g, "_") + ".test";
|
||||||
let testCaseContent = Harness.TestCaseParser.makeUnitsFromTest(content, testFilename);
|
let testCaseContent = Harness.TestCaseParser.makeUnitsFromTest(content, testFilename);
|
||||||
|
|
||||||
let inputFiles = testCaseContent.testUnitData.map(unit => {
|
let inputFiles = testCaseContent.testUnitData.map(unit => {
|
||||||
|
@ -61,15 +61,15 @@ class Test262BaselineRunner extends RunnerBase {
|
||||||
testState = undefined;
|
testState = undefined;
|
||||||
});
|
});
|
||||||
|
|
||||||
it('has the expected emitted code', () => {
|
it("has the expected emitted code", () => {
|
||||||
Harness.Baseline.runBaseline('has the expected emitted code', testState.filename + '.output.js', () => {
|
Harness.Baseline.runBaseline("has the expected emitted code", testState.filename + ".output.js", () => {
|
||||||
let files = testState.compilerResult.files.filter(f => f.fileName !== Test262BaselineRunner.helpersFilePath);
|
let files = testState.compilerResult.files.filter(f => f.fileName !== Test262BaselineRunner.helpersFilePath);
|
||||||
return Harness.Compiler.collateOutputs(files);
|
return Harness.Compiler.collateOutputs(files);
|
||||||
}, false, Test262BaselineRunner.baselineOptions);
|
}, false, Test262BaselineRunner.baselineOptions);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('has the expected errors', () => {
|
it("has the expected errors", () => {
|
||||||
Harness.Baseline.runBaseline('has the expected errors', testState.filename + '.errors.txt', () => {
|
Harness.Baseline.runBaseline("has the expected errors", testState.filename + ".errors.txt", () => {
|
||||||
let errors = testState.compilerResult.errors;
|
let errors = testState.compilerResult.errors;
|
||||||
if (errors.length === 0) {
|
if (errors.length === 0) {
|
||||||
return null;
|
return null;
|
||||||
|
@ -79,13 +79,13 @@ class Test262BaselineRunner extends RunnerBase {
|
||||||
}, false, Test262BaselineRunner.baselineOptions);
|
}, false, Test262BaselineRunner.baselineOptions);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('satisfies inletiants', () => {
|
it("satisfies inletiants", () => {
|
||||||
let sourceFile = testState.program.getSourceFile(Test262BaselineRunner.getTestFilePath(testState.filename));
|
let sourceFile = testState.program.getSourceFile(Test262BaselineRunner.getTestFilePath(testState.filename));
|
||||||
Utils.assertInvariants(sourceFile, /*parent:*/ undefined);
|
Utils.assertInvariants(sourceFile, /*parent:*/ undefined);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('has the expected AST', () => {
|
it("has the expected AST", () => {
|
||||||
Harness.Baseline.runBaseline('has the expected AST', testState.filename + '.AST.txt', () => {
|
Harness.Baseline.runBaseline("has the expected AST", testState.filename + ".AST.txt", () => {
|
||||||
let sourceFile = testState.program.getSourceFile(Test262BaselineRunner.getTestFilePath(testState.filename));
|
let sourceFile = testState.program.getSourceFile(Test262BaselineRunner.getTestFilePath(testState.filename));
|
||||||
return Utils.sourceFileToJSON(sourceFile);
|
return Utils.sourceFileToJSON(sourceFile);
|
||||||
}, false, Test262BaselineRunner.baselineOptions);
|
}, false, Test262BaselineRunner.baselineOptions);
|
||||||
|
|
Loading…
Reference in a new issue