繁体   English   中英

有没有办法检查 npm package 是否需要发布,然后只发布?

[英]Is there a way to check if an npm package needs a publish and only do a publish then?

我正在创建一个包含多个项目的单一代码库,并且每个项目都可以发布。

为了创建一个简化的持续集成过程,我希望我的构建代理运行一个命令来发布所有需要发布的项目。 显然,这不起作用,因为如果发布将在先前发布的版本上发布,则发布失败,这会导致命令失败并且所有后续命令都不会执行。 像这样的东西:

"build-package1": "ng build package1",
"publish-package1": "npm publish ./dist/package1",
"build-package2": "ng build package2",
"publish-package2": "npm publish ./dist/package2",
"build-all": "npm run build-package1 && npm run build-package2",
"publish-all": "npm run publish-package1 && npm run publish-package2"

因此,在这种情况下,如果我运行 build-all,然后 publish-all 并且 package1 的 package.json 文件中没有版本更改,那么命令将失败并且 package2 将不会发布。

有没有我可以执行的命令在尝试发布之前检查是否需要发布?

我已经看到了这个答案: https://askubuntu.com/questions/334994/which-one-is-better-using-or-to-execute-multiple-commands-in-one-line/539293#539293

理想情况下,尽管我认为在尝试发布之前确定发布是否可行可能会更干净。

可以将 npm 安装到项目本地,然后使用命令式 npm 命令检查最新发布的版本,并在使用命令式 npm 发布命令之前使用节点文件系统检查本地版本

import * as fs from 'fs';
import * as npm from 'npm';

function getLocalPackageData(path): Promise<IPackageData> {
  return new Promise((resolve, reject) => {
    fs.readFile(path + '/package.json', (err, data) => {
      if (err) reject(err);

      const pData = JSON.parse(data as unknown as string);
      resolve({ version: pData.version, name: pData.name });
    });
  });
}

function getPublishedPackageData(packageName: string) {
    npm.commands.show([packageName], function (err, result) {
      if (err) reject(err);

      const latestVersion = Object.keys(result)[0];
      resolve({ version: latestVersion, name: result[latestVersion].name });
    });
}

function needsPublish(latestPackageSegments: IPackageVersionSegments, localPackageSegments: IPackageVersionSegments): boolean {
  const majorGreater = localPackageSegments.major > latestPackageSegments.major;
  const majorEqual = localPackageSegments.major === latestPackageSegments.major;
  const minorGreater = localPackageSegments.minor > latestPackageSegments.minor;
  const minorEqual = localPackageSegments.minor === latestPackageSegments.minor;
  const bugFixGreater = localPackageSegments.bug > latestPackageSegments.bug;

  return majorGreater ||
    (majorEqual && (minorGreater || bugFixGreater)) ||
    (majorEqual && minorEqual && bugFixGreater);
}

从那里你可以实现对已发布的本地检查并执行以下操作:

npm.commands.publish(projectPathsToUpdate, (error, res) => {

    if (error) {
      throw error;
    }

    console.log('================= published: =================');
    packagesToUpdate.forEach(p => console.log(p.name + ' updated to ' + p.version));
  });

希望这对将来的某人有所帮助-可能又是我。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM