12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- 'use strict';
- module.exports = exports = testbinary;
- exports.usage = 'Tests that the binary.node can be required';
- const path = require('path');
- const log = require('npmlog');
- const cp = require('child_process');
- const versioning = require('./util/versioning.js');
- const napi = require('./util/napi.js');
- function testbinary(gyp, argv, callback) {
- const args = [];
- const options = {};
- let shell_cmd = process.execPath;
- const package_json = gyp.package_json;
- const napi_build_version = napi.get_napi_build_version_from_command_args(argv);
- const opts = versioning.evaluate(package_json, gyp.opts, napi_build_version);
- // skip validation for runtimes we don't explicitly support (like electron)
- if (opts.runtime &&
- opts.runtime !== 'node-webkit' &&
- opts.runtime !== 'node') {
- return callback();
- }
- const nw = (opts.runtime && opts.runtime === 'node-webkit');
- // ensure on windows that / are used for require path
- const binary_module = opts.module.replace(/\\/g, '/');
- if ((process.arch !== opts.target_arch) ||
- (process.platform !== opts.target_platform)) {
- let msg = 'skipping validation since host platform/arch (';
- msg += process.platform + '/' + process.arch + ')';
- msg += ' does not match target (';
- msg += opts.target_platform + '/' + opts.target_arch + ')';
- log.info('validate', msg);
- return callback();
- }
- if (nw) {
- options.timeout = 5000;
- if (process.platform === 'darwin') {
- shell_cmd = 'node-webkit';
- } else if (process.platform === 'win32') {
- shell_cmd = 'nw.exe';
- } else {
- shell_cmd = 'nw';
- }
- const modulePath = path.resolve(binary_module);
- const appDir = path.join(__dirname, 'util', 'nw-pre-gyp');
- args.push(appDir);
- args.push(modulePath);
- log.info('validate', "Running test command: '" + shell_cmd + ' ' + args.join(' ') + "'");
- cp.execFile(shell_cmd, args, options, (err, stdout, stderr) => {
- // check for normal timeout for node-webkit
- if (err) {
- if (err.killed === true && err.signal && err.signal.indexOf('SIG') > -1) {
- return callback();
- }
- const stderrLog = stderr.toString();
- log.info('stderr', stderrLog);
- if (/^\s*Xlib:\s*extension\s*"RANDR"\s*missing\s*on\s*display\s*":\d+\.\d+"\.\s*$/.test(stderrLog)) {
- log.info('RANDR', 'stderr contains only RANDR error, ignored');
- return callback();
- }
- return callback(err);
- }
- return callback();
- });
- return;
- }
- args.push('--eval');
- args.push("require('" + binary_module.replace(/'/g, '\'') + "')");
- log.info('validate', "Running test command: '" + shell_cmd + ' ' + args.join(' ') + "'");
- cp.execFile(shell_cmd, args, options, (err, stdout, stderr) => {
- if (err) {
- return callback(err, { stdout: stdout, stderr: stderr });
- }
- return callback();
- });
- }
|