123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- var t = require('assert')
- var defaults = require('./utils/defaults')
- module.exports = ({popup, advanced, content}) => {
- before(async () => {
- await defaults({popup, advanced, content})
- // enable path matching
- await advanced.evaluate(() => {
- document.querySelector('.m-list li:nth-of-type(1) input').value = 'encoding-.*'
- document.querySelector('.m-list li:nth-of-type(1) input').dispatchEvent(new Event('keyup'))
- })
- // there is debounce timeout of 750ms in the options UI
- await advanced.waitForTimeout(800)
- })
- describe('no content-type header set', () => {
- before(async () => {
- // set wrong encoding
- await advanced.select('.m-list li:nth-of-type(1) .m-encoding select', 'Shift_JIS')
- // go to page serving Big5 encoded string
- // with no content-type header set
- await content.goto('http://localhost:3000/encoding-no-content-type')
- await content.bringToFront()
- await content.waitForTimeout(300)
- })
- it('do not override if content-type header is missing', async () => {
- t.equal(
- await content.evaluate(() => document.charset),
- 'Big5',
- 'chrome detects the correct encoding automatically'
- )
- t.equal(
- await content.evaluate(() => document.querySelector('#_html p').innerText),
- '你好',
- 'text should be decoded correctly'
- )
- })
- })
- describe('no charset in content-type header', () => {
- before(async () => {
- // set wrong encoding
- await advanced.select('.m-list li:nth-of-type(1) .m-encoding select', 'Shift_JIS')
- // go to page serving Big5 encoded string
- // with no charset set in the content-type header
- await content.goto('http://localhost:3000/encoding-no-charset')
- await content.bringToFront()
- await content.waitForTimeout(300)
- })
- it('do not override if charset is missing in content-type header', async () => {
- t.equal(
- await content.evaluate(() => document.charset),
- 'Big5',
- 'chrome detects the correct encoding automatically'
- )
- t.equal(
- await content.evaluate(() => document.querySelector('#_html p').innerText),
- '你好',
- 'text should be decoded correctly'
- )
- })
- })
- describe('wrong charset in content-type header', () => {
- before(async () => {
- // detect encoding automatically
- await advanced.select('.m-list li:nth-of-type(1) .m-encoding select', '')
- // go to page serving windows-1251 encoded string
- // with UTF-8 charset set in content-type header
- await content.goto('http://localhost:3000/encoding-wrong-charset')
- await content.bringToFront()
- await content.waitForTimeout(300)
- })
- it('when encoding override is disabled', async () => {
- t.equal(
- await content.evaluate(() => document.charset),
- 'UTF-8',
- 'chrome picks the wrong encoding from the content-type charset'
- )
- t.equal(
- await content.evaluate(() => document.querySelector('#_html p').innerText),
- '�������',
- 'text should be decoded incorrectly'
- )
- })
- })
- // TEST: overriding content-type no longer works
- describe.skip('override charset set in content-type header', () => {
- before(async () => {
- await advanced.bringToFront()
- // override encoding
- await advanced.select('.m-list li:nth-of-type(1) .m-encoding select', 'Windows-1251')
- // go to page serving windows-1251 encoded string
- // with UTF-8 charset set in content-type header
- await content.goto('http://localhost:3000/encoding-wrong-charset')
- await content.bringToFront()
- await content.waitForTimeout(300)
- })
- it('use encoding set for the origin', async () => {
- t.equal(
- await content.evaluate(() => document.charset),
- 'windows-1251',
- 'the content-type charset should be overridden'
- )
- t.equal(
- await content.evaluate(() => document.querySelector('#_html p').innerText),
- 'здрасти',
- 'text should be decoded correctly'
- )
- })
- })
- describe('persist state', () => {
- before(async () => {
- await advanced.bringToFront()
- await advanced.reload()
- await advanced.waitForTimeout(300)
- // expand origin
- await advanced.click('.m-list li:nth-of-type(1)')
- })
- it('reload', async () => {
- t.equal(
- await advanced.evaluate(() =>
- document.querySelector('.m-list li:nth-of-type(1) .m-encoding select').value
- ),
- 'Windows-1251',
- 'should persist the selected encoding'
- )
- })
- })
- }
|