// These tests expect that a network error is returned if there's a CR that is not immediately // followed by LF before reaching message-body. // // No browser does this currently, but Firefox does treat it equivalently to a space which gives // hope. [ "HTTP/1.1\r200 OK\n\nBODY", "HTTP/1.1 200\rOK\n\nBODY", "HTTP/1.1 200 OK\n\rHeader: Value\n\nBODY", "HTTP/1.1 200 OK\nHeader\r: Value\n\nBODY", "HTTP/1.1 200 OK\nHeader:\r Value\n\nBODY", "HTTP/1.1 200 OK\nHeader: Value\r\n\nBody", "HTTP/1.1 200 OK\nHeader: Value\r\r\nBODY", "HTTP/1.1 200 OK\nHeader: Value\rHeader2: Value2\n\nBODY", "HTTP/1.1 200 OK\nHeader: Value\n\rBODY", "HTTP/1.1 200 OK\nHeader: Value\n\r" ].forEach(input => { promise_test(t => { const message = encodeURIComponent(input); return promise_rejects_js(t, TypeError, fetch(`resources/message.py?message=${message}`)); }, `Parsing response with a lone CR before message-body (${input})`); });