|
| 1 | +'use strict'; |
| 2 | + |
| 3 | +const common = require('../common'); |
| 4 | +if (!common.hasCrypto) |
| 5 | + common.skip('missing crypto'); |
| 6 | + |
| 7 | +const fixtures = require('../common/fixtures'); |
| 8 | + |
| 9 | +const assert = require('assert'); |
| 10 | +const { spawnSync } = require('child_process'); |
| 11 | +const fs = require('fs'); |
| 12 | +const crypto = require('crypto'); |
| 13 | + |
| 14 | +const depPolicy = fixtures.path('policy', 'dep-policy.json'); |
| 15 | +const dep = fixtures.path('policy', 'dep.js'); |
| 16 | + |
| 17 | +const emptyHash = crypto.createHash('sha512'); |
| 18 | +emptyHash.update(''); |
| 19 | +const emptySRI = `sha512-${emptyHash.digest('base64')}`; |
| 20 | +const policyHash = crypto.createHash('sha512'); |
| 21 | +policyHash.update(fs.readFileSync(depPolicy)); |
| 22 | + |
| 23 | +/* eslint-disable max-len */ |
| 24 | +// When using \n only |
| 25 | +const nixPolicySRI = 'sha512-u/nXI6UacK5fKDC2bopcgnuQY4JXJKlK3dESO3GIKKxwogVHjJqpF9rgk7Zw+TJXIc96xBUWKHuUgOzic8/4tQ=='; |
| 26 | +// When \n is turned into \r\n |
| 27 | +const windowsPolicySRI = 'sha512-OeyCPRo4OZMosHyquZXDHpuU1F4KzG9UHFnn12FMaHsvqFUt3TFZ+7wmZE7ThZ5rsQWkUjc9ZH0knGZ2e8BYPQ=='; |
| 28 | +/* eslint-enable max-len */ |
| 29 | + |
| 30 | +const depPolicySRI = `${nixPolicySRI} ${windowsPolicySRI}`; |
| 31 | +console.dir({ |
| 32 | + depPolicySRI, |
| 33 | + body: JSON.stringify(fs.readFileSync(depPolicy).toString('utf8')) |
| 34 | +}); |
| 35 | +{ |
| 36 | + const { status, stderr } = spawnSync( |
| 37 | + process.execPath, |
| 38 | + [ |
| 39 | + '--policy-integrity', emptySRI, |
| 40 | + '--experimental-policy', depPolicy, dep, |
| 41 | + ] |
| 42 | + ); |
| 43 | + |
| 44 | + assert.ok(stderr.includes('ERR_MANIFEST_ASSERT_INTEGRITY')); |
| 45 | + assert.strictEqual(status, 1); |
| 46 | +} |
| 47 | +{ |
| 48 | + const { status, stderr } = spawnSync( |
| 49 | + process.execPath, |
| 50 | + [ |
| 51 | + '--policy-integrity', '', |
| 52 | + '--experimental-policy', depPolicy, dep, |
| 53 | + ] |
| 54 | + ); |
| 55 | + |
| 56 | + assert.ok(stderr.includes('--policy-integrity')); |
| 57 | + assert.strictEqual(status, 9); |
| 58 | +} |
| 59 | +{ |
| 60 | + const { status, stderr } = spawnSync( |
| 61 | + process.execPath, |
| 62 | + [ |
| 63 | + '--policy-integrity', depPolicySRI, |
| 64 | + '--experimental-policy', depPolicy, dep, |
| 65 | + ] |
| 66 | + ); |
| 67 | + |
| 68 | + assert.strictEqual(status, 0, `status: ${status}\nstderr: ${stderr}`); |
| 69 | +} |
0 commit comments