'use strict'; // From: https://github.com/w3c/web-platform-tests/blob/7f567fa29c/encoding/textdecoder-ignorebom.html const common = require('../common'); const assert = require('assert'); const { TextDecoder } = require('util'); const cases = [ { encoding: 'utf-8', bytes: [0xEF, 0xBB, 0xBF, 0x61, 0x62, 0x63], skipNoIntl: false }, { encoding: 'utf-16le', bytes: [0xFF, 0xFE, 0x61, 0x00, 0x62, 0x00, 0x63, 0x00], skipNoIntl: false }, { encoding: 'utf-16be', bytes: [0xFE, 0xFF, 0x00, 0x61, 0x00, 0x62, 0x00, 0x63], skipNoIntl: true } ]; cases.forEach((testCase) => { if (testCase.skipNoIntl && !common.hasIntl) { console.log(`skipping ${testCase.encoding} because missing Intl`); return; // skipping } const BOM = '\uFEFF'; let decoder = new TextDecoder(testCase.encoding, { ignoreBOM: true }); const bytes = new Uint8Array(testCase.bytes); assert.strictEqual(decoder.decode(bytes), `${BOM}abc`); decoder = new TextDecoder(testCase.encoding, { ignoreBOM: false }); assert.strictEqual(decoder.decode(bytes), 'abc'); decoder = new TextDecoder(testCase.encoding); assert.strictEqual(decoder.decode(bytes), 'abc'); }); { assert('ignoreBOM' in new TextDecoder()); assert.strictEqual(typeof new TextDecoder().ignoreBOM, 'boolean'); assert(!new TextDecoder().ignoreBOM); assert(new TextDecoder('utf-8', { ignoreBOM: true }).ignoreBOM); }