Node UnhandledPromiseRejectionWarning

时间:2017-03-17 23:09:20

标签: node.js npm promise

我的npm包有问题就像这个问题但是我无法弄清楚如何解决

What is Unhandled Promise Rejection

这是我的index.js:

'use strict';
var got = require('got');
var registryUrl = require('registry-url');
var Promise = require('pinkie-promise');

module.exports = function (name) {
    if (typeof name !== 'string') {
        return Promise.reject(new Error('username required'));
    }

    return got.head(registryUrl + name.toLowerCase())
        .then(function (res) {
            return 'test';
        })
        .catch(function (err) {
            if (err.statusCode === 404) {
                err.message = 'Package doesn\'t exist';
            }

            throw err;
        });
};

这是我的cli.js

#!/usr/bin/env node
'use strict';
var pkg = require('./package.json');
var info = require('./');
var argv = process.argv.slice(2);
var input = argv[0];

function help() {
    console.log(pkg.description);
    console.log('');
    console.log('Usage');
    console.log('  $ package-info <package-name>');
    console.log('');
    console.log('Example');
    console.log('  $ package-info pageres');
}

if (!input || argv.indexOf('--help') !== -1) {
    help();
    return;
}

if (process.argv.indexOf('-v') !== -1 || process.argv.indexOf('--version') !== -1) {
    console.log(pkg.version);
    return;
}

info(input, function (err, version) {
    if (err) {
        console.error(err);
        process.exit(1);
        return;
    }

    console.log(version);
});

如果我尝试在本地安装:

npm install . -g
npm link

然后我更改目录并安装:

cd ../otherDir
npm install ../my-package

启动它

my-package somePackage

我明白了:

(node:2145) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): RequestError: getaddrinfo ENOTFOUND function function:80

我该如何解决?

1 个答案:

答案 0 :(得分:2)

您无法正确捕获cli文件中的错误。事实上,您根本不处理返回的承诺并传递未使用的回调。尝试更改

info(input, function (err, version) {
    if (err) {
        console.error(err);
        process.exit(1);
        return;
    }

    console.log(version);
});

info(input)
.then(version => console.log(version))
.catch(err => {
  console.error(err);
  process.exit(1);
});

发生这种情况是因为在您捕获信息函数中的错误之后,您再次将其抛出链中。