chromium/third_party/blink/web_tests/external/wpt/websockets/stream/tentative/remote-close.any.js

// META: script=../../constants.sub.js
// META: script=resources/url-constants.js
// META: global=window,worker
// META: variant=?default
// META: variant=?wss
// META: variant=?wpt_flags=h2

'use strict';

promise_test(async t => {
  const wss = new WebSocketStream(`${BASEURL}/remote-close?code=1000`);
  const { readable, writable } = await wss.opened;
  const { closeCode, reason } = await wss.closed;
  assert_equals(closeCode, 1000, 'code should be 1000');
  assert_equals(reason, '', 'reason should be empty');
  const { value, done } = await readable.getReader().read();
  assert_true(done, 'readable should be closed');
  await promise_rejects_dom(t, 'InvalidStateError', writable.getWriter().ready,
                            'writable should be errored');
}, 'clean close should be clean');

promise_test(async () => {
  const wss = new WebSocketStream(`${BASEURL}/remote-close`);
  const { closeCode, reason } = await wss.closed;
  assert_equals(closeCode, 1005, 'code should be No Status Rcvd');
  assert_equals(reason, '', 'reason should be empty');
}, 'close frame with no body should result in status code 1005');

promise_test(async () => {
  const wss = new WebSocketStream(`${BASEURL}/remote-close?code=4000&reason=robot`);
  const { closeCode, reason } = await wss.closed;
  assert_equals(closeCode, 4000, 'code should be 4000');
  assert_equals(reason, 'robot', 'reason should be set');
}, 'reason should be passed through');

promise_test(async () => {
  const wss = new WebSocketStream(`${BASEURL}/remote-close?code=4000&` +
                                  'reason=%E3%83%AD%E3%83%9C%E3%83%83%E3%83%88');
  const { reason } = await wss.closed;
  assert_equals(reason, 'ロボット', 'reason should be set');
}, 'UTF-8 reason should work');

promise_test(async t => {
  const wss = new WebSocketStream(`${BASEURL}/remote-close?code=4567`);
  const { writable } = await wss.opened;
  const veryLargeMessage = new Uint8Array(20 * 1024 * 1024);  // 20MB.
  const writePromise = writable.getWriter().write(veryLargeMessage);
  const closedError = await wss.closed.then(t.unreached_func('closed should reject'), e => e);
  assert_equals(closedError.constructor, WebSocketError, 'error should be WebSocketError');
  assert_equals(closedError.closeCode, 4567, 'closeCode should be set');
  promise_rejects_js(t, WebSocketError, writePromise, 'write() should reject');
}, 'close with unwritten data should not be considered clean');

promise_test(async t => {
  const wss = new WebSocketStream(`${BASEURL}/remote-close?code=4222&reason=remote`);
  await wss.opened;
  wss.close({closeCode: 4111, reason: 'local'});
  const { closeCode, reason } = await wss.closed;
  assert_equals(closeCode, 4222, 'remote code should be used');
  assert_equals(reason, 'remote', 'remote reason should be used');
}, 'remote code and reason should be used');

promise_test(async t => {
  const wss = new WebSocketStream(`${BASEURL}/remote-close?abrupt=1`);
  const { readable, writable } = await wss.opened;
  const closedError = await wss.closed.then(t.unreached_func('closed should reject'), e => e);
  assert_equals(closedError.constructor, WebSocketError, 'error should be a WebSocketError');
  assert_equals(closedError.name, 'WebSocketError', 'error name should be WebSocketError');
  assert_equals(closedError.closeCode, 1006, 'code should be Abnormal Closure');
  await promise_rejects_exactly(t, closedError, readable.getReader().read(),
                                'readable should be errored with the same object');
  await promise_rejects_exactly(t, closedError, writable.getWriter().ready,
                                'writable should be errored with the same object');
}, 'abrupt close should give an error');