From 5352ae8eb1998b8d2dc3ec6a4aaab6f451ccff0e Mon Sep 17 00:00:00 2001 From: Jordan Date: Tue, 4 Mar 2025 07:20:00 -0800 Subject: [PATCH] add more mocking --- components/Settings.tsx | 31 +++++++++++--------- components/ui/__tests__/Settings.spec.tsx | 33 +++++++++++++++------- translation_terrace.db | Bin 24576 -> 0 bytes 3 files changed, 41 insertions(+), 23 deletions(-) delete mode 100644 translation_terrace.db diff --git a/components/Settings.tsx b/components/Settings.tsx index a7a97dc..4f4d5fc 100644 --- a/components/Settings.tsx +++ b/components/Settings.tsx @@ -1,6 +1,6 @@ import React, { useState, useEffect } from "react"; import { View, Text, TextInput, Pressable, StyleSheet } from "react-native"; -import { WhisperFile } from "@/app/lib/whisper"; +import { WhisperFile, download_status_t, whisper_tag_t } from "@/app/lib/whisper"; import { Settings } from "@/app/lib/settings"; import { Picker } from "@react-native-picker/picker"; import { LanguageServer, language_matrix, language_matrix_entry } from "@/app/i18n/api"; @@ -25,9 +25,9 @@ const SettingsComponent = () => { const [whisperModel, setWhisperModel] = useState("small"); const [downloader, setDownloader] = useState(null); - const [whisperDownloadProgress, setWhisperDownloadProgress] = useState< - any | null - >(null); + const [whisperFile, setWhisperFile] = useState(null); + const [downloadStatus, setDownloadStatus] = useState(); + const [downloadStatusChecker, setDownloadStatusChecker] = useState(); useEffect(() => { loadSettings(); @@ -74,17 +74,22 @@ const SettingsComponent = () => { } }; + const intervalUpdateDownloadStatus = async () => { + if (!whisperFile) return; + const status = await whisperFile.getDownloadStatus(); + setDownloadStatus(status); + } + const handleWhisperModelChange = async ( - model: keyof typeof WHISPER_MODELS + model: whisper_tag_t, ) => { const settings = await Settings.getDefault(); - setWhisperModel(model); await settings.setWhisperModel(model); - checkDownloadStatus(model); + setWhisperModel(model); + setWhisperFile(new WhisperFile(model)); }; const doDownload = async () => { - const whisperFile = WHISPER_MODELS[whisperModel]; const resumable = await whisperFile.createDownloadResumable({ onData: (progress) => setWhisperDownloadProgress(progress), }); @@ -122,16 +127,16 @@ const SettingsComponent = () => { return hostLanguage && libretranslateBaseUrl ? ( Host Language: - - { languag } - - - + {languageOptions && Object.entries(languageOptions).map(([key, value]) => { + return () + })} + )} LibreTranslate Base URL: { - const originalModule = jest.requireActual('@/app/lib/whisper'); +// Mock the WhisperFile class +jest.mock("@/app/lib/whisper", () => { + const originalModule = jest.requireActual("@/app/lib/whisper"); return { ...originalModule, - Whisper: class { - constructor(...args) { - originalModule.Whisper.apply(this, args); - } + WhisperFile: jest.fn().mockImplementation((tag, targetFileName, label, size) => ({ + tag, + targetFileName, + label, + size, + doesTargetExist: jest.fn(), + getDownloadStatus: jest.fn(), // Mock other methods as needed + isDownloadcomplete: () => true, + })), + }; +}); - targetFile = { - bytes: jest.fn().mockReturnValue(new Uint8Array([/* mock data */])), - }; - }, +jest.mock("expo-file-system", () => { + const originalModule = jest.requireActual("expo-file-system"); + + return { + ...originalModule, + File: jest.fn().mockImplementation(() => ({ + bytes: jest.fn(), + exists: jest.fn(), + })), }; }); diff --git a/translation_terrace.db b/translation_terrace.db deleted file mode 100644 index 1bee6945684e97164c926edb040b977c3699b446..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 24576 zcmeI)J#W)M7zglk(lk_}4TvEul}-#*qf~t*2q6Xv>QWW))&&r_W?AVp*lTvW?2Un(C886;=<(&GMEhism-2uh9ZC2Tw`!=^d`~LE$b6Ow-0SG_< z0uX=z1Rwwb2tXh&FnCcaS8FxzNL$g2=%6D_ml8kLAw?#;HT~e}*5>XO-`%{wv&DmK zFyM>9uu;I@ilo&M$>MsWQCs3cs1H=6Md%wVY|jL|sdYp`xe)cc)UxD4@*M?SDobrj zTp$w0`W<090k_n*Zcp>jlJP^W+;O=MMj`7Gh_bQTU~Q^gouBuP8pGraSu0iBjO$W1 zq4DlCm5z1;h=gkQMEmz1BiT&ICPJA=Sn`{~kl#yky}Lp8q#w$}r6{%fHN6a7e#|$D z_QY|vs&0=O?x!|G_F)g{4 zwZUDloSyP%<*c-G=@c^O406$7o~MKTvn11jWUoYe(+S&hx8Ui0Ik^zNmFe-JyZq@| zEuEXYNk6N6&i}x$4FL#100Izz00bZa0SG_<0uX?}-zRW$p~N1})Yn(n8><_uu3Edb zcH5UqS}7ub^uS};nwPry#y!~KkA~H&bpBtcd|{Pi_k{%l5P$##AOHafKmY;|fB*y_ z0D*r*;98+r_i}F*EL6Q>VA38bt~vlxCkp9*`IRn!2vURq1Rwwb2tWV=5P$##AOHafTu6bRcZ+E)