aboutsummaryrefslogtreecommitdiffstats
path: root/__tests__/FileSystemAPIUtils.ts
diff options
context:
space:
mode:
Diffstat (limited to '__tests__/FileSystemAPIUtils.ts')
-rw-r--r--__tests__/FileSystemAPIUtils.ts124
1 files changed, 124 insertions, 0 deletions
diff --git a/__tests__/FileSystemAPIUtils.ts b/__tests__/FileSystemAPIUtils.ts
new file mode 100644
index 00000000000..efb273e9dcd
--- /dev/null
+++ b/__tests__/FileSystemAPIUtils.ts
@@ -0,0 +1,124 @@
+import { basename } from 'node:path'
+import mime from 'mime'
+
+class FileSystemEntry {
+
+ private _isFile: boolean
+ private _fullPath: string
+
+ constructor(isFile: boolean, fullPath: string) {
+ this._isFile = isFile
+ this._fullPath = fullPath
+ }
+
+ get isFile() {
+ return !!this._isFile
+ }
+
+ get isDirectory() {
+ return !this.isFile
+ }
+
+ get name() {
+ return basename(this._fullPath)
+ }
+
+}
+
+export class FileSystemFileEntry extends FileSystemEntry {
+
+ private _contents: string
+ private _lastModified: number
+
+ constructor(fullPath: string, contents: string, lastModified = Date.now()) {
+ super(true, fullPath)
+ this._contents = contents
+ this._lastModified = lastModified
+ }
+
+ file(success: (file: File) => void) {
+ const lastModified = this._lastModified
+ // Faking the mime by using the file extension
+ const type = mime.getType(this.name) || ''
+ success(new File([this._contents], this.name, { lastModified, type }))
+ }
+
+}
+
+export class FileSystemDirectoryEntry extends FileSystemEntry {
+
+ private _entries: FileSystemEntry[]
+
+ constructor(fullPath: string, entries: FileSystemEntry[]) {
+ super(false, fullPath)
+ this._entries = entries || []
+ }
+
+ createReader() {
+ let read = false
+ return {
+ readEntries: (success: (entries: FileSystemEntry[]) => void) => {
+ if (read) {
+ return success([])
+ }
+ read = true
+ success(this._entries)
+ },
+ }
+ }
+
+}
+
+/**
+ * This mocks the File API's File class
+ * It will allow us to test the Filesystem API as well as the
+ * File API in the same test suite.
+ */
+export class DataTransferItem {
+
+ private _type: string
+ private _entry: FileSystemEntry
+
+ getAsEntry?: () => FileSystemEntry
+
+ constructor(type = '', entry: FileSystemEntry, isFileSystemAPIAvailable = true) {
+ this._type = type
+ this._entry = entry
+
+ // Only when the Files API is available we are
+ // able to get the entry
+ if (isFileSystemAPIAvailable) {
+ this.getAsEntry = () => this._entry
+ }
+ }
+
+ get kind() {
+ return 'file'
+ }
+
+ get type() {
+ return this._type
+ }
+
+ getAsFile(): File|null {
+ if (this._entry.isFile && this._entry instanceof FileSystemFileEntry) {
+ let file: File | null = null
+ this._entry.file((f) => {
+ file = f
+ })
+ return file
+ }
+
+ // The browser will return an empty File object if the entry is a directory
+ return new File([], this._entry.name, { type: '' })
+ }
+
+}
+
+export const fileSystemEntryToDataTransferItem = (entry: FileSystemEntry, isFileSystemAPIAvailable = true): DataTransferItem => {
+ return new DataTransferItem(
+ entry.isFile ? 'text/plain' : 'httpd/unix-directory',
+ entry,
+ isFileSystemAPIAvailable,
+ )
+}