2014-07-13 01:04:16 +02:00
// This file contains the build logic for the public repo
var fs = require ( "fs" ) ;
2014-12-02 00:32:52 +01:00
var os = require ( "os" ) ;
2014-07-13 01:04:16 +02:00
var path = require ( "path" ) ;
2015-03-04 07:12:06 +01:00
var child_process = require ( "child_process" ) ;
2016-08-11 18:53:38 +02:00
var fold = require ( "travis-fold" ) ;
2016-06-09 03:09:36 +02:00
var runTestsInParallel = require ( "./scripts/mocha-parallel" ) . runTestsInParallel ;
2014-07-13 01:04:16 +02:00
// Variables
var compilerDirectory = "src/compiler/" ;
var servicesDirectory = "src/services/" ;
2015-02-12 04:43:10 +01:00
var serverDirectory = "src/server/" ;
2016-08-12 23:01:23 +02:00
var typingsInstallerDirectory = "src/server/typingsInstaller" ;
2016-09-23 01:20:27 +02:00
var cancellationTokenDirectory = "src/server/cancellationToken" ;
2014-07-13 01:04:16 +02:00
var harnessDirectory = "src/harness/" ;
var libraryDirectory = "src/lib/" ;
2014-07-24 13:53:42 +02:00
var scriptsDirectory = "scripts/" ;
2016-07-12 02:42:52 +02:00
var unittestsDirectory = "src/harness/unittests/" ;
2014-09-26 23:36:18 +02:00
var docDirectory = "doc/" ;
2014-07-13 01:04:16 +02:00
var builtDirectory = "built/" ;
var builtLocalDirectory = "built/local/" ;
2015-07-27 19:07:07 +02:00
var LKGDirectory = "lib/" ;
2014-07-13 01:04:16 +02:00
var copyright = "CopyrightNotice.txt" ;
var thirdParty = "ThirdPartyNoticeText.txt" ;
2014-07-22 07:08:27 +02:00
// add node_modules to path so we don't need global modules, prefer the modules by adding them first
2014-07-24 04:30:13 +02:00
var nodeModulesPathPrefix = path . resolve ( "./node_modules/.bin/" ) + path . delimiter ;
if ( process . env . path !== undefined ) {
2016-08-19 23:34:14 +02:00
process . env . path = nodeModulesPathPrefix + process . env . path ;
2015-03-04 07:12:06 +01:00
} else if ( process . env . PATH !== undefined ) {
2016-08-19 23:34:14 +02:00
process . env . PATH = nodeModulesPathPrefix + process . env . PATH ;
2014-07-24 04:30:13 +02:00
}
2014-07-22 07:08:27 +02:00
2016-08-12 23:00:50 +02:00
function toNs ( diff ) {
return diff [ 0 ] * 1 e9 + diff [ 1 ] ;
}
function mark() {
if ( ! fold . isTravis ( ) ) return ;
var stamp = process . hrtime ( ) ;
var id = Math . floor ( Math . random ( ) * 0xFFFFFFFF ) . toString ( 16 ) ;
console . log ( "travis_time:start:" + id + "\r" ) ;
return {
stamp : stamp ,
id : id
} ;
}
function measure ( marker ) {
if ( ! fold . isTravis ( ) ) return ;
var diff = process . hrtime ( marker . stamp ) ;
var total = [ marker . stamp [ 0 ] + diff [ 0 ] , marker . stamp [ 1 ] + diff [ 1 ] ] ;
console . log ( "travis_time:end:" + marker . id + ":start=" + toNs ( marker . stamp ) + ",finish=" + toNs ( total ) + ",duration=" + toNs ( diff ) + "\r" ) ;
}
2014-07-13 01:04:16 +02:00
var compilerSources = [
"core.ts" ,
2016-07-20 00:10:29 +02:00
"performance.ts" ,
2014-07-13 01:04:16 +02:00
"sys.ts" ,
"types.ts" ,
"scanner.ts" ,
"parser.ts" ,
2014-12-11 01:42:41 +01:00
"utilities.ts" ,
2014-07-13 01:04:16 +02:00
"binder.ts" ,
"checker.ts" ,
2016-02-04 03:11:32 +01:00
"factory.ts" ,
"visitor.ts" ,
2016-02-12 19:49:09 +01:00
"transformers/destructuring.ts" ,
"transformers/ts.ts" ,
"transformers/jsx.ts" ,
2016-10-28 01:03:01 +02:00
"transformers/esnext.ts" ,
2016-10-12 21:34:00 +02:00
"transformers/es2017.ts" ,
2016-10-12 21:28:11 +02:00
"transformers/es2016.ts" ,
2016-10-13 13:32:00 +02:00
"transformers/es2015.ts" ,
2016-02-29 20:04:56 +01:00
"transformers/generators.ts" ,
2016-10-17 21:11:21 +02:00
"transformers/es5.ts" ,
2016-10-14 02:53:44 +02:00
"transformers/module/es2015.ts" ,
"transformers/module/system.ts" ,
"transformers/module/module.ts" ,
2016-02-09 21:39:46 +01:00
"transformer.ts" ,
2015-11-24 07:38:05 +01:00
"sourcemap.ts" ,
2016-02-09 22:43:40 +01:00
"comments.ts" ,
2015-03-19 00:37:52 +01:00
"declarationEmitter.ts" ,
2014-07-13 01:04:16 +02:00
"emitter.ts" ,
2014-12-16 22:28:38 +01:00
"program.ts" ,
2014-07-13 01:04:16 +02:00
"commandLineParser.ts" ,
2014-08-07 08:21:53 +02:00
"tsc.ts" ,
2014-07-13 01:04:16 +02:00
"diagnosticInformationMap.generated.ts"
] . map ( function ( f ) {
return path . join ( compilerDirectory , f ) ;
} ) ;
var servicesSources = [
"core.ts" ,
2016-07-20 00:10:29 +02:00
"performance.ts" ,
2014-12-11 01:42:41 +01:00
"sys.ts" ,
2014-07-13 01:04:16 +02:00
"types.ts" ,
"scanner.ts" ,
"parser.ts" ,
2014-12-11 01:42:41 +01:00
"utilities.ts" ,
2014-07-13 01:04:16 +02:00
"binder.ts" ,
"checker.ts" ,
2016-02-04 03:11:32 +01:00
"factory.ts" ,
"visitor.ts" ,
2016-02-12 19:49:09 +01:00
"transformers/destructuring.ts" ,
"transformers/ts.ts" ,
"transformers/jsx.ts" ,
2016-10-28 01:03:01 +02:00
"transformers/esnext.ts" ,
2016-10-12 21:34:00 +02:00
"transformers/es2017.ts" ,
2016-10-12 21:28:11 +02:00
"transformers/es2016.ts" ,
2016-10-13 13:32:00 +02:00
"transformers/es2015.ts" ,
2016-02-29 20:04:56 +01:00
"transformers/generators.ts" ,
2016-10-17 21:11:21 +02:00
"transformers/es5.ts" ,
2016-10-14 02:53:44 +02:00
"transformers/module/es2015.ts" ,
"transformers/module/system.ts" ,
"transformers/module/module.ts" ,
2016-02-09 21:39:46 +01:00
"transformer.ts" ,
2015-11-24 07:38:05 +01:00
"sourcemap.ts" ,
2016-02-09 22:43:40 +01:00
"comments.ts" ,
2015-03-19 00:37:52 +01:00
"declarationEmitter.ts" ,
2014-12-11 01:42:41 +01:00
"emitter.ts" ,
2014-12-16 22:28:38 +01:00
"program.ts" ,
2015-01-12 01:20:19 +01:00
"commandLineParser.ts" ,
2014-12-11 01:42:41 +01:00
"diagnosticInformationMap.generated.ts"
2014-07-13 01:04:16 +02:00
] . map ( function ( f ) {
return path . join ( compilerDirectory , f ) ;
} ) . concat ( [
2016-09-07 21:05:21 +02:00
"types.ts" ,
"utilities.ts" ,
2014-10-18 00:39:31 +02:00
"breakpoints.ts" ,
2016-09-07 21:05:21 +02:00
"classifier.ts" ,
"completions.ts" ,
"documentHighlights.ts" ,
2016-09-08 20:54:46 +02:00
"documentRegistry.ts" ,
2016-09-07 21:05:21 +02:00
"findAllReferences.ts" ,
"goToDefinition.ts" ,
2016-09-15 02:25:56 +02:00
"goToImplementation.ts" ,
2016-09-07 21:05:21 +02:00
"jsDoc.ts" ,
"jsTyping.ts" ,
2015-03-19 00:37:52 +01:00
"navigateTo.ts" ,
2014-12-11 01:42:41 +01:00
"navigationBar.ts" ,
"outliningElementsCollector.ts" ,
2015-02-20 09:22:41 +01:00
"patternMatcher.ts" ,
2016-09-07 21:05:21 +02:00
"preProcess.ts" ,
"rename.ts" ,
2014-07-13 01:04:16 +02:00
"services.ts" ,
"shims.ts" ,
2014-09-24 04:00:45 +02:00
"signatureHelp.ts" ,
2016-09-07 21:05:21 +02:00
"symbolDisplay.ts" ,
2016-09-07 23:25:52 +02:00
"transpile.ts" ,
2014-12-11 01:42:41 +01:00
"formatting/formatting.ts" ,
"formatting/formattingContext.ts" ,
"formatting/formattingRequestKind.ts" ,
"formatting/formattingScanner.ts" ,
"formatting/references.ts" ,
"formatting/rule.ts" ,
"formatting/ruleAction.ts" ,
"formatting/ruleDescriptor.ts" ,
"formatting/ruleFlag.ts" ,
"formatting/ruleOperation.ts" ,
"formatting/ruleOperationContext.ts" ,
"formatting/rules.ts" ,
"formatting/rulesMap.ts" ,
"formatting/rulesProvider.ts" ,
"formatting/smartIndenter.ts" ,
"formatting/tokenRange.ts"
2014-07-13 01:04:16 +02:00
] . map ( function ( f ) {
return path . join ( servicesDirectory , f ) ;
} ) ) ;
2015-10-29 00:02:16 +01:00
var serverCoreSources = [
2016-08-12 23:01:23 +02:00
"types.d.ts" ,
2016-11-07 22:36:08 +01:00
"shared.ts" ,
2016-06-22 02:31:54 +02:00
"utilities.ts" ,
2016-06-01 01:51:00 +02:00
"scriptVersionCache.ts" ,
2016-08-17 23:47:54 +02:00
"typingsCache.ts" ,
2016-06-22 02:31:54 +02:00
"scriptInfo.ts" ,
"lsHost.ts" ,
"project.ts" ,
2015-02-12 04:43:10 +01:00
"editorServices.ts" ,
2016-10-12 20:02:56 +02:00
"protocol.ts" ,
2015-02-16 03:49:22 +01:00
"session.ts" ,
2015-02-12 04:43:10 +01:00
"server.ts"
] . map ( function ( f ) {
return path . join ( serverDirectory , f ) ;
2015-10-28 23:42:15 +01:00
} ) ;
2016-06-15 02:30:55 +02:00
var cancellationTokenSources = [
"cancellationToken.ts"
] . map ( function ( f ) {
2016-09-23 01:20:27 +02:00
return path . join ( cancellationTokenDirectory , f ) ;
2016-06-15 02:30:55 +02:00
} ) ;
2016-08-12 23:01:23 +02:00
var typingsInstallerSources = [
"../types.d.ts" ,
2016-11-07 22:36:08 +01:00
"../shared.ts" ,
2016-08-12 23:01:23 +02:00
"typingsInstaller.ts" ,
"nodeTypingsInstaller.ts"
] . map ( function ( f ) {
return path . join ( typingsInstallerDirectory , f ) ;
} ) ;
2015-10-29 00:02:16 +01:00
var serverSources = serverCoreSources . concat ( servicesSources ) ;
2015-02-12 04:43:10 +01:00
2015-06-10 02:00:35 +02:00
var languageServiceLibrarySources = [
2016-10-12 20:02:56 +02:00
"protocol.ts" ,
2016-06-25 02:15:36 +02:00
"utilities.ts" ,
"scriptVersionCache.ts" ,
"scriptInfo.ts" ,
"lsHost.ts" ,
"project.ts" ,
2015-06-10 02:00:35 +02:00
"editorServices.ts" ,
2016-06-25 02:15:36 +02:00
"session.ts" ,
2015-06-10 02:00:35 +02:00
] . map ( function ( f ) {
return path . join ( serverDirectory , f ) ;
2015-06-17 21:39:02 +02:00
} ) . concat ( servicesSources ) ;
2015-06-10 02:00:35 +02:00
2015-07-15 02:47:15 +02:00
var harnessCoreSources = [
2014-07-13 01:04:16 +02:00
"harness.ts" ,
2015-12-17 00:49:31 +01:00
"virtualFileSystem.ts" ,
2014-07-13 01:04:16 +02:00
"sourceMapRecorder.ts" ,
2014-07-29 19:37:01 +02:00
"harnessLanguageService.ts" ,
"fourslash.ts" ,
2014-07-13 01:04:16 +02:00
"runnerbase.ts" ,
"compilerRunner.ts" ,
"typeWriter.ts" ,
2014-07-29 19:37:01 +02:00
"fourslashRunner.ts" ,
2014-07-13 01:04:16 +02:00
"projectsRunner.ts" ,
2014-08-21 00:26:33 +02:00
"loggedIO.ts" ,
2014-07-13 01:04:16 +02:00
"rwcRunner.ts" ,
2014-11-17 20:01:05 +01:00
"test262Runner.ts" ,
2014-07-29 19:37:01 +02:00
"runner.ts"
2014-07-13 01:04:16 +02:00
] . map ( function ( f ) {
return path . join ( harnessDirectory , f ) ;
2015-07-15 02:47:15 +02:00
} ) ;
var harnessSources = harnessCoreSources . concat ( [
2014-12-10 01:39:52 +01:00
"incrementalParser.ts" ,
2015-05-28 19:14:18 +02:00
"jsDocParsing.ts" ,
2014-10-30 01:36:39 +01:00
"services/colorization.ts" ,
2014-10-25 01:03:59 +02:00
"services/documentRegistry.ts" ,
2015-02-20 09:22:41 +01:00
"services/preProcessFile.ts" ,
2015-04-01 02:30:57 +02:00
"services/patternMatcher.ts" ,
2015-07-22 01:05:03 +02:00
"session.ts" ,
2015-04-08 07:54:06 +02:00
"versionCache.ts" ,
2015-05-27 05:18:13 +02:00
"convertToBase64.ts" ,
2016-03-16 22:09:45 +01:00
"transpile.ts" ,
2015-08-04 02:42:29 +02:00
"reuseProgramStructure.ts" ,
2015-08-18 03:31:12 +02:00
"cachingInServerLSHost.ts" ,
2015-10-29 12:56:13 +01:00
"moduleResolution.ts" ,
2016-03-15 19:44:33 +01:00
"tsconfigParsing.ts" ,
2016-03-15 19:45:21 +01:00
"commandLineParsing.ts" ,
2016-07-25 23:48:41 +02:00
"configurationExtension.ts" ,
2016-03-15 19:45:21 +01:00
"convertCompilerOptionsFromJson.ts" ,
2016-06-02 09:03:10 +02:00
"convertTypingOptionsFromJson.ts" ,
2016-06-18 00:34:06 +02:00
"tsserverProjectSystem.ts" ,
2016-08-30 20:47:08 +02:00
"compileOnSave.ts" ,
"typingsInstaller.ts" ,
"projectErrors.ts" ,
2016-08-18 00:23:28 +02:00
"matchFiles.ts" ,
"initializeTSConfig.ts" ,
2014-10-17 03:13:26 +02:00
] . map ( function ( f ) {
return path . join ( unittestsDirectory , f ) ;
2015-02-12 04:43:10 +01:00
} ) ) . concat ( [
2016-10-12 20:02:56 +02:00
"protocol.ts" ,
2016-06-25 02:15:36 +02:00
"utilities.ts" ,
2016-06-01 01:51:00 +02:00
"scriptVersionCache.ts" ,
2016-06-25 02:15:36 +02:00
"scriptInfo.ts" ,
"lsHost.ts" ,
"project.ts" ,
2016-08-12 20:04:43 +02:00
"typingsCache.ts" ,
2016-06-25 02:15:36 +02:00
"editorServices.ts" ,
"session.ts" ,
2015-02-12 04:43:10 +01:00
] . map ( function ( f ) {
return path . join ( serverDirectory , f ) ;
2014-10-17 03:13:26 +02:00
} ) ) ;
2014-07-13 01:04:16 +02:00
2016-03-28 22:19:17 +02:00
var es2015LibrarySources = [
2016-04-05 07:02:12 +02:00
"es2015.core.d.ts" ,
2016-03-28 22:19:17 +02:00
"es2015.collection.d.ts" ,
"es2015.generator.d.ts" ,
"es2015.iterable.d.ts" ,
"es2015.promise.d.ts" ,
"es2015.proxy.d.ts" ,
"es2015.reflect.d.ts" ,
"es2015.symbol.d.ts" ,
2016-05-19 22:31:21 +02:00
"es2015.symbol.wellknown.d.ts"
2014-07-13 01:04:16 +02:00
] ;
2016-08-19 23:34:14 +02:00
var es2015LibrarySourceMap = es2015LibrarySources . map ( function ( source ) {
return { target : "lib." + source , sources : [ "header.d.ts" , source ] } ;
2016-02-06 02:00:45 +01:00
} ) ;
2016-08-19 23:34:14 +02:00
var es2016LibrarySource = [ "es2016.array.include.d.ts" ] ;
2016-02-06 02:00:45 +01:00
2016-05-19 22:31:21 +02:00
var es2016LibrarySourceMap = es2016LibrarySource . map ( function ( source ) {
2016-02-06 02:00:45 +01:00
return { target : "lib." + source , sources : [ "header.d.ts" , source ] } ;
2016-05-19 22:31:21 +02:00
} ) ;
2016-02-06 02:00:45 +01:00
2016-05-23 17:41:44 +02:00
var es2017LibrarySource = [
"es2017.object.d.ts" ,
2016-11-10 21:43:51 +01:00
"es2017.sharedmemory.d.ts" ,
"es2017.string.d.ts" ,
2016-05-23 17:41:44 +02:00
] ;
2016-05-10 23:22:00 +02:00
2016-05-19 22:31:21 +02:00
var es2017LibrarySourceMap = es2017LibrarySource . map ( function ( source ) {
2016-05-10 23:22:00 +02:00
return { target : "lib." + source , sources : [ "header.d.ts" , source ] } ;
2016-05-19 22:31:21 +02:00
} ) ;
2016-05-10 23:22:00 +02:00
2016-05-19 22:31:21 +02:00
var hostsLibrarySources = [ "dom.generated.d.ts" , "webworker.importscripts.d.ts" , "scripthost.d.ts" ] ;
2016-02-06 02:00:45 +01:00
var librarySourceMap = [
2016-08-19 23:34:14 +02:00
// Host library
{ target : "lib.dom.d.ts" , sources : [ "header.d.ts" , "dom.generated.d.ts" ] } ,
{ target : "lib.dom.iterable.d.ts" , sources : [ "header.d.ts" , "dom.iterable.d.ts" ] } ,
{ target : "lib.webworker.d.ts" , sources : [ "header.d.ts" , "webworker.generated.d.ts" ] } ,
{ target : "lib.scripthost.d.ts" , sources : [ "header.d.ts" , "scripthost.d.ts" ] } ,
// JavaScript library
{ target : "lib.es5.d.ts" , sources : [ "header.d.ts" , "es5.d.ts" ] } ,
{ target : "lib.es2015.d.ts" , sources : [ "header.d.ts" , "es2015.d.ts" ] } ,
{ target : "lib.es2016.d.ts" , sources : [ "header.d.ts" , "es2016.d.ts" ] } ,
{ target : "lib.es2017.d.ts" , sources : [ "header.d.ts" , "es2017.d.ts" ] } ,
// JavaScript + all host library
{ target : "lib.d.ts" , sources : [ "header.d.ts" , "es5.d.ts" ] . concat ( hostsLibrarySources ) } ,
{ target : "lib.es6.d.ts" , sources : [ "header.d.ts" , "es5.d.ts" ] . concat ( es2015LibrarySources , hostsLibrarySources , "dom.iterable.d.ts" ) }
2016-05-10 23:22:00 +02:00
] . concat ( es2015LibrarySourceMap , es2016LibrarySourceMap , es2017LibrarySourceMap ) ;
2016-02-06 02:00:45 +01:00
2014-07-13 01:04:16 +02:00
var libraryTargets = librarySourceMap . map ( function ( f ) {
return path . join ( builtLocalDirectory , f . target ) ;
} ) ;
// Prepends the contents of prefixFile to destinationFile
function prependFile ( prefixFile , destinationFile ) {
if ( ! fs . existsSync ( prefixFile ) ) {
fail ( prefixFile + " does not exist!" ) ;
}
if ( ! fs . existsSync ( destinationFile ) ) {
fail ( destinationFile + " failed to be created!" ) ;
}
var temp = "temptemp" ;
2016-08-19 23:34:14 +02:00
jake . cpR ( prefixFile , temp , { silent : true } ) ;
2014-07-13 01:04:16 +02:00
fs . appendFileSync ( temp , fs . readFileSync ( destinationFile ) ) ;
fs . renameSync ( temp , destinationFile ) ;
}
// concatenate a list of sourceFiles to a destinationFile
function concatenateFiles ( destinationFile , sourceFiles ) {
var temp = "temptemp" ;
// Copy the first file to temp
if ( ! fs . existsSync ( sourceFiles [ 0 ] ) ) {
fail ( sourceFiles [ 0 ] + " does not exist!" ) ;
}
2016-08-19 23:34:14 +02:00
jake . cpR ( sourceFiles [ 0 ] , temp , { silent : true } ) ;
2014-07-13 01:04:16 +02:00
// append all files in sequence
for ( var i = 1 ; i < sourceFiles . length ; i ++ ) {
if ( ! fs . existsSync ( sourceFiles [ i ] ) ) {
2016-08-19 23:34:14 +02:00
fail ( sourceFiles [ i ] + " does not exist!" ) ;
2014-07-13 01:04:16 +02:00
}
2016-10-17 18:46:26 +02:00
fs . appendFileSync ( temp , "\n\n" ) ;
2014-07-13 01:04:16 +02:00
fs . appendFileSync ( temp , fs . readFileSync ( sourceFiles [ i ] ) ) ;
}
// Move the file to the final destination
fs . renameSync ( temp , destinationFile ) ;
}
2014-11-04 21:18:32 +01:00
var useDebugMode = true ;
2016-05-19 22:31:21 +02:00
var host = process . env . TYPESCRIPT_HOST || process . env . host || "node" ;
2014-09-02 21:19:58 +02:00
var compilerFilename = "tsc.js" ;
2015-09-18 22:13:26 +02:00
var LKGCompiler = path . join ( LKGDirectory , compilerFilename ) ;
var builtLocalCompiler = path . join ( builtLocalDirectory , compilerFilename ) ;
2015-03-04 07:12:06 +01:00
/ * C o m p i l e s a f i l e f r o m a l i s t o f s o u r c e s
2014-07-13 01:04:16 +02:00
* @param outFile : the target file name
* @param sources : an array of the names of the source files
* @param prereqs : prerequisite tasks to compiling the file
* @param prefixes : a list of files to prepend to the target file
* @param useBuiltCompiler : true to use the built compiler , false to use the LKG
2016-02-10 09:20:40 +01:00
* @parap { Object } opts - property bag containing auxiliary options
* @param { boolean } opts.noOutFile : true to compile without using -- out
* @param { boolean } opts.generateDeclarations : true to compile using -- declaration
* @param { string } opts.outDir : value for '--outDir' command line option
* @param { boolean } opts.keepComments : false to compile using -- removeComments
* @param { boolean } opts.preserveConstEnums : true if compiler should keep const enums in code
* @param { boolean } opts.noResolve : true if compiler should not include non - rooted files in compilation
* @param { boolean } opts.stripInternal : true if compiler should remove declarations marked as @internal
* @param { boolean } opts.noMapRoot : true if compiler omit mapRoot option
2016-06-11 03:22:20 +02:00
* @param { boolean } opts.inlineSourceMap : true if compiler should inline sourceMap
2016-07-12 01:00:16 +02:00
* @param { Array } opts.types : array of types to include in compilation
2014-12-11 01:42:41 +01:00
* @param callback : a function to execute after the compilation process ends
2014-07-13 01:04:16 +02:00
* /
2016-02-10 09:20:40 +01:00
function compileFile ( outFile , sources , prereqs , prefixes , useBuiltCompiler , opts , callback ) {
2014-07-13 01:04:16 +02:00
file ( outFile , prereqs , function ( ) {
2016-06-07 19:32:03 +02:00
if ( process . env . USE_TRANSFORMS === "false" ) {
useBuiltCompiler = false ;
}
2016-08-12 23:00:50 +02:00
var startCompileTime = mark ( ) ;
2016-02-10 09:20:40 +01:00
opts = opts || { } ;
2016-07-12 01:00:16 +02:00
var compilerPath = useBuiltCompiler ? builtLocalCompiler : LKGCompiler ;
2016-08-19 23:34:14 +02:00
var options = "--noImplicitAny --noImplicitThis --noEmitOnError --types "
2016-07-12 01:00:16 +02:00
if ( opts . types ) {
options += opts . types . join ( "," ) ;
}
options += " --pretty" ;
2015-04-01 03:00:02 +02:00
// Keep comments when specifically requested
// or when in debug mode.
2016-02-10 09:20:40 +01:00
if ( ! ( opts . keepComments || useDebugMode ) ) {
2015-04-01 03:00:02 +02:00
options += " --removeComments" ;
2014-12-11 01:42:41 +01:00
}
2016-02-10 09:20:40 +01:00
if ( opts . generateDeclarations ) {
2014-12-11 01:42:41 +01:00
options += " --declaration" ;
2014-10-08 05:51:23 +02:00
}
2014-11-04 20:27:34 +01:00
2016-02-10 09:20:40 +01:00
if ( opts . preserveConstEnums || useDebugMode ) {
2014-12-11 01:42:41 +01:00
options += " --preserveConstEnums" ;
}
2016-02-10 09:20:40 +01:00
if ( opts . outDir ) {
options += " --outDir " + opts . outDir ;
2014-12-11 01:42:41 +01:00
}
2016-02-10 09:20:40 +01:00
if ( ! opts . noOutFile ) {
2014-12-11 01:42:41 +01:00
options += " --out " + outFile ;
2015-10-21 00:14:18 +02:00
}
else {
2016-05-19 22:31:21 +02:00
options += " --module commonjs" ;
2014-12-11 01:42:41 +01:00
}
2016-08-19 23:34:14 +02:00
if ( opts . noResolve ) {
2014-12-11 01:42:41 +01:00
options += " --noResolve" ;
2014-07-13 01:04:16 +02:00
}
2014-08-04 21:06:50 +02:00
2014-07-13 01:04:16 +02:00
if ( useDebugMode ) {
2016-06-11 03:22:20 +02:00
if ( opts . inlineSourceMap ) {
options += " --inlineSourceMap --inlineSources" ;
} else {
options += " -sourcemap" ;
if ( ! opts . noMapRoot ) {
options += " -mapRoot file:///" + path . resolve ( path . dirname ( outFile ) ) ;
}
}
2016-06-08 19:33:03 +02:00
} else {
options += " --newLine LF" ;
2014-07-13 01:04:16 +02:00
}
2014-12-11 01:42:41 +01:00
2016-02-10 09:20:40 +01:00
if ( opts . stripInternal ) {
2016-05-19 22:31:21 +02:00
options += " --stripInternal" ;
2015-02-03 22:47:46 +01:00
}
2016-10-19 17:27:49 +02:00
options += " --target es5 --noUnusedLocals --noUnusedParameters" ;
2016-10-18 16:34:48 +02:00
2015-09-18 22:13:26 +02:00
var cmd = host + " " + compilerPath + " " + options + " " ;
2014-12-11 01:42:41 +01:00
cmd = cmd + sources . join ( " " ) ;
2015-03-04 07:12:06 +01:00
console . log ( cmd + "\n" ) ;
2014-12-11 01:42:41 +01:00
2015-03-04 07:12:06 +01:00
var ex = jake . createExec ( [ cmd ] ) ;
// Add listeners for output and error
2016-08-19 23:34:14 +02:00
ex . addListener ( "stdout" , function ( output ) {
2015-03-04 07:12:06 +01:00
process . stdout . write ( output ) ;
} ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "stderr" , function ( error ) {
2015-03-04 07:12:06 +01:00
process . stderr . write ( error ) ;
} ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "cmdEnd" , function ( ) {
2014-07-13 01:04:16 +02:00
if ( ! useDebugMode && prefixes && fs . existsSync ( outFile ) ) {
for ( var i in prefixes ) {
prependFile ( prefixes [ i ] , outFile ) ;
}
}
2014-12-02 00:32:52 +01:00
if ( callback ) {
callback ( ) ;
}
2015-03-04 07:12:06 +01:00
2016-08-12 23:00:50 +02:00
measure ( startCompileTime ) ;
2015-03-04 07:12:06 +01:00
complete ( ) ;
} ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "error" , function ( ) {
2014-07-13 01:04:16 +02:00
fs . unlinkSync ( outFile ) ;
2014-12-12 17:49:21 +01:00
fail ( "Compilation of " + outFile + " unsuccessful" ) ;
2016-08-12 23:00:50 +02:00
measure ( startCompileTime ) ;
2014-07-13 01:04:16 +02:00
} ) ;
2015-03-04 07:12:06 +01:00
ex . run ( ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-07-13 01:04:16 +02:00
}
// Prerequisite task for built directory and library typings
directory ( builtLocalDirectory ) ;
for ( var i in libraryTargets ) {
( function ( i ) {
var entry = librarySourceMap [ i ] ;
var target = libraryTargets [ i ] ;
var sources = [ copyright ] . concat ( entry . sources . map ( function ( s ) {
return path . join ( libraryDirectory , s ) ;
} ) ) ;
2016-08-19 23:34:14 +02:00
file ( target , [ builtLocalDirectory ] . concat ( sources ) , function ( ) {
2014-07-13 01:04:16 +02:00
concatenateFiles ( target , sources ) ;
} ) ;
} ) ( i ) ;
}
// Lib target to build the library files
desc ( "Builds the library targets" ) ;
task ( "lib" , libraryTargets ) ;
// Generate diagnostics
var processDiagnosticMessagesJs = path . join ( scriptsDirectory , "processDiagnosticMessages.js" ) ;
var processDiagnosticMessagesTs = path . join ( scriptsDirectory , "processDiagnosticMessages.ts" ) ;
var diagnosticMessagesJson = path . join ( compilerDirectory , "diagnosticMessages.json" ) ;
var diagnosticInfoMapTs = path . join ( compilerDirectory , "diagnosticInformationMap.generated.ts" ) ;
2015-10-27 21:20:12 +01:00
var generatedDiagnosticMessagesJSON = path . join ( compilerDirectory , "diagnosticMessages.generated.json" ) ;
var builtGeneratedDiagnosticMessagesJSON = path . join ( builtLocalDirectory , "diagnosticMessages.generated.json" ) ;
2014-07-13 01:04:16 +02:00
2015-07-15 21:56:00 +02:00
file ( processDiagnosticMessagesTs ) ;
2014-08-01 02:20:57 +02:00
2014-07-13 01:04:16 +02:00
// processDiagnosticMessages script
compileFile ( processDiagnosticMessagesJs ,
2016-08-19 23:34:14 +02:00
[ processDiagnosticMessagesTs ] ,
[ processDiagnosticMessagesTs ] ,
[ ] ,
2014-12-02 00:32:52 +01:00
/*useBuiltCompiler*/ false ) ;
2014-07-13 01:04:16 +02:00
2016-10-12 20:02:56 +02:00
var buildProtocolTs = path . join ( scriptsDirectory , "buildProtocol.ts" ) ;
var buildProtocolJs = path . join ( scriptsDirectory , "buildProtocol.js" ) ;
var buildProtocolDts = path . join ( builtLocalDirectory , "protocol.d.ts" ) ;
var typescriptServicesDts = path . join ( builtLocalDirectory , "typescriptServices.d.ts" ) ;
file ( buildProtocolTs ) ;
compileFile ( buildProtocolJs ,
[ buildProtocolTs ] ,
[ buildProtocolTs ] ,
[ ] ,
/*useBuiltCompiler*/ false ,
{ noOutFile : true } ) ;
file ( buildProtocolDts , [ buildProtocolTs , buildProtocolJs , typescriptServicesDts ] , function ( ) {
var protocolTs = path . join ( serverDirectory , "protocol.ts" ) ;
var cmd = host + " " + buildProtocolJs + " " + protocolTs + " " + typescriptServicesDts + " " + buildProtocolDts ;
console . log ( cmd ) ;
var ex = jake . createExec ( [ cmd ] ) ;
// Add listeners for output and error
ex . addListener ( "stdout" , function ( output ) {
process . stdout . write ( output ) ;
} ) ;
ex . addListener ( "stderr" , function ( error ) {
process . stderr . write ( error ) ;
} ) ;
ex . addListener ( "cmdEnd" , function ( ) {
complete ( ) ;
} ) ;
ex . run ( ) ;
} , { async : true } )
2014-07-13 01:04:16 +02:00
// The generated diagnostics map; built for the compiler and for the 'generate-diagnostics' task
file ( diagnosticInfoMapTs , [ processDiagnosticMessagesJs , diagnosticMessagesJson ] , function ( ) {
2016-08-19 23:34:14 +02:00
var cmd = host + " " + processDiagnosticMessagesJs + " " + diagnosticMessagesJson ;
2015-03-04 07:12:06 +01:00
console . log ( cmd ) ;
var ex = jake . createExec ( [ cmd ] ) ;
// Add listeners for output and error
2016-08-19 23:34:14 +02:00
ex . addListener ( "stdout" , function ( output ) {
2015-03-04 07:12:06 +01:00
process . stdout . write ( output ) ;
} ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "stderr" , function ( error ) {
2015-03-04 07:12:06 +01:00
process . stderr . write ( error ) ;
} ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "cmdEnd" , function ( ) {
2015-03-04 07:12:06 +01:00
complete ( ) ;
} ) ;
ex . run ( ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-07-13 01:04:16 +02:00
2016-08-19 23:34:14 +02:00
file ( builtGeneratedDiagnosticMessagesJSON , [ generatedDiagnosticMessagesJSON ] , function ( ) {
2015-10-27 22:16:05 +01:00
if ( fs . existsSync ( builtLocalDirectory ) ) {
jake . cpR ( generatedDiagnosticMessagesJSON , builtGeneratedDiagnosticMessagesJSON ) ;
}
2015-10-28 19:40:33 +01:00
} ) ;
2015-10-27 22:16:05 +01:00
2014-07-13 01:04:16 +02:00
desc ( "Generates a diagnostic file in TypeScript based on an input JSON file" ) ;
2015-07-30 17:00:29 +02:00
task ( "generate-diagnostics" , [ diagnosticInfoMapTs ] ) ;
2014-07-13 01:04:16 +02:00
2015-07-15 21:56:00 +02:00
// Publish nightly
var configureNightlyJs = path . join ( scriptsDirectory , "configureNightly.js" ) ;
var configureNightlyTs = path . join ( scriptsDirectory , "configureNightly.ts" ) ;
var packageJson = "package.json" ;
2015-07-23 21:53:41 +02:00
var programTs = path . join ( compilerDirectory , "program.ts" ) ;
2015-07-15 21:56:00 +02:00
file ( configureNightlyTs ) ;
compileFile ( /*outfile*/ configureNightlyJs ,
2016-08-19 23:34:14 +02:00
/*sources*/ [ configureNightlyTs ] ,
/*prereqs*/ [ configureNightlyTs ] ,
/*prefixes*/ [ ] ,
2015-07-15 21:56:00 +02:00
/*useBuiltCompiler*/ false ,
2016-08-19 23:34:14 +02:00
{ noOutFile : false , generateDeclarations : false , keepComments : false , noResolve : false , stripInternal : false } ) ;
2015-07-23 21:32:17 +02:00
2016-08-19 23:34:14 +02:00
task ( "setDebugMode" , function ( ) {
2015-07-15 21:56:00 +02:00
useDebugMode = true ;
} ) ;
2016-08-19 23:34:14 +02:00
task ( "configure-nightly" , [ configureNightlyJs ] , function ( ) {
2015-09-18 22:13:26 +02:00
var cmd = host + " " + configureNightlyJs + " " + packageJson + " " + programTs ;
2015-07-23 21:32:17 +02:00
console . log ( cmd ) ;
exec ( cmd ) ;
} , { async : true } ) ;
2015-07-15 21:56:00 +02:00
desc ( "Configure, build, test, and publish the nightly release." ) ;
2015-07-23 21:32:17 +02:00
task ( "publish-nightly" , [ "configure-nightly" , "LKG" , "clean" , "setDebugMode" , "runtests" ] , function ( ) {
var cmd = "npm publish --tag next" ;
2015-07-15 21:56:00 +02:00
console . log ( cmd ) ;
2015-07-23 21:32:17 +02:00
exec ( cmd ) ;
} ) ;
2015-07-15 21:56:00 +02:00
2015-09-18 02:55:07 +02:00
var importDefinitelyTypedTestsDirectory = path . join ( scriptsDirectory , "importDefinitelyTypedTests" ) ;
var importDefinitelyTypedTestsJs = path . join ( importDefinitelyTypedTestsDirectory , "importDefinitelyTypedTests.js" ) ;
var importDefinitelyTypedTestsTs = path . join ( importDefinitelyTypedTestsDirectory , "importDefinitelyTypedTests.ts" ) ;
2015-09-18 22:13:26 +02:00
file ( importDefinitelyTypedTestsTs ) ;
file ( importDefinitelyTypedTestsJs , [ "tsd-scripts" , importDefinitelyTypedTestsTs ] , function ( ) {
var cmd = host + " " + LKGCompiler + " -p " + importDefinitelyTypedTestsDirectory ;
2015-09-18 02:55:07 +02:00
console . log ( cmd ) ;
exec ( cmd ) ;
2015-09-18 22:13:26 +02:00
} , { async : true } ) ;
task ( "importDefinitelyTypedTests" , [ importDefinitelyTypedTestsJs ] , function ( ) {
var cmd = host + " " + importDefinitelyTypedTestsJs + " ./ ../DefinitelyTyped" ;
console . log ( cmd ) ;
exec ( cmd ) ;
} , { async : true } ) ;
2015-09-18 02:55:07 +02:00
2014-07-13 01:04:16 +02:00
// Local target to build the compiler and services
2014-09-02 21:19:58 +02:00
var tscFile = path . join ( builtLocalDirectory , compilerFilename ) ;
2014-08-07 08:21:53 +02:00
compileFile ( tscFile , compilerSources , [ builtLocalDirectory , copyright ] . concat ( compilerSources ) , [ copyright ] , /*useBuiltCompiler:*/ false ) ;
2014-07-13 01:04:16 +02:00
2014-08-07 08:21:53 +02:00
var servicesFile = path . join ( builtLocalDirectory , "typescriptServices.js" ) ;
2016-06-11 03:22:20 +02:00
var servicesFileInBrowserTest = path . join ( builtLocalDirectory , "typescriptServicesInBrowserTest.js" ) ;
2015-04-09 23:15:07 +02:00
var standaloneDefinitionsFile = path . join ( builtLocalDirectory , "typescriptServices.d.ts" ) ;
2015-02-01 06:14:28 +01:00
var nodePackageFile = path . join ( builtLocalDirectory , "typescript.js" ) ;
2015-04-09 23:15:07 +02:00
var nodeDefinitionsFile = path . join ( builtLocalDirectory , "typescript.d.ts" ) ;
2015-09-08 21:26:29 +02:00
var nodeStandaloneDefinitionsFile = path . join ( builtLocalDirectory , "typescript_standalone.d.ts" ) ;
2015-04-09 23:15:07 +02:00
2016-08-19 23:34:14 +02:00
compileFile ( servicesFile , servicesSources , [ builtLocalDirectory , copyright ] . concat ( servicesSources ) ,
/*prefixes*/ [ copyright ] ,
2014-12-13 01:17:30 +01:00
/*useBuiltCompiler*/ true ,
2016-08-19 23:34:14 +02:00
/*opts*/ {
noOutFile : false ,
generateDeclarations : true ,
preserveConstEnums : true ,
keepComments : true ,
noResolve : false ,
stripInternal : true
} ,
2015-07-10 01:39:58 +02:00
/*callback*/ function ( ) {
2016-08-19 23:34:14 +02:00
jake . cpR ( servicesFile , nodePackageFile , { silent : true } ) ;
2014-12-02 00:32:52 +01:00
2016-08-19 23:34:14 +02:00
prependFile ( copyright , standaloneDefinitionsFile ) ;
2014-12-11 01:42:41 +01:00
2016-08-19 23:34:14 +02:00
// Stanalone/web definition file using global 'ts' namespace
jake . cpR ( standaloneDefinitionsFile , nodeDefinitionsFile , { silent : true } ) ;
var definitionFileContents = fs . readFileSync ( nodeDefinitionsFile ) . toString ( ) ;
definitionFileContents = definitionFileContents . replace ( /^(\s*)(export )?const enum (\S+) {(\s*)$/gm , '$1$2enum $3 {$4' ) ;
fs . writeFileSync ( standaloneDefinitionsFile , definitionFileContents ) ;
2015-09-08 21:26:29 +02:00
2016-08-19 23:34:14 +02:00
// Official node package definition file, pointed to by 'typings' in package.json
// Created by appending 'export = ts;' at the end of the standalone file to turn it into an external module
var nodeDefinitionsFileContents = definitionFileContents + "\r\nexport = ts;" ;
fs . writeFileSync ( nodeDefinitionsFile , nodeDefinitionsFileContents ) ;
2015-09-08 21:26:29 +02:00
2016-08-19 23:34:14 +02:00
// Node package definition file to be distributed without the package. Created by replacing
// 'ts' namespace with '"typescript"' as a module.
var nodeStandaloneDefinitionsFileContents = definitionFileContents . replace ( /declare (namespace|module) ts/g , 'declare module "typescript"' ) ;
fs . writeFileSync ( nodeStandaloneDefinitionsFile , nodeStandaloneDefinitionsFileContents ) ;
} ) ;
2014-12-11 01:42:41 +01:00
2016-06-11 03:22:20 +02:00
compileFile (
servicesFileInBrowserTest ,
servicesSources ,
[ builtLocalDirectory , copyright ] . concat ( servicesSources ) ,
2016-08-19 23:34:14 +02:00
/*prefixes*/ [ copyright ] ,
2016-06-11 03:22:20 +02:00
/*useBuiltCompiler*/ true ,
2016-08-19 23:34:14 +02:00
{
noOutFile : false ,
generateDeclarations : true ,
preserveConstEnums : true ,
keepComments : true ,
noResolve : false ,
stripInternal : true ,
noMapRoot : true ,
inlineSourceMap : true
} ) ;
2014-07-13 01:04:16 +02:00
2016-10-12 20:02:56 +02:00
file ( typescriptServicesDts , [ servicesFile ] ) ;
2016-06-15 02:30:55 +02:00
var cancellationTokenFile = path . join ( builtLocalDirectory , "cancellationToken.js" ) ;
compileFile ( cancellationTokenFile , cancellationTokenSources , [ builtLocalDirectory ] . concat ( cancellationTokenSources ) , /*prefixes*/ [ copyright ] , /*useBuiltCompiler*/ true , { outDir : builtLocalDirectory , noOutFile : true } ) ;
2016-08-12 23:01:23 +02:00
var typingsInstallerFile = path . join ( builtLocalDirectory , "typingsInstaller.js" ) ;
compileFile ( typingsInstallerFile , typingsInstallerSources , [ builtLocalDirectory ] . concat ( typingsInstallerSources ) , /*prefixes*/ [ copyright ] , /*useBuiltCompiler*/ true , { outDir : builtLocalDirectory , noOutFile : false } ) ;
2015-02-16 03:52:17 +01:00
var serverFile = path . join ( builtLocalDirectory , "tsserver.js" ) ;
2016-08-20 02:36:02 +02:00
compileFile ( serverFile , serverSources , [ builtLocalDirectory , copyright , cancellationTokenFile , typingsInstallerFile ] . concat ( serverSources ) , /*prefixes*/ [ copyright ] , /*useBuiltCompiler*/ true , { types : [ "node" ] } ) ;
2016-05-19 22:32:27 +02:00
var tsserverLibraryFile = path . join ( builtLocalDirectory , "tsserverlibrary.js" ) ;
2016-05-21 21:36:06 +02:00
var tsserverLibraryDefinitionFile = path . join ( builtLocalDirectory , "tsserverlibrary.d.ts" ) ;
2015-06-10 02:00:35 +02:00
compileFile (
2016-05-19 22:31:21 +02:00
tsserverLibraryFile ,
2015-07-10 01:39:58 +02:00
languageServiceLibrarySources ,
2016-08-05 23:16:29 +02:00
[ builtLocalDirectory , copyright , builtLocalCompiler ] . concat ( languageServiceLibrarySources ) . concat ( libraryTargets ) ,
2016-08-19 23:34:14 +02:00
/*prefixes*/ [ copyright ] ,
2015-07-10 01:39:58 +02:00
/*useBuiltCompiler*/ true ,
2016-02-10 09:20:40 +01:00
{ noOutFile : false , generateDeclarations : true } ) ;
2015-06-10 02:00:35 +02:00
// Local target to build the language service server library
desc ( "Builds language service server library" ) ;
2016-05-21 21:36:06 +02:00
task ( "lssl" , [ tsserverLibraryFile , tsserverLibraryDefinitionFile ] ) ;
2015-06-10 02:00:35 +02:00
2016-08-11 18:53:38 +02:00
desc ( "Emit the start of the build fold" ) ;
2016-08-19 23:34:14 +02:00
task ( "build-fold-start" , [ ] , function ( ) {
2016-08-11 18:53:38 +02:00
if ( fold . isTravis ( ) ) console . log ( fold . start ( "build" ) ) ;
} ) ;
desc ( "Emit the end of the build fold" ) ;
2016-08-19 23:34:14 +02:00
task ( "build-fold-end" , [ ] , function ( ) {
2016-08-11 18:53:38 +02:00
if ( fold . isTravis ( ) ) console . log ( fold . end ( "build" ) ) ;
} ) ;
2014-07-13 01:04:16 +02:00
// Local target to build the compiler and services
desc ( "Builds the full compiler and services" ) ;
2016-10-12 20:02:56 +02:00
task ( "local" , [ "build-fold-start" , "generate-diagnostics" , "lib" , tscFile , servicesFile , nodeDefinitionsFile , serverFile , buildProtocolDts , builtGeneratedDiagnosticMessagesJSON , "lssl" , "build-fold-end" ] ) ;
2014-07-13 01:04:16 +02:00
2015-02-04 14:52:45 +01:00
// Local target to build only tsc.js
desc ( "Builds only the compiler" ) ;
task ( "tsc" , [ "generate-diagnostics" , "lib" , tscFile ] ) ;
2014-07-13 01:04:16 +02:00
// Local target to build the compiler and services
2014-11-04 21:18:32 +01:00
desc ( "Sets release mode flag" ) ;
2016-08-19 23:34:14 +02:00
task ( "release" , function ( ) {
2014-11-04 21:18:32 +01:00
useDebugMode = false ;
2014-07-13 01:04:16 +02:00
} ) ;
// Set the default task to "local"
task ( "default" , [ "local" ] ) ;
// Cleans the built directory
desc ( "Cleans the compiler output, declare files, and tests" ) ;
2016-08-19 23:34:14 +02:00
task ( "clean" , function ( ) {
2014-07-13 01:04:16 +02:00
jake . rmRf ( builtDirectory ) ;
} ) ;
2014-09-26 23:36:18 +02:00
// Generate Markdown spec
var word2mdJs = path . join ( scriptsDirectory , "word2md.js" ) ;
var word2mdTs = path . join ( scriptsDirectory , "word2md.ts" ) ;
var specWord = path . join ( docDirectory , "TypeScript Language Specification.docx" ) ;
var specMd = path . join ( docDirectory , "spec.md" ) ;
file ( word2mdTs ) ;
// word2md script
compileFile ( word2mdJs ,
2016-08-19 23:34:14 +02:00
[ word2mdTs ] ,
[ word2mdTs ] ,
[ ] ,
2014-12-02 00:32:52 +01:00
/*useBuiltCompiler*/ false ) ;
2014-09-26 23:36:18 +02:00
// The generated spec.md; built for the 'generate-spec' task
file ( specMd , [ word2mdJs , specWord ] , function ( ) {
2014-10-08 05:51:23 +02:00
var specWordFullPath = path . resolve ( specWord ) ;
2015-12-08 22:55:59 +01:00
var specMDFullPath = path . resolve ( specMd ) ;
var cmd = "cscript //nologo " + word2mdJs + ' "' + specWordFullPath + '" ' + '"' + specMDFullPath + '"' ;
2015-03-04 07:12:06 +01:00
console . log ( cmd ) ;
child_process . exec ( cmd , function ( ) {
complete ( ) ;
} ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-09-26 23:36:18 +02:00
desc ( "Generates a Markdown version of the Language Specification" ) ;
2015-07-30 17:00:29 +02:00
task ( "generate-spec" , [ specMd ] ) ;
2014-09-26 23:36:18 +02:00
2014-07-13 01:04:16 +02:00
// Makes a new LKG. This target does not build anything, but errors if not all the outputs are present in the built/local directory
desc ( "Makes a new LKG out of the built js files" ) ;
2016-08-19 23:34:14 +02:00
task ( "LKG" , [ "clean" , "release" , "local" ] . concat ( libraryTargets ) , function ( ) {
2016-10-12 20:02:56 +02:00
var expectedFiles = [ tscFile , servicesFile , serverFile , nodePackageFile , nodeDefinitionsFile , standaloneDefinitionsFile , tsserverLibraryFile , tsserverLibraryDefinitionFile , cancellationTokenFile , typingsInstallerFile , buildProtocolDts ] . concat ( libraryTargets ) ;
2014-07-13 01:04:16 +02:00
var missingFiles = expectedFiles . filter ( function ( f ) {
return ! fs . existsSync ( f ) ;
} ) ;
if ( missingFiles . length > 0 ) {
fail ( "Cannot replace the LKG unless all built targets are present in directory " + builtLocalDirectory +
2016-08-19 23:34:14 +02:00
". The following files are missing:\n" + missingFiles . join ( "\n" ) ) ;
2014-07-13 01:04:16 +02:00
}
// Copy all the targets into the LKG directory
jake . mkdirP ( LKGDirectory ) ;
for ( i in expectedFiles ) {
jake . cpR ( expectedFiles [ i ] , LKGDirectory ) ;
}
//var resourceDirectories = fs.readdirSync(builtLocalResourcesDirectory).map(function(p) { return path.join(builtLocalResourcesDirectory, p); });
//resourceDirectories.map(function(d) {
// jake.cpR(d, LKGResourcesDirectory);
//});
} ) ;
// Test directory
directory ( builtLocalDirectory ) ;
// Task to build the tests infrastructure using the built compiler
var run = path . join ( builtLocalDirectory , "run.js" ) ;
2016-06-11 03:22:20 +02:00
compileFile (
/*outFile*/ run ,
/*source*/ harnessSources ,
2016-08-19 23:34:14 +02:00
/*prereqs*/ [ builtLocalDirectory , tscFile ] . concat ( libraryTargets ) . concat ( servicesSources ) . concat ( harnessSources ) ,
/*prefixes*/ [ ] ,
2016-06-11 03:22:20 +02:00
/*useBuiltCompiler:*/ true ,
2016-07-12 01:00:16 +02:00
/*opts*/ { inlineSourceMap : true , types : [ "node" , "mocha" , "chai" ] } ) ;
2014-07-13 01:04:16 +02:00
2016-05-19 22:31:21 +02:00
var internalTests = "internal/" ;
2015-01-30 19:32:07 +01:00
2014-07-13 01:04:16 +02:00
var localBaseline = "tests/baselines/local/" ;
var refBaseline = "tests/baselines/reference/" ;
2015-02-02 21:52:26 +01:00
var localRwcBaseline = path . join ( internalTests , "baselines/rwc/local" ) ;
var refRwcBaseline = path . join ( internalTests , "baselines/rwc/reference" ) ;
2014-07-13 01:04:16 +02:00
2015-02-02 21:52:26 +01:00
var localTest262Baseline = path . join ( internalTests , "baselines/test262/local" ) ;
var refTest262Baseline = path . join ( internalTests , "baselines/test262/reference" ) ;
2014-11-17 20:01:05 +01:00
2014-07-13 01:04:16 +02:00
desc ( "Builds the test infrastructure using the built compiler" ) ;
task ( "tests" , [ "local" , run ] . concat ( libraryTargets ) ) ;
2015-07-10 01:39:58 +02:00
function exec ( cmd , completeHandler , errorHandler ) {
2016-08-19 23:34:14 +02:00
var ex = jake . createExec ( [ cmd ] , { windowsVerbatimArguments : true } ) ;
2015-03-04 07:12:06 +01:00
// Add listeners for output and error
2016-08-19 23:34:14 +02:00
ex . addListener ( "stdout" , function ( output ) {
2015-03-04 07:12:06 +01:00
process . stdout . write ( output ) ;
} ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "stderr" , function ( error ) {
2015-03-04 07:12:06 +01:00
process . stderr . write ( error ) ;
} ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "cmdEnd" , function ( ) {
2014-07-17 21:32:51 +02:00
if ( completeHandler ) {
completeHandler ( ) ;
}
2015-03-04 07:12:06 +01:00
complete ( ) ;
2014-07-13 01:04:16 +02:00
} ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "error" , function ( e , status ) {
if ( errorHandler ) {
2015-07-10 01:39:58 +02:00
errorHandler ( e , status ) ;
} else {
fail ( "Process exited with code " + status ) ;
}
} ) ;
2014-12-17 00:28:36 +01:00
ex . run ( ) ;
2014-07-13 01:04:16 +02:00
}
function cleanTestDirs() {
// Clean the local baselines directory
if ( fs . existsSync ( localBaseline ) ) {
jake . rmRf ( localBaseline ) ;
}
2015-01-30 19:32:07 +01:00
// Clean the local Rwc baselines directory
2014-07-13 01:04:16 +02:00
if ( fs . existsSync ( localRwcBaseline ) ) {
jake . rmRf ( localRwcBaseline ) ;
}
2015-01-30 19:32:07 +01:00
jake . mkdirP ( localRwcBaseline ) ;
2015-03-19 00:37:52 +01:00
jake . mkdirP ( localTest262Baseline ) ;
2014-07-13 01:04:16 +02:00
jake . mkdirP ( localBaseline ) ;
}
// used to pass data from jake command line directly to run.js
2016-06-07 19:32:03 +02:00
function writeTestConfigFile ( tests , light , taskConfigsFolder , workerCount , stackTraceLimit ) {
2016-09-15 02:25:56 +02:00
var testConfigContents = JSON . stringify ( {
2016-06-07 19:32:03 +02:00
test : tests ? [ tests ] : undefined ,
light : light ,
workerCount : workerCount ,
taskConfigsFolder : taskConfigsFolder ,
stackTraceLimit : stackTraceLimit
} ) ;
2014-09-18 20:49:40 +02:00
fs . writeFileSync ( 'test.config' , testConfigContents ) ;
2014-07-13 01:04:16 +02:00
}
2014-07-17 21:32:51 +02:00
function deleteTemporaryProjectOutput() {
2015-02-02 21:52:26 +01:00
if ( fs . existsSync ( path . join ( localBaseline , "projectOutput/" ) ) ) {
jake . rmRf ( path . join ( localBaseline , "projectOutput/" ) ) ;
2014-07-17 21:32:51 +02:00
}
}
2016-05-24 01:00:56 +02:00
function runConsoleTests ( defaultReporter , runInParallel ) {
2016-06-07 19:32:03 +02:00
var dirty = process . env . dirty ;
2016-04-13 03:40:39 +02:00
if ( ! dirty ) {
cleanTestDirs ( ) ;
}
2015-09-05 03:01:43 +02:00
var debug = process . env . debug || process . env . d ;
2014-07-18 00:26:50 +02:00
tests = process . env . test || process . env . tests || process . env . t ;
2015-04-29 21:13:35 +02:00
var light = process . env . light || false ;
2016-06-07 19:32:03 +02:00
var stackTraceLimit = process . env . stackTraceLimit ;
2014-07-13 01:04:16 +02:00
var testConfigFile = 'test.config' ;
2016-08-19 23:34:14 +02:00
if ( fs . existsSync ( testConfigFile ) ) {
2014-07-13 01:04:16 +02:00
fs . unlinkSync ( testConfigFile ) ;
}
2016-05-24 01:00:56 +02:00
var workerCount , taskConfigsFolder ;
if ( runInParallel ) {
// generate name to store task configuration files
var prefix = os . tmpdir ( ) + "/ts-tests" ;
var i = 1 ;
do {
taskConfigsFolder = prefix + i ;
i ++ ;
} while ( fs . existsSync ( taskConfigsFolder ) ) ;
fs . mkdirSync ( taskConfigsFolder ) ;
workerCount = process . env . workerCount || os . cpus ( ) . length ;
}
2014-09-03 19:37:32 +02:00
2016-05-24 01:00:56 +02:00
if ( tests || light || taskConfigsFolder ) {
2016-06-01 03:43:51 +02:00
writeTestConfigFile ( tests , light , taskConfigsFolder , workerCount , stackTraceLimit ) ;
2014-07-13 01:04:16 +02:00
}
2014-09-03 19:37:32 +02:00
if ( tests && tests . toLocaleLowerCase ( ) === "rwc" ) {
2016-07-01 18:59:30 +02:00
testTimeout = 400000 ;
2014-09-03 19:37:32 +02:00
}
2016-05-19 22:31:21 +02:00
colors = process . env . colors || process . env . color ;
2015-02-24 01:16:26 +01:00
colors = colors ? ' --no-colors ' : ' --colors ' ;
2015-10-26 18:25:01 +01:00
reporter = process . env . reporter || process . env . r || defaultReporter ;
2016-06-13 22:35:37 +02:00
var bail = ( process . env . bail || process . env . b ) ? "--bail" : "" ;
2016-05-16 20:53:44 +02:00
var lintFlag = process . env . lint !== 'false' ;
2015-10-26 18:25:01 +01:00
2014-07-26 02:01:01 +02:00
// timeout normally isn't necessary but Travis-CI has been timing out on compiler baselines occasionally
// default timeout is 2sec which really should be enough, but maybe we just need a small amount longer
2016-08-19 23:34:14 +02:00
if ( ! runInParallel ) {
2016-08-12 23:00:50 +02:00
var startTime = mark ( ) ;
2016-05-24 01:00:56 +02:00
tests = tests ? ' -g "' + tests + '"' : '' ;
2016-06-13 22:35:37 +02:00
var cmd = "mocha" + ( debug ? " --debug-brk" : "" ) + " -R " + reporter + tests + colors + bail + ' -t ' + testTimeout + ' ' + run ;
2015-10-24 01:27:44 +02:00
console . log ( cmd ) ;
2016-06-10 07:07:07 +02:00
var savedNodeEnv = process . env . NODE_ENV ;
process . env . NODE_ENV = "development" ;
2016-05-20 22:40:34 +02:00
exec ( cmd , function ( ) {
2016-06-10 07:07:07 +02:00
process . env . NODE_ENV = savedNodeEnv ;
2016-08-12 23:00:50 +02:00
measure ( startTime ) ;
2016-05-24 23:29:52 +02:00
runLinter ( ) ;
2016-05-20 22:40:34 +02:00
finish ( ) ;
2016-08-19 23:34:14 +02:00
} , function ( e , status ) {
2016-06-10 07:07:07 +02:00
process . env . NODE_ENV = savedNodeEnv ;
2016-08-12 23:00:50 +02:00
measure ( startTime ) ;
2016-05-26 01:23:51 +02:00
finish ( status ) ;
} ) ;
2016-06-06 20:37:59 +02:00
2016-05-24 01:00:56 +02:00
}
else {
2016-06-10 07:07:07 +02:00
var savedNodeEnv = process . env . NODE_ENV ;
process . env . NODE_ENV = "development" ;
2016-08-12 23:00:50 +02:00
var startTime = mark ( ) ;
2016-06-09 03:09:36 +02:00
runTestsInParallel ( taskConfigsFolder , run , { testTimeout : testTimeout , noColors : colors === " --no-colors " } , function ( err ) {
2016-06-10 07:07:07 +02:00
process . env . NODE_ENV = savedNodeEnv ;
2016-08-12 23:00:50 +02:00
measure ( startTime ) ;
2016-06-09 03:09:36 +02:00
// last worker clean everything and runs linter in case if there were no errors
deleteTemporaryProjectOutput ( ) ;
jake . rmRf ( taskConfigsFolder ) ;
if ( err ) {
fail ( err ) ;
}
else {
runLinter ( ) ;
complete ( ) ;
2016-05-24 01:00:56 +02:00
}
} ) ;
}
2016-06-06 20:37:59 +02:00
2016-05-26 01:23:51 +02:00
function failWithStatus ( status ) {
fail ( "Process exited with code " + status ) ;
}
2016-06-06 20:37:59 +02:00
2016-05-26 01:23:51 +02:00
function finish ( errorStatus ) {
2016-05-24 01:00:56 +02:00
deleteTemporaryProjectOutput ( ) ;
2016-05-26 01:23:51 +02:00
if ( errorStatus !== undefined ) {
failWithStatus ( errorStatus ) ;
2016-05-20 22:40:34 +02:00
}
2016-05-26 01:23:51 +02:00
else {
complete ( ) ;
}
2016-05-24 01:00:56 +02:00
}
function runLinter() {
2016-06-01 03:43:51 +02:00
if ( ! lintFlag || dirty ) {
2016-05-24 01:00:56 +02:00
return ;
}
var lint = jake . Task [ 'lint' ] ;
lint . addListener ( 'complete' , function ( ) {
complete ( ) ;
} ) ;
lint . invoke ( ) ;
}
2015-10-26 18:25:01 +01:00
}
var testTimeout = 20000 ;
desc ( "Runs all the tests in parallel using the built run.js file. Optional arguments are: t[ests]=category1|category2|... d[ebug]=true." ) ;
2016-08-19 23:34:14 +02:00
task ( "runtests-parallel" , [ "build-rules" , "tests" , builtLocalDirectory ] , function ( ) {
2016-05-24 01:00:56 +02:00
runConsoleTests ( 'min' , /*runInParallel*/ true ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2015-10-24 01:27:44 +02:00
[Transforms] Merge master 06/14/2016 (#9169)
* Remove check narrowing only certain types, add test showing issues with this
* string literal case test
* Reconcile fix with CFA work
* Defaultable -> NotNarrowable to align with use
* Missed a defaultable in comments
* Add test for narrowing to unions of string literals
* Rewrite isInStringLiteral to accomodate for unterminated strings
* Refactor signatureHelp to expose helper functions
* Add support for completion in string literals
* Remove unused check
* Use const instead of let
* Fix error
* Formatting changes
* Use shorthand properties
* Add failing test for #8738
* Sort baseline reference identifier by name
* Detects assignment to internal module export clause, fixes #8738
* add SharedArrayBuffer
fix
* Factor out assignment op check
* Add test for composite assignment
* Factor out the behaviour and handles x++ and ++x
* Handles ES3 default as identifier name
* Fix missing else statement
* isNameOfExportedDeclarationInNonES6Module
* Reorder options alphabetically
* Mark diagnostics, and skipDefaultLibCheck as internal
* Allow an import of "foo.js" to be matched by a file "foo.ts"
* Improve loadModuleFromFile code
* Respond to PR comments
* Respond to more PR comments
* Fix test
* Actually merge from master
* Revert to old tryLoad implementation
* Run fixupParentReferences when parsing isolated jsDocComment
* initial revision of unit test support for project system in tsserver
* Allow wildcard ("*") patterns in ambient module declarations
* Add non-widening forms of null and undefined
* Create separate control flows for property declarations with initializers
* Add regression test
* Allow trailing commas in function parameter and argument lists
* Add tests
* Remove unused variable
* Add null check and CR feedback
* Support shorthand ambient module declarations
* Revert "Merge pull request #7235 from weswigham/narrow-all-types"
This reverts commit ef0f6c8fe4f94a7e294cfe42d7025c9dca6535d5, reversing
changes made to 9f087cb62ade7a879e23c229df752fc8f87d679c.
* reuse the fixupParentReferences function
* Improve typing of && operator with --strictNullChecks
* Add test
* Respond to PR comments
* Respond to PR comments
* Add merging tests
* Use a function `stringify` to simplify calls to `JSON.stringify(xyz, undefined, 2)`
* Update tests
* Fix mistake
* Include indent in navigation bar protocol
Previously navbar01 test had indents when run in the browser but not when run from node. Now they run the same.
* Remove unnecessary restrictions in property access narrowing
* Fix fourslash test
* Add regression test
* Consider property declarations to be control flow containers
* Adding regression test
* Remove restriction on --target es5 and --module es6
* change type definition for Object.create
* Fix signature help
* Add "implicit any" warning for shorthand ambient modules
* Remove trailing whitespace
* Support using string values in enums for CompilerOptions in transpile methods
* Remove trailing whitespace in jakefile
* Make `jake runtests-browser` support test regexes with spaces
For example: `jake runtests-browser t="transpile .js files"` now works.
* Add another test
* factor out isJsxOrTsxExtension
* Move to a conformance test
* Revert "Revert "Merge pull request #7235 from weswigham/narrow-all-types""
This reverts commit fc3e040c5167868ed623612e8f33fb3beedf73b1.
* Use inclusive flag, as originally done, but include almost everything
* Add additional tests
* Respond to PR comments
* Fix typo
* add tests for tsserver project system
* Fix test
* Allow case comparison to undefined and null in strict null checking mode
* Remove incorrectly added tests
* check if moduleResolution when verifying that program can be reused
* more tests for module resolution change and exclude
* Fix linting issues
* Merge JSDoc of assignments from function expressions
* Allow nested assignments in type guards
* Add tests
* Improve order of parameter's merged jsdoc
* Force LF newlines for LKG builds/non debug builds
Fixes 6630
* Create intersection types in type guards for unrelated types
* Split commentsFunction test into expr/decl
And renumber.
* Remove TODO comments
* Accept new baselines
* Add tests
* Remove comments
* Fix test helper
* Recognize relative path using in outDir property (#9025)
* Recognize relative path using in outDir property
* Add projects tests
* Add project .json files
* Update baselines
* Add comments
* Add test case
The test passes in 1.8 and fails in master.
* Return trace when exception happens
* Remove Long-Done TODO
AFAIK, the harness sources have been concatenated into `run.js` for as long as I've known. This stops executing them twice (and in turn makes debugging tests much easier, since you no longer have to debug into eval'd code).
* Allow primitive type guards with typeof on right
Previously, only type guards of the form `typeof x === 'string'` were
allowed. Now you can write `'string' === typeof x`.
* Primitive type guards are now order independent
* Fix comments in tests
* Add handleing for classes
* Add more tests for target=es5 module=es6
* addExportToArgumentListKind
* Accept baseline
* Add more tests
* Adds progress indicators to the runtests-parallel build task.
* Fixed typo
* Fix comment
* Add test for out-of-range error
* Use proper method of not resolving alias
* Fix module loading error
(commandLineOptions_stringToEnum would be undefined if optionDeclarations wasn't loaded yet)
* Update tests
* Contextually type return statement in async function
* Remove stale files
* Undo change
* Improve perf
* Improve tests
* Fix sourcemaps for debugging tests
* Allow --sourceRoot with --inlineSources option
Fixes #8445
* this in parameter initializers resolves to class
Accept baselines now that the test passes.
* Add tests for more kinds of import/export
* Fix7334 Disallow async in functionExpression and ArrowFunction (#9062)
* Error when using async modifier in function-expression and arrow-function when target es5
* Add tests and baselines
* Resolve function-this in parameter initialisers when explicitly provided
* Allow null/undefined guard with null/undefined on left
Also add a test with baselines.
* Code review comments
* Update more diagnostic messages ES6->2015
Fix #8996 CC @mhegazy.
* Fixes an issue with runtests-parallel when global mocha is not installed.
* Update LKG
* Add tests
* fix baselines
* Salsa: get members of variables whose initialisers are functions
* Test adding members to JS variables whose initialisers are functions
* Recommend runtests-parallel in CONTRIBUTING
* Allow empty lists on command line
* Remove single-comma empty array form
* Remove trailing whitespace
* Implicit type inclusion changes
* Only inlineSourceMap when debugging through jake-browser (#9080)
* Only inlineSourceMap when debugging through jake-browser
* Address PR: fix typo in opt's property
* minor fix: add missing return clause
* Use camel-case instead of snake-case (#9134)
* Baseline fix, CR comments, lint
* CR changes
* Add test for jsdoc in navigation bar
* Fixes runtests-parallel not reporting failure for failed tests.
* Fix decorator metadata emit for rest arg with no type
* Add isDefinition to ReferenceEntry
Clients can now easily tell if the reference is to a definition or a
usage.
* Test isDefinition
* Add option to bail out of `jake runtests` when one test fails
* Absolute-ify paths in both places
* Refactor
* Add unit test
* lint
* Added tests.
* Accepted baselines.
* Emit 'exports.' if the shorthand is a general export.
* Accepted baselines.
* Emit 'Promise' decorator metadata return type for async methods
* Respond to PR comment
* Unescape identifiers used in code completion
* Make isDefinition required.
For the deprecated getOccurrencesAtPosition, isDefinition is always false.
* Add more isDefinition tests and fix computed property bug
* Fix bug: do unescaping in the right place, so that it only affects escaped javascript identifiers
* Use `isLiteralComputedPropertyDeclarationName`
2016-06-15 00:00:40 +02:00
desc ( "Runs the tests using the built run.js file. Optional arguments are: t[ests]=regex r[eporter]=[list|spec|json|<more>] d[ebug]=true color[s]=false lint=true bail=false dirty=false." ) ;
2015-10-03 01:21:20 +02:00
task ( "runtests" , [ "build-rules" , "tests" , builtLocalDirectory ] , function ( ) {
2016-05-24 01:00:56 +02:00
runConsoleTests ( 'mocha-fivemat-progress-reporter' , /*runInParallel*/ false ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-07-13 01:04:16 +02:00
2015-07-30 17:00:29 +02:00
desc ( "Generates code coverage data via instanbul" ) ;
2014-07-25 01:03:13 +02:00
task ( "generate-code-coverage" , [ "tests" , builtLocalDirectory ] , function ( ) {
2014-09-02 23:22:14 +02:00
var cmd = 'istanbul cover node_modules/mocha/bin/_mocha -- -R min -t ' + testTimeout + ' ' + run ;
2015-03-04 07:12:06 +01:00
console . log ( cmd ) ;
2014-09-18 20:49:40 +02:00
exec ( cmd ) ;
2014-07-25 01:03:13 +02:00
} , { async : true } ) ;
2014-07-13 01:04:16 +02:00
// Browser tests
2016-05-19 22:31:21 +02:00
var nodeServerOutFile = "tests/webTestServer.js" ;
var nodeServerInFile = "tests/webTestServer.ts" ;
2016-02-10 09:20:40 +01:00
compileFile ( nodeServerOutFile , [ nodeServerInFile ] , [ builtLocalDirectory , tscFile ] , [ ] , /*useBuiltCompiler:*/ true , { noOutFile : true } ) ;
2014-07-13 01:04:16 +02:00
desc ( "Runs browserify on run.js to produce a file suitable for running tests in the browser" ) ;
task ( "browserify" , [ "tests" , builtLocalDirectory , nodeServerOutFile ] , function ( ) {
[Transforms] Merge master 06/06/2016 (#8991)
* Remove check narrowing only certain types, add test showing issues with this
* string literal case test
* Reconcile fix with CFA work
* Defaultable -> NotNarrowable to align with use
* Missed a defaultable in comments
* Add test for narrowing to unions of string literals
* Rewrite isInStringLiteral to accomodate for unterminated strings
* Refactor signatureHelp to expose helper functions
* Add support for completion in string literals
* Remove unused check
* Use const instead of let
* Fix error
* Formatting changes
* Use shorthand properties
* Add failing test for #8738
* Sort baseline reference identifier by name
* Detects assignment to internal module export clause, fixes #8738
* add SharedArrayBuffer
fix
* Factor out assignment op check
* Add test for composite assignment
* Factor out the behaviour and handles x++ and ++x
* Handles ES3 default as identifier name
* Fix missing else statement
* isNameOfExportedDeclarationInNonES6Module
* Reorder options alphabetically
* Mark diagnostics, and skipDefaultLibCheck as internal
* Allow an import of "foo.js" to be matched by a file "foo.ts"
* Improve loadModuleFromFile code
* Respond to PR comments
* Respond to more PR comments
* Fix test
* Actually merge from master
* Revert to old tryLoad implementation
* Run fixupParentReferences when parsing isolated jsDocComment
* initial revision of unit test support for project system in tsserver
* Allow wildcard ("*") patterns in ambient module declarations
* Add non-widening forms of null and undefined
* Create separate control flows for property declarations with initializers
* Add regression test
* Allow trailing commas in function parameter and argument lists
* Add tests
* Remove unused variable
* Add null check and CR feedback
* Support shorthand ambient module declarations
* Revert "Merge pull request #7235 from weswigham/narrow-all-types"
This reverts commit ef0f6c8fe4f94a7e294cfe42d7025c9dca6535d5, reversing
changes made to 9f087cb62ade7a879e23c229df752fc8f87d679c.
* reuse the fixupParentReferences function
* Improve typing of && operator with --strictNullChecks
* Add test
* Respond to PR comments
* Respond to PR comments
* Add merging tests
* Use a function `stringify` to simplify calls to `JSON.stringify(xyz, undefined, 2)`
* Update tests
* Fix mistake
* Include indent in navigation bar protocol
Previously navbar01 test had indents when run in the browser but not when run from node. Now they run the same.
* Remove unnecessary restrictions in property access narrowing
* Fix fourslash test
* Add regression test
* Consider property declarations to be control flow containers
* Adding regression test
* Remove restriction on --target es5 and --module es6
* change type definition for Object.create
* Fix signature help
* Add "implicit any" warning for shorthand ambient modules
* Remove trailing whitespace
* Support using string values in enums for CompilerOptions in transpile methods
* Remove trailing whitespace in jakefile
* Make `jake runtests-browser` support test regexes with spaces
For example: `jake runtests-browser t="transpile .js files"` now works.
* Add another test
* factor out isJsxOrTsxExtension
* Move to a conformance test
* Revert "Revert "Merge pull request #7235 from weswigham/narrow-all-types""
This reverts commit fc3e040c5167868ed623612e8f33fb3beedf73b1.
* Use inclusive flag, as originally done, but include almost everything
* Add additional tests
* Respond to PR comments
* Fix typo
* add tests for tsserver project system
* Fix test
* Allow case comparison to undefined and null in strict null checking mode
* Remove incorrectly added tests
* check if moduleResolution when verifying that program can be reused
* more tests for module resolution change and exclude
* Fix linting issues
* Merge JSDoc of assignments from function expressions
* Allow nested assignments in type guards
* Add tests
* Improve order of parameter's merged jsdoc
* Force LF newlines for LKG builds/non debug builds
Fixes 6630
* Create intersection types in type guards for unrelated types
* Split commentsFunction test into expr/decl
And renumber.
* Remove TODO comments
* Accept new baselines
* Add tests
* Remove comments
* Fix test helper
* Recognize relative path using in outDir property (#9025)
* Recognize relative path using in outDir property
* Add projects tests
* Add project .json files
* Update baselines
* Add comments
* Add test case
The test passes in 1.8 and fails in master.
* Return trace when exception happens
* Remove Long-Done TODO
AFAIK, the harness sources have been concatenated into `run.js` for as long as I've known. This stops executing them twice (and in turn makes debugging tests much easier, since you no longer have to debug into eval'd code).
* Allow primitive type guards with typeof on right
Previously, only type guards of the form `typeof x === 'string'` were
allowed. Now you can write `'string' === typeof x`.
* Primitive type guards are now order independent
* Fix comments in tests
* Add handleing for classes
* Add more tests for target=es5 module=es6
* addExportToArgumentListKind
* Accept baseline
* Add more tests
* wip-fixing transforms
* Adds progress indicators to the runtests-parallel build task.
* Fixed typo
* Fix comment
* Add test for out-of-range error
* Use proper method of not resolving alias
* Fix module loading error
(commandLineOptions_stringToEnum would be undefined if optionDeclarations wasn't loaded yet)
* Port 8739
* Update tests
* Update baselines
* Contextually type return statement in async function
* Remove stale files
* Undo change
* Improve perf
* Improve tests
* Fix sourcemaps for debugging tests
* Allow --sourceRoot with --inlineSources option
Fixes #8445
* this in parameter initializers resolves to class
Accept baselines now that the test passes.
* Add tests for more kinds of import/export
* Fix7334 Disallow async in functionExpression and ArrowFunction (#9062)
* Error when using async modifier in function-expression and arrow-function when target es5
* Add tests and baselines
* Resolve function-this in parameter initialisers when explicitly provided
* Allow null/undefined guard with null/undefined on left
Also add a test with baselines.
* Code review comments
* Update more diagnostic messages ES6->2015
Fix #8996 CC @mhegazy.
* Fixes an issue with runtests-parallel when global mocha is not installed.
* Update LKG
* Add tests
* fix baselines
* Recommend runtests-parallel in CONTRIBUTING
* Only inlineSourceMap when debugging through jake-browser (#9080)
* Only inlineSourceMap when debugging through jake-browser
* Address PR: fix typo in opt's property
* Manually port tests from PR 8470
* minor fix: add missing return clause
* Support using string values in enums for CompilerOptions in transpile methods
* Support using string values in enums for CompilerOptions in transpile methods
# Conflicts:
# tests/cases/unittests/transpile.ts
* Fix test helper
* Add test for out-of-range error
* Fix module loading error
(commandLineOptions_stringToEnum would be undefined if optionDeclarations wasn't loaded yet)
* Use camel-case instead of snake-case (#9134)
* Manually add tests for PR 8988
* Allow wildcard ("*") patterns in ambient module declarations
* Respond to PR comments
* Add another test
* Improve perf
* Improve tests
* Update baseline from merging with master
* Address PR comment
* Update baseline
* Refactor how we retrieve binding-name cache in module transformer
* Temporary accept so we get a clean run-tests result
2016-06-14 20:36:57 +02:00
var cmd = 'browserify built/local/run.js -t ./scripts/browserify-optional -d -o built/local/bundle.js' ;
2014-07-13 01:04:16 +02:00
exec ( cmd ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-07-13 01:04:16 +02:00
2016-07-28 22:40:05 +02:00
desc ( "Runs the tests using the built run.js file like 'jake runtests'. Syntax is jake runtests-browser. Additional optional parameters tests=[regex], browser=[chrome|IE]" ) ;
2016-08-19 23:34:14 +02:00
task ( "runtests-browser" , [ "tests" , "browserify" , builtLocalDirectory , servicesFileInBrowserTest ] , function ( ) {
2014-07-13 01:04:16 +02:00
cleanTestDirs ( ) ;
2016-05-19 22:31:21 +02:00
host = "node" ;
2016-09-22 23:17:19 +02:00
browser = process . env . browser || process . env . b || ( os . platform ( ) === "linux" ? "chrome" : "IE" ) ;
2014-07-18 00:26:50 +02:00
tests = process . env . test || process . env . tests || process . env . t ;
2015-04-29 21:13:35 +02:00
var light = process . env . light || false ;
2014-07-13 01:04:16 +02:00
var testConfigFile = 'test.config' ;
2016-08-19 23:34:14 +02:00
if ( fs . existsSync ( testConfigFile ) ) {
2014-07-13 01:04:16 +02:00
fs . unlinkSync ( testConfigFile ) ;
}
2016-08-19 23:34:14 +02:00
if ( tests || light ) {
2016-05-31 19:17:45 +02:00
writeTestConfigFile ( tests , light ) ;
2014-07-13 01:04:16 +02:00
}
tests = tests ? tests : '' ;
2016-07-28 22:40:05 +02:00
var cmd = host + " tests/webTestServer.js " + browser + " " + JSON . stringify ( tests ) ;
2015-03-04 07:12:06 +01:00
console . log ( cmd ) ;
2014-07-13 01:04:16 +02:00
exec ( cmd ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-07-13 01:04:16 +02:00
2014-12-04 15:27:24 +01:00
function getDiffTool() {
2016-05-19 22:31:21 +02:00
var program = process . env [ 'DIFF' ] ;
2014-12-04 20:15:00 +01:00
if ( ! program ) {
2015-07-30 17:00:29 +02:00
fail ( "Add the 'DIFF' environment variable to the path of the program you want to use." ) ;
2014-12-04 20:15:00 +01:00
}
2014-12-04 15:27:24 +01:00
return program ;
}
2014-07-13 01:04:16 +02:00
// Baseline Diff
2014-12-04 20:15:00 +01:00
desc ( "Diffs the compiler baselines using the diff tool specified by the 'DIFF' environment variable" ) ;
2014-07-13 01:04:16 +02:00
task ( 'diff' , function ( ) {
2016-08-19 23:34:14 +02:00
var cmd = '"' + getDiffTool ( ) + '" ' + refBaseline + ' ' + localBaseline ;
2015-07-30 17:00:29 +02:00
console . log ( cmd ) ;
2014-07-13 01:04:16 +02:00
exec ( cmd ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-07-13 01:04:16 +02:00
2014-12-04 20:15:00 +01:00
desc ( "Diffs the RWC baselines using the diff tool specified by the 'DIFF' environment variable" ) ;
2014-07-13 01:04:16 +02:00
task ( 'diff-rwc' , function ( ) {
2016-08-19 23:34:14 +02:00
var cmd = '"' + getDiffTool ( ) + '" ' + refRwcBaseline + ' ' + localRwcBaseline ;
2015-07-30 17:00:29 +02:00
console . log ( cmd ) ;
2014-07-13 01:04:16 +02:00
exec ( cmd ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-07-13 01:04:16 +02:00
desc ( "Builds the test sources and automation in debug mode" ) ;
task ( "tests-debug" , [ "setDebugMode" , "tests" ] ) ;
// Makes the test results the new baseline
desc ( "Makes the most recent test results the new baseline, overwriting the old baseline" ) ;
2016-08-19 23:34:14 +02:00
task ( "baseline-accept" , function ( ) {
acceptBaseline ( "" ) ;
} ) ;
function acceptBaseline ( containerFolder ) {
var sourceFolder = path . join ( localBaseline , containerFolder ) ;
var targetFolder = path . join ( refBaseline , containerFolder ) ;
console . log ( 'Accept baselines from ' + sourceFolder + ' to ' + targetFolder ) ;
var files = fs . readdirSync ( sourceFolder ) ;
2016-08-08 23:30:27 +02:00
var deleteEnding = '.delete' ;
for ( var i in files ) {
2016-08-19 23:34:14 +02:00
var filename = files [ i ] ;
2016-09-09 19:13:18 +02:00
var fullLocalPath = path . join ( sourceFolder , filename ) ;
if ( fs . statSync ( fullLocalPath ) . isFile ( ) ) {
if ( filename . substr ( filename . length - deleteEnding . length ) === deleteEnding ) {
filename = filename . substr ( 0 , filename . length - deleteEnding . length ) ;
fs . unlinkSync ( path . join ( targetFolder , filename ) ) ;
} else {
var target = path . join ( targetFolder , filename ) ;
if ( fs . existsSync ( target ) ) {
fs . unlinkSync ( target ) ;
}
fs . renameSync ( path . join ( sourceFolder , filename ) , target ) ;
2016-08-19 23:34:14 +02:00
}
2014-07-13 01:04:16 +02:00
}
}
2016-08-19 23:34:14 +02:00
}
2014-07-13 01:04:16 +02:00
desc ( "Makes the most recent rwc test results the new baseline, overwriting the old baseline" ) ;
2016-08-19 23:34:14 +02:00
task ( "baseline-accept-rwc" , function ( ) {
acceptBaseline ( "rwc" ) ;
2014-07-13 01:04:16 +02:00
} ) ;
2014-11-17 20:01:05 +01:00
desc ( "Makes the most recent test262 test results the new baseline, overwriting the old baseline" ) ;
2016-08-19 23:34:14 +02:00
task ( "baseline-accept-test262" , function ( ) {
acceptBaseline ( "test262" ) ;
2014-11-17 20:01:05 +01:00
} ) ;
2014-07-13 01:04:16 +02:00
// Webhost
var webhostPath = "tests/webhost/webtsc.ts" ;
var webhostJsPath = "tests/webhost/webtsc.js" ;
2014-12-02 00:32:52 +01:00
compileFile ( webhostJsPath , [ webhostPath ] , [ tscFile , webhostPath ] . concat ( libraryTargets ) , [ ] , /*useBuiltCompiler*/ true ) ;
2014-07-13 01:04:16 +02:00
desc ( "Builds the tsc web host" ) ;
2016-08-19 23:34:14 +02:00
task ( "webhost" , [ webhostJsPath ] , function ( ) {
jake . cpR ( path . join ( builtLocalDirectory , "lib.d.ts" ) , "tests/webhost/" , { silent : true } ) ;
2014-07-13 01:04:16 +02:00
} ) ;
2015-03-04 07:12:06 +01:00
// Perf compiler
var perftscPath = "tests/perftsc.ts" ;
var perftscJsPath = "built/local/perftsc.js" ;
compileFile ( perftscJsPath , [ perftscPath ] , [ tscFile , perftscPath , "tests/perfsys.ts" ] . concat ( libraryTargets ) , [ ] , /*useBuiltCompiler*/ true ) ;
desc ( "Builds augmented version of the compiler for perf tests" ) ;
task ( "perftsc" , [ perftscJsPath ] ) ;
2014-09-02 21:19:58 +02:00
// Instrumented compiler
var loggedIOpath = harnessDirectory + 'loggedIO.ts' ;
var loggedIOJsPath = builtLocalDirectory + 'loggedIO.js' ;
2016-08-19 23:34:14 +02:00
file ( loggedIOJsPath , [ builtLocalDirectory , loggedIOpath ] , function ( ) {
2014-09-02 23:22:14 +02:00
var temp = builtLocalDirectory + 'temp' ;
2014-09-02 21:19:58 +02:00
jake . mkdirP ( temp ) ;
2016-09-13 21:39:29 +02:00
var options = "--types --outdir " + temp + ' ' + loggedIOpath ;
2014-09-02 21:19:58 +02:00
var cmd = host + " " + LKGDirectory + compilerFilename + " " + options + " " ;
2015-03-04 07:12:06 +01:00
console . log ( cmd + "\n" ) ;
var ex = jake . createExec ( [ cmd ] ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "cmdEnd" , function ( ) {
2014-09-02 23:22:14 +02:00
fs . renameSync ( temp + '/harness/loggedIO.js' , loggedIOJsPath ) ;
jake . rmRf ( temp ) ;
complete ( ) ;
2014-09-02 21:19:58 +02:00
} ) ;
2015-03-04 07:12:06 +01:00
ex . run ( ) ;
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;
2014-09-02 21:19:58 +02:00
var instrumenterPath = harnessDirectory + 'instrumenter.ts' ;
var instrumenterJsPath = builtLocalDirectory + 'instrumenter.js' ;
2015-03-19 01:23:40 +01:00
compileFile ( instrumenterJsPath , [ instrumenterPath ] , [ tscFile , instrumenterPath ] . concat ( libraryTargets ) , [ ] , /*useBuiltCompiler*/ true ) ;
2014-09-02 21:19:58 +02:00
desc ( "Builds an instrumented tsc.js" ) ;
2016-08-19 23:34:14 +02:00
task ( 'tsc-instrumented' , [ loggedIOJsPath , instrumenterJsPath , tscFile ] , function ( ) {
2014-09-02 23:22:14 +02:00
var cmd = host + ' ' + instrumenterJsPath + ' record iocapture ' + builtLocalDirectory + compilerFilename ;
2015-03-04 07:12:06 +01:00
console . log ( cmd ) ;
var ex = jake . createExec ( [ cmd ] ) ;
2016-08-19 23:34:14 +02:00
ex . addListener ( "cmdEnd" , function ( ) {
2015-03-04 07:12:06 +01:00
complete ( ) ;
} ) ;
ex . run ( ) ;
2014-09-02 23:22:14 +02:00
} , { async : true } ) ;
2015-06-23 18:05:49 +02:00
desc ( "Updates the sublime plugin's tsserver" ) ;
2016-08-19 23:34:14 +02:00
task ( "update-sublime" , [ "local" , serverFile ] , function ( ) {
2015-06-23 18:05:49 +02:00
jake . cpR ( serverFile , "../TypeScript-Sublime-Plugin/tsserver/" ) ;
jake . cpR ( serverFile + ".map" , "../TypeScript-Sublime-Plugin/tsserver/" ) ;
} ) ;
2015-07-10 01:39:58 +02:00
2015-08-26 03:09:32 +02:00
var tslintRuleDir = "scripts/tslint" ;
2016-05-19 22:31:21 +02:00
var tslintRules = [
2015-08-26 03:09:32 +02:00
"nextLineRule" ,
2015-11-04 20:02:43 +01:00
"preferConstRule" ,
2015-10-22 20:35:48 +02:00
"booleanTriviaRule" ,
2015-12-02 00:14:24 +01:00
"typeOperatorSpacingRule" ,
2015-12-02 01:19:40 +01:00
"noInOperatorRule" ,
2016-06-23 21:32:14 +02:00
"noIncrementDecrementRule" ,
"objectLiteralSurroundingSpaceRule" ,
2016-07-26 22:29:53 +02:00
"noTypeAssertionWhitespaceRule"
2016-05-19 22:31:21 +02:00
] ;
2016-08-19 23:34:14 +02:00
var tslintRulesFiles = tslintRules . map ( function ( p ) {
2015-08-26 03:09:32 +02:00
return path . join ( tslintRuleDir , p + ".ts" ) ;
} ) ;
2016-08-19 23:34:14 +02:00
var tslintRulesOutFiles = tslintRules . map ( function ( p ) {
2015-08-26 03:09:32 +02:00
return path . join ( builtLocalDirectory , "tslint" , p + ".js" ) ;
} ) ;
desc ( "Compiles tslint rules to js" ) ;
2016-08-11 18:53:38 +02:00
task ( "build-rules" , [ "build-rules-start" ] . concat ( tslintRulesOutFiles ) . concat ( [ "build-rules-end" ] ) ) ;
2016-08-19 23:34:14 +02:00
tslintRulesFiles . forEach ( function ( ruleFile , i ) {
2016-02-10 09:20:40 +01:00
compileFile ( tslintRulesOutFiles [ i ] , [ ruleFile ] , [ ruleFile ] , [ ] , /*useBuiltCompiler*/ false ,
2016-08-19 23:34:14 +02:00
{ noOutFile : true , generateDeclarations : false , outDir : path.join ( builtLocalDirectory , "tslint" ) } ) ;
2015-08-26 03:09:32 +02:00
} ) ;
2016-08-11 18:53:38 +02:00
desc ( "Emit the start of the build-rules fold" ) ;
2016-08-19 23:34:14 +02:00
task ( "build-rules-start" , [ ] , function ( ) {
2016-08-11 18:53:38 +02:00
if ( fold . isTravis ( ) ) console . log ( fold . start ( "build-rules" ) ) ;
} ) ;
desc ( "Emit the end of the build-rules fold" ) ;
2016-08-19 23:34:14 +02:00
task ( "build-rules-end" , [ ] , function ( ) {
2016-08-11 18:53:38 +02:00
if ( fold . isTravis ( ) ) console . log ( fold . end ( "build-rules" ) ) ;
} ) ;
2015-10-28 23:42:15 +01:00
var lintTargets = compilerSources
2016-05-24 19:17:16 +02:00
. concat ( harnessSources )
2016-05-20 18:40:13 +02:00
// Other harness sources
2016-08-19 23:34:14 +02:00
. concat ( [ "instrumenter.ts" ] . map ( function ( f ) { return path . join ( harnessDirectory , f ) } ) )
2015-11-21 01:28:58 +01:00
. concat ( serverCoreSources )
2015-12-23 01:12:07 +01:00
. concat ( tslintRulesFiles )
2016-06-23 19:12:14 +02:00
. concat ( servicesSources )
2016-08-17 23:47:54 +02:00
. concat ( typingsInstallerSources )
. concat ( cancellationTokenSources )
2016-07-27 16:26:28 +02:00
. concat ( [ "Gulpfile.ts" ] )
. concat ( [ nodeServerInFile , perftscPath , "tests/perfsys.ts" , webhostPath ] ) ;
2015-09-18 06:04:33 +02:00
2016-08-15 19:45:46 +02:00
function sendNextFile ( files , child , callback , failures ) {
var file = files . pop ( ) ;
if ( file ) {
console . log ( "Linting '" + file + "'." ) ;
2016-08-19 23:34:14 +02:00
child . send ( { kind : "file" , name : file } ) ;
2016-08-15 19:45:46 +02:00
}
else {
2016-08-19 23:34:14 +02:00
child . send ( { kind : "close" } ) ;
2016-08-15 19:45:46 +02:00
callback ( failures ) ;
}
}
function spawnLintWorker ( files , callback ) {
var child = child_process . fork ( "./scripts/parallel-lint" ) ;
var failures = 0 ;
2016-08-19 23:34:14 +02:00
child . on ( "message" , function ( data ) {
2016-08-15 19:45:46 +02:00
switch ( data . kind ) {
case "result" :
if ( data . failures > 0 ) {
failures += data . failures ;
console . log ( data . output ) ;
}
sendNextFile ( files , child , callback , failures ) ;
break ;
case "error" :
console . error ( data . error ) ;
failures ++ ;
sendNextFile ( files , child , callback , failures ) ;
break ;
}
} ) ;
sendNextFile ( files , child , callback , failures ) ;
}
2015-09-18 06:04:33 +02:00
2016-05-18 16:41:37 +02:00
desc ( "Runs tslint on the compiler sources. Optional arguments are: f[iles]=regex" ) ;
2016-08-19 23:34:14 +02:00
task ( "lint" , [ "build-rules" ] , function ( ) {
2016-08-11 18:53:38 +02:00
if ( fold . isTravis ( ) ) console . log ( fold . start ( "lint" ) ) ;
2016-08-12 23:00:50 +02:00
var startTime = mark ( ) ;
2015-12-02 00:05:08 +01:00
var failed = 0 ;
2016-05-18 16:41:37 +02:00
var fileMatcher = RegExp ( process . env . f || process . env . file || process . env . files || "" ) ;
2016-05-24 22:57:12 +02:00
var done = { } ;
2015-07-23 22:59:41 +02:00
for ( var i in lintTargets ) {
2016-05-18 16:41:37 +02:00
var target = lintTargets [ i ] ;
2016-05-24 22:57:12 +02:00
if ( ! done [ target ] && fileMatcher . test ( target ) ) {
2016-08-15 19:45:46 +02:00
done [ target ] = fs . statSync ( target ) . size ;
2015-09-18 06:04:33 +02:00
}
2015-07-10 01:39:58 +02:00
}
2015-09-18 06:04:33 +02:00
2016-08-15 19:45:46 +02:00
var workerCount = ( process . env . workerCount && + process . env . workerCount ) || os . cpus ( ) . length ;
2015-11-24 07:38:05 +01:00
2016-08-19 23:34:14 +02:00
var names = Object . keys ( done ) . sort ( function ( namea , nameb ) {
2016-08-15 19:45:46 +02:00
return done [ namea ] - done [ nameb ] ;
2015-09-18 06:04:33 +02:00
} ) ;
2016-08-15 19:45:46 +02:00
for ( var i = 0 ; i < workerCount ; i ++ ) {
spawnLintWorker ( names , finished ) ;
2015-09-18 06:04:33 +02:00
}
2016-08-15 19:45:46 +02:00
var completed = 0 ;
var failures = 0 ;
function finished ( fails ) {
completed ++ ;
failures += fails ;
if ( completed === workerCount ) {
measure ( startTime ) ;
if ( fold . isTravis ( ) ) console . log ( fold . end ( "lint" ) ) ;
if ( failures > 0 ) {
fail ( 'Linter errors.' , failed ) ;
}
else {
complete ( ) ;
}
}
}
2016-08-19 23:34:14 +02:00
} , { async : true } ) ;