2021-01-11 12:13:41 -05:00
|
|
|
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
|
2020-09-27 06:22:32 -04:00
|
|
|
import { assertEquals, unitTest } from "./test_util.ts";
|
2020-08-11 08:00:53 -04:00
|
|
|
|
|
|
|
unitTest(function fileReaderConstruct(): void {
|
|
|
|
const fr = new FileReader();
|
|
|
|
assertEquals(fr.readyState, FileReader.EMPTY);
|
|
|
|
|
|
|
|
assertEquals(FileReader.EMPTY, 0);
|
|
|
|
assertEquals(FileReader.LOADING, 1);
|
|
|
|
assertEquals(FileReader.DONE, 2);
|
|
|
|
});
|
|
|
|
|
|
|
|
unitTest(async function fileReaderLoadBlob(): Promise<void> {
|
|
|
|
await new Promise<void>((resolve) => {
|
|
|
|
const fr = new FileReader();
|
|
|
|
const b1 = new Blob(["Hello World"]);
|
|
|
|
|
|
|
|
assertEquals(fr.readyState, FileReader.EMPTY);
|
|
|
|
|
|
|
|
const hasOnEvents = {
|
|
|
|
load: false,
|
|
|
|
loadend: false,
|
|
|
|
loadstart: false,
|
|
|
|
progress: 0,
|
|
|
|
};
|
|
|
|
const hasDispatchedEvents = {
|
|
|
|
load: false,
|
|
|
|
loadend: false,
|
|
|
|
loadstart: false,
|
|
|
|
progress: 0,
|
|
|
|
};
|
|
|
|
let result: string | null = null;
|
|
|
|
|
|
|
|
fr.addEventListener("load", () => {
|
|
|
|
hasDispatchedEvents.load = true;
|
|
|
|
});
|
|
|
|
fr.addEventListener("loadend", () => {
|
|
|
|
hasDispatchedEvents.loadend = true;
|
|
|
|
});
|
|
|
|
fr.addEventListener("loadstart", () => {
|
|
|
|
hasDispatchedEvents.loadstart = true;
|
|
|
|
});
|
|
|
|
fr.addEventListener("progress", () => {
|
|
|
|
hasDispatchedEvents.progress += 1;
|
|
|
|
});
|
|
|
|
|
|
|
|
fr.onloadstart = (): void => {
|
|
|
|
hasOnEvents.loadstart = true;
|
|
|
|
};
|
|
|
|
fr.onprogress = (): void => {
|
|
|
|
assertEquals(fr.readyState, FileReader.LOADING);
|
|
|
|
|
|
|
|
hasOnEvents.progress += 1;
|
|
|
|
};
|
|
|
|
fr.onload = (): void => {
|
|
|
|
hasOnEvents.load = true;
|
|
|
|
};
|
|
|
|
fr.onloadend = (ev): void => {
|
|
|
|
hasOnEvents.loadend = true;
|
|
|
|
result = fr.result as string;
|
|
|
|
|
|
|
|
assertEquals(hasOnEvents.loadstart, true);
|
|
|
|
assertEquals(hasDispatchedEvents.loadstart, true);
|
|
|
|
assertEquals(hasOnEvents.load, true);
|
|
|
|
assertEquals(hasDispatchedEvents.load, true);
|
|
|
|
assertEquals(hasOnEvents.loadend, true);
|
|
|
|
assertEquals(hasDispatchedEvents.loadend, true);
|
|
|
|
|
|
|
|
assertEquals(fr.readyState, FileReader.DONE);
|
|
|
|
|
|
|
|
assertEquals(result, "Hello World");
|
|
|
|
assertEquals(ev.lengthComputable, true);
|
|
|
|
resolve();
|
|
|
|
};
|
|
|
|
|
|
|
|
fr.readAsText(b1);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
unitTest(async function fileReaderLoadBlobDouble(): Promise<void> {
|
|
|
|
// impl note from https://w3c.github.io/FileAPI/
|
|
|
|
// Event handler for the load or error events could have started another load,
|
|
|
|
// if that happens the loadend event for the first load is not fired
|
|
|
|
|
|
|
|
const fr = new FileReader();
|
|
|
|
const b1 = new Blob(["First load"]);
|
|
|
|
const b2 = new Blob(["Second load"]);
|
|
|
|
|
|
|
|
await new Promise<void>((resolve) => {
|
|
|
|
let result: string | null = null;
|
|
|
|
|
|
|
|
fr.onload = (): void => {
|
|
|
|
result = fr.result as string;
|
|
|
|
assertEquals(result === "First load" || result === "Second load", true);
|
|
|
|
|
|
|
|
if (result === "First load") {
|
|
|
|
fr.readAsText(b2);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
fr.onloadend = (): void => {
|
|
|
|
assertEquals(result, "Second load");
|
|
|
|
|
|
|
|
resolve();
|
|
|
|
};
|
|
|
|
|
|
|
|
fr.readAsText(b1);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
unitTest(async function fileReaderLoadBlobArrayBuffer(): Promise<void> {
|
|
|
|
await new Promise<void>((resolve) => {
|
|
|
|
const fr = new FileReader();
|
|
|
|
const b1 = new Blob(["Hello World"]);
|
|
|
|
let result: ArrayBuffer | null = null;
|
|
|
|
|
|
|
|
fr.onloadend = (ev): void => {
|
|
|
|
assertEquals(fr.result instanceof ArrayBuffer, true);
|
|
|
|
result = fr.result as ArrayBuffer;
|
|
|
|
|
|
|
|
const decoder = new TextDecoder();
|
|
|
|
const text = decoder.decode(result);
|
|
|
|
|
|
|
|
assertEquals(text, "Hello World");
|
|
|
|
assertEquals(ev.lengthComputable, true);
|
|
|
|
resolve();
|
|
|
|
};
|
|
|
|
|
|
|
|
fr.readAsArrayBuffer(b1);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
unitTest(async function fileReaderLoadBlobDataUrl(): Promise<void> {
|
|
|
|
await new Promise<void>((resolve) => {
|
|
|
|
const fr = new FileReader();
|
|
|
|
const b1 = new Blob(["Hello World"]);
|
|
|
|
let result: string | null = null;
|
|
|
|
|
|
|
|
fr.onloadend = (ev): void => {
|
|
|
|
result = fr.result as string;
|
|
|
|
assertEquals(
|
|
|
|
result,
|
|
|
|
"data:application/octet-stream;base64,SGVsbG8gV29ybGQ=",
|
|
|
|
);
|
|
|
|
assertEquals(ev.lengthComputable, true);
|
|
|
|
resolve();
|
|
|
|
};
|
|
|
|
|
|
|
|
fr.readAsDataURL(b1);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
unitTest(async function fileReaderLoadBlobAbort(): Promise<void> {
|
|
|
|
await new Promise<void>((resolve) => {
|
|
|
|
const fr = new FileReader();
|
|
|
|
const b1 = new Blob(["Hello World"]);
|
|
|
|
|
|
|
|
const hasOnEvents = {
|
|
|
|
load: false,
|
|
|
|
loadend: false,
|
|
|
|
abort: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
fr.onload = (): void => {
|
|
|
|
hasOnEvents.load = true;
|
|
|
|
};
|
|
|
|
fr.onloadend = (ev): void => {
|
|
|
|
hasOnEvents.loadend = true;
|
|
|
|
|
|
|
|
assertEquals(hasOnEvents.load, false);
|
|
|
|
assertEquals(hasOnEvents.loadend, true);
|
|
|
|
assertEquals(hasOnEvents.abort, true);
|
|
|
|
|
|
|
|
assertEquals(fr.readyState, FileReader.DONE);
|
|
|
|
assertEquals(fr.result, null);
|
|
|
|
assertEquals(ev.lengthComputable, false);
|
|
|
|
resolve();
|
|
|
|
};
|
|
|
|
fr.onabort = (): void => {
|
|
|
|
hasOnEvents.abort = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
fr.readAsDataURL(b1);
|
|
|
|
fr.abort();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
unitTest(async function fileReaderLoadBlobAbort(): Promise<void> {
|
|
|
|
await new Promise<void>((resolve) => {
|
|
|
|
const fr = new FileReader();
|
|
|
|
const b1 = new Blob(["Hello World"]);
|
|
|
|
|
|
|
|
const hasOnEvents = {
|
|
|
|
load: false,
|
|
|
|
loadend: false,
|
|
|
|
abort: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
fr.onload = (): void => {
|
|
|
|
hasOnEvents.load = true;
|
|
|
|
};
|
|
|
|
fr.onloadend = (ev): void => {
|
|
|
|
hasOnEvents.loadend = true;
|
|
|
|
|
|
|
|
assertEquals(hasOnEvents.load, false);
|
|
|
|
assertEquals(hasOnEvents.loadend, true);
|
|
|
|
assertEquals(hasOnEvents.abort, true);
|
|
|
|
|
|
|
|
assertEquals(fr.readyState, FileReader.DONE);
|
|
|
|
assertEquals(fr.result, null);
|
|
|
|
assertEquals(ev.lengthComputable, false);
|
|
|
|
resolve();
|
|
|
|
};
|
|
|
|
fr.onabort = (): void => {
|
|
|
|
hasOnEvents.abort = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
fr.readAsDataURL(b1);
|
|
|
|
fr.abort();
|
|
|
|
});
|
|
|
|
});
|
2020-11-11 10:59:49 -05:00
|
|
|
|
|
|
|
unitTest(
|
|
|
|
async function fileReaderDispatchesEventsInCorrectOrder(): Promise<void> {
|
|
|
|
await new Promise<void>((resolve) => {
|
|
|
|
const fr = new FileReader();
|
|
|
|
const b1 = new Blob(["Hello World"]);
|
|
|
|
let out = "";
|
|
|
|
fr.addEventListener("loadend", () => {
|
|
|
|
out += "1";
|
|
|
|
});
|
|
|
|
fr.onloadend = (ev): void => {
|
|
|
|
out += "2";
|
|
|
|
};
|
|
|
|
fr.addEventListener("loadend", () => {
|
|
|
|
assertEquals(out, "12");
|
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
|
|
|
|
fr.readAsDataURL(b1);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
);
|