test: skip test-process-config if no config.gypi

If you run the tests in a different machine to the one you built on,
this test will fail. Avoid this by skipping if the file doesn't exist.
We shouldn't need to check that the file exists in this test, as the
build won't pass without a config.gypi anyway.

Also adds console.logs, so you can see what the actual difference
between the objects was, as `assert.deepStrictEqual()` only shows you
the first three lines.

PR-URL: https://github.com/nodejs/node/pull/16436
Reviewed-By: Gireesh Punathil <gpunathi@in.ibm.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Refael Ackermann <refack@gmail.com>
Reviewed-By: Richard Lau <riclau@uk.ibm.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
This commit is contained in:
Gibson Fahnestock 2017-10-20 14:33:29 +01:00
parent ee76f3153b
commit 502563b277
No known key found for this signature in database
GPG Key ID: B01FBB92821C587A

View File

@ -20,21 +20,31 @@
// USE OR OTHER DEALINGS IN THE SOFTWARE.
'use strict';
require('../common');
const common = require('../common');
// Checks that the internal process.config is equivalent to the config.gypi file
// created when we run configure.
const assert = require('assert');
const fs = require('fs');
const path = require('path');
// check for existence
// Check for existence of `process.config`.
assert(process.hasOwnProperty('config'));
// ensure that `process.config` is an Object
// Ensure that `process.config` is an Object.
assert.strictEqual(Object(process.config), process.config);
const configPath = path.resolve(__dirname, '..', '..', 'config.gypi');
if (!fs.existsSync(configPath)) {
common.skip('config.gypi does not exist.');
}
let config = fs.readFileSync(configPath, 'utf8');
// clean up comment at the first line
// Clean up comment at the first line.
config = config.split('\n').slice(1).join('\n').replace(/'/g, '"');
config = JSON.parse(config, function(key, value) {
if (value === 'true') return true;
@ -42,4 +52,13 @@ config = JSON.parse(config, function(key, value) {
return value;
});
assert.deepStrictEqual(config, process.config);
try {
assert.deepStrictEqual(config, process.config);
} catch (e) {
// If the assert fails, it only shows 3 lines. We need all the output to
// compare.
console.log('config:', config);
console.log('process.config:', process.config);
throw e;
}