summaryrefslogtreecommitdiffstats
path: root/remote/test/browser/io/browser_read.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /remote/test/browser/io/browser_read.js
parentInitial commit. (diff)
downloadfirefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz
firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'remote/test/browser/io/browser_read.js')
-rw-r--r--remote/test/browser/io/browser_read.js155
1 files changed, 155 insertions, 0 deletions
diff --git a/remote/test/browser/io/browser_read.js b/remote/test/browser/io/browser_read.js
new file mode 100644
index 0000000000..1692e45e90
--- /dev/null
+++ b/remote/test/browser/io/browser_read.js
@@ -0,0 +1,155 @@
+/* Any copyright is dedicated to the Public Domain.
+ * http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+add_task(async function seekByOffsets({ client }) {
+ const { IO } = client;
+ const contents = "Lorem ipsum";
+ const { handle } = await registerFileStream(contents);
+
+ for (const offset of [0, 5, 10, 100, 0, -1]) {
+ const result = await IO.read({ handle, offset });
+ ok(result.base64Encoded, `Data for offset ${offset} is base64 encoded`);
+ ok(result.eof, `All data has been read for offset ${offset}`);
+ is(
+ atob(result.data),
+ contents.substring(offset >= 0 ? offset : 0),
+ `Found expected data for offset ${offset}`
+ );
+ }
+});
+
+add_task(async function remembersOffsetAfterRead({ client }) {
+ const { IO } = client;
+ const contents = "Lorem ipsum";
+ const { handle } = await registerFileStream(contents);
+
+ let expectedOffset = 0;
+ const size = 3;
+ do {
+ const result = await IO.read({ handle, size });
+ is(
+ atob(result.data),
+ contents.substring(expectedOffset, expectedOffset + size),
+ `Found expected data for expectedOffset ${expectedOffset}`
+ );
+ ok(
+ result.base64Encoded,
+ `Data up to expected offset ${expectedOffset} is base64 encoded`
+ );
+
+ is(
+ result.eof,
+ expectedOffset + size >= contents.length,
+ `All data has been read up to expected offset ${expectedOffset}`
+ );
+
+ expectedOffset = Math.min(expectedOffset + size, contents.length);
+ } while (expectedOffset < contents.length);
+});
+
+add_task(async function readBySize({ client }) {
+ const { IO } = client;
+ const contents = "Lorem ipsum";
+ const { handle } = await registerFileStream(contents);
+
+ for (const size of [0, 5, 10, 100, 0, -1]) {
+ const result = await IO.read({ handle, offset: 0, size });
+ ok(result.base64Encoded, `Data for size ${size} is base64 encoded`);
+ is(
+ result.eof,
+ size >= contents.length,
+ `All data has been read for size ${size}`
+ );
+ is(
+ atob(result.data),
+ contents.substring(0, size),
+ `Found expected data for size ${size}`
+ );
+ }
+});
+
+add_task(async function readAfterClose({ client }) {
+ const { IO } = client;
+ const contents = "Lorem ipsum";
+ const { handle } = await registerFileStream(contents);
+
+ await IO.close({ handle });
+
+ try {
+ await IO.read({ handle });
+ ok(false, "Read shouldn't pass");
+ } catch (e) {
+ ok(
+ e.message.startsWith(`Invalid stream handle`),
+ "Error contains expected message"
+ );
+ }
+});
+
+add_task(async function unknownHandle({ client }) {
+ const { IO } = client;
+ const handle = "1000000";
+
+ try {
+ await IO.read({ handle });
+ ok(false, "Read shouldn't pass");
+ } catch (e) {
+ ok(
+ e.message.startsWith(`Invalid stream handle`),
+ "Error contains expected message"
+ );
+ }
+});
+
+add_task(async function invalidHandleTypes({ client }) {
+ const { IO } = client;
+ for (const handle of [null, true, 1, [], {}]) {
+ try {
+ await IO.read({ handle });
+ ok(false, "Read shouldn't pass");
+ } catch (e) {
+ ok(
+ e.message.startsWith(`handle: string value expected`),
+ "Error contains expected message"
+ );
+ }
+ }
+});
+
+add_task(async function invalidOffsetTypes({ client }) {
+ const { IO } = client;
+ const contents = "Lorem ipsum";
+ const { handle } = await registerFileStream(contents);
+
+ for (const offset of [null, true, "1", [], {}]) {
+ try {
+ await IO.read({ handle, offset });
+ ok(false, "Read shouldn't pass");
+ } catch (e) {
+ ok(
+ e.message.startsWith(`offset: integer value expected`),
+ "Error contains expected message"
+ );
+ }
+ }
+});
+
+add_task(async function invalidSizeTypes({ client }) {
+ const { IO } = client;
+ const contents = "Lorem ipsum";
+ const { handle } = await registerFileStream(contents);
+
+ for (const size of [null, true, "1", [], {}]) {
+ try {
+ await IO.read({ handle, size });
+ ok(false, "Read shouldn't pass");
+ } catch (e) {
+ ok(
+ e.message.startsWith(`size: integer value expected`),
+ "Error contains expected message"
+ );
+ }
+ }
+});