mirror of
				https://github.com/microsoft/playwright.git
				synced 2025-06-26 21:40:17 +00:00 
			
		
		
		
	
		
			
	
	
		
			99 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			99 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|   | /** | ||
|  |  * Copyright (c) 2014-present Matt Zabriskie | ||
|  |  * Modifications copyright (c) Microsoft Corporation. | ||
|  |  * | ||
|  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||
|  |  * of this software and associated documentation files (the "Software"), to deal | ||
|  |  * in the Software without restriction, including without limitation the rights | ||
|  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
|  |  * copies of the Software, and to permit persons to whom the Software is | ||
|  |  * furnished to do so, subject to the following conditions: | ||
|  |  * | ||
|  |  * The above copyright notice and this permission notice shall be included in | ||
|  |  * all copies or substantial portions of the Software. | ||
|  |  * | ||
|  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
|  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
|  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
|  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
|  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
|  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||
|  |  * THE SOFTWARE. | ||
|  |  */ | ||
|  | 
 | ||
|  | import { contextTest as it, expect } from '../config/browserTest'; | ||
|  | import util from 'util'; | ||
|  | import zlib from 'zlib'; | ||
|  | 
 | ||
|  | const gzip = util.promisify(zlib.gzip); | ||
|  | const deflate = util.promisify(zlib.deflate); | ||
|  | const brotliCompress = util.promisify(zlib.brotliCompress); | ||
|  | 
 | ||
|  | it.skip(({ mode }) => mode !== 'default'); | ||
|  | 
 | ||
|  | it.describe('algorithms', () => { | ||
|  |   const responseBody = 'str'; | ||
|  | 
 | ||
|  |   for (const [type, zipped] of Object.entries({ | ||
|  |     gzip: gzip(responseBody), | ||
|  |     deflate: deflate(responseBody), | ||
|  |     br: brotliCompress(responseBody) | ||
|  |   })) { | ||
|  |     it.describe(`${type} decompression`, () => { | ||
|  |       it(`should support decompression`, async ({ context, server }) => { | ||
|  |         server.setRoute('/compressed', async (req, res) => { | ||
|  |           res.setHeader('Content-Encoding', type); | ||
|  |           res.end(await zipped); | ||
|  |         }); | ||
|  | 
 | ||
|  |         const response = await context.request.get(server.PREFIX + '/compressed'); | ||
|  |         expect(await response.text()).toEqual(responseBody); | ||
|  |       }); | ||
|  | 
 | ||
|  |       it(`should not fail if response content-length header is missing (${type})`, async ({ context, server }) => { | ||
|  |         server.setRoute('/compressed', async (req, res) => { | ||
|  |           res.setHeader('Content-Encoding', type); | ||
|  |           res.removeHeader('Content-Length'); | ||
|  |           res.end(await zipped); | ||
|  |         }); | ||
|  | 
 | ||
|  |         const response = await context.request.get(server.PREFIX + '/compressed'); | ||
|  |         expect(await response.text()).toEqual(responseBody); | ||
|  |       }); | ||
|  | 
 | ||
|  |       it('should not fail with chunked responses (without Content-Length header)', async ({ context, server }) => { | ||
|  |         server.setRoute('/compressed', async (req, res) => { | ||
|  |           res.setHeader('Content-Encoding', type); | ||
|  |           res.setHeader('Transfer-Encoding', 'chunked'); | ||
|  |           res.removeHeader('Content-Length'); | ||
|  |           res.write(await zipped); | ||
|  |           res.end(); | ||
|  |         }); | ||
|  | 
 | ||
|  |         const response = await context.request.get(server.PREFIX + '/compressed'); | ||
|  |         expect(await response.text()).toEqual(responseBody); | ||
|  |       }); | ||
|  | 
 | ||
|  |       it('should not fail with an empty response without content-length header (Z_BUF_ERROR)', async ({ context, server }) => { | ||
|  |         server.setRoute('/compressed', async (req, res) => { | ||
|  |           res.setHeader('Content-Encoding', type); | ||
|  |           res.removeHeader('Content-Length'); | ||
|  |           res.end(); | ||
|  |         }); | ||
|  | 
 | ||
|  |         const response = await context.request.get(server.PREFIX + '/compressed'); | ||
|  |         expect(await response.text()).toEqual(''); | ||
|  |       }); | ||
|  | 
 | ||
|  |       it('should not fail with an empty response with content-length header (Z_BUF_ERROR)', async ({ context, server }) => { | ||
|  |         server.setRoute('/compressed', async (req, res) => { | ||
|  |           res.setHeader('Content-Encoding', type); | ||
|  |           res.end(); | ||
|  |         }); | ||
|  | 
 | ||
|  |         await context.request.get(server.PREFIX + '/compressed'); | ||
|  |       }); | ||
|  |     }); | ||
|  |   } | ||
|  | }); |