我有以下层次结构:
dist/
|- BuildTasks/
|- CustomTask/
- CustomTask.js
node_modules/
source/
|- BuildTasks/
|- CustomTask/
- CustomTask.ts
- tsconfig.json
此外,我正在尝试为内部(私有)用法创建VSTS任务扩展。最初,我在我的根目录下有我的tsconfig.json,一切都在我的本地机器上工作正常。问题是VSTS扩展要求所有文件都包含在与任务文件夹本身相同的目录中。有关详细信息,请参阅https://github.com/Microsoft/vsts-task-lib/issues/274:
您需要发布一个自包含的任务文件夹。代理人没有运行 npm install以恢复您的依赖项。
最初,我解决了这个问题,包括将整个node_modules目录复制到每个Task文件夹中的步骤,在本例中是我的 CustomTask 文件夹,其中包含我的JS文件。但是,考虑到我写的每个任务都没有相同的模块要求,这似乎有点多了。
我的想法是在每个Task文件夹中创建一个tsconfig.json,它指定创建一个包含所有依赖模块的输出文件,但遗憾的是它不起作用:
{
"compilerOptions": {
"baseUrl": ".",
"target": "ES6",
"module": "system",
"strict": true,
"rootDir": ".",
"outFile": "../../../dist/BuildTasks/CustomTask/CustomTask.js",
"paths": {
"*" : ["../../../node_modules/*"]
}
}
}
在添加"路径"之前,我收到以下错误:
错误TS2307:找不到模块' vsts-task-lib / task'。
错误TS2307:无法找到模块'时刻'。
添加路径后,我仍然收到错误,它找不到模块' moment&#39 ;,这是在我的node_modules目录中。此外,当我查看输出JS时,似乎它没有包含' vsts-tasks-lib'必要的代码,也许是因为它在“时刻”方面仍然存在错误。模块?不确定我错过了什么?
答案 0 :(得分:1)
使用webpack编译JavaScript模块,简单示例:
webpack.config.js:
const path = require('path');
module.exports = {
entry: './testtask.ts',
module: {
rules: [
{
test: /\.tsx?$/,
use: 'ts-loader',
exclude: /node_modules/
}
]
},
resolve: {
extensions: ['.tsx', '.ts', '.js']
},
output: {
filename: 'bundle.js',
path: path.resolve(__dirname, 'dist')
},
node: {
fs: 'empty'
},
target: 'node'
};
之后,任务文件夹中只有bundle.js和task.json。
更新:testtask.ts中的示例代码:
import tl = require('vsts-task-lib/task');
import fs = require('fs');
console.log('Set variable================');
tl.setVariable('varCode1', 'code1');
tl.setTaskVariable('varTaskCode1', 'taskCode1');
var taskVariables = tl.getVariables();
console.log("variables are:");
for (var taskVariable of taskVariables) {
console.log(taskVariable.name);
console.log(taskVariable.value);
}
console.log('##vso[task.setvariable variable=LogCode1;]LogCode1');
console.log('end========================');
console.log('current path is:' + __dirname);
fs.appendFile('TextFile1.txt', 'data to append', function (err) {
if (err) throw err;
console.log('Saved!');
});
console.log('configure file path:' + process.env.myconfig);
console.log('configure file path2:' + process.env.myconfig2);