From f8fcf108204ef6aae8a546bcec75cacfd0533a3d Mon Sep 17 00:00:00 2001 From: Jack Greenlee Date: Fri, 13 Sep 2024 14:46:26 -0400 Subject: [PATCH] add `ui_error`s to clientStats Whenever the user sees an error, it will be recorded in clientStats as a `stats/client_error` --- www/__tests__/clientStats.test.ts | 8 ++++++-- www/js/plugin/clientStats.ts | 7 ++++--- www/js/plugin/logger.ts | 3 +++ 3 files changed, 13 insertions(+), 5 deletions(-) diff --git a/www/__tests__/clientStats.test.ts b/www/__tests__/clientStats.test.ts index 632eafddf..2795ff3fd 100644 --- a/www/__tests__/clientStats.test.ts +++ b/www/__tests__/clientStats.test.ts @@ -40,10 +40,14 @@ it('stores a client stats event', async () => { it('stores a client stats error', async () => { const errorStr = 'test error'; - await addStatError('missing_keys', errorStr); + try { + throw new Error(errorStr); + } catch (error) { + await addStatError(error.message); + } const storedMessages = await db.getAllMessages('stats/client_error', false); expect(storedMessages).toContainEqual({ - name: 'missing_keys', + name: 'ui_error', ts: expect.any(Number), reading: errorStr, client_app_version: '1.2.3', diff --git a/www/js/plugin/clientStats.ts b/www/js/plugin/clientStats.ts index e106dd7cf..7c512f2c2 100644 --- a/www/js/plugin/clientStats.ts +++ b/www/js/plugin/clientStats.ts @@ -12,7 +12,8 @@ type StatKey = | 'set_reminder_prefs' | 'force_sync' | 'open_notification' - | 'missing_keys'; + | 'missing_keys' + | 'ui_error'; let appVersion; export function getAppVersion() { @@ -39,9 +40,9 @@ export async function addStatReading(name: StatKey, reading?: any) { displayErrorMsg('addStatReading: db is not defined'); } -export async function addStatError(name: StatKey, errorStr: string) { +export async function addStatError(errorMsg: string) { const db = window['cordova']?.plugins?.BEMUserCache; - const event = await getStatsEvent(name, errorStr); + const event = await getStatsEvent('ui_error', errorMsg); logDebug('addStatError: adding CLIENT_ERROR event: ' + JSON.stringify(event)); if (db) return db.putMessage(CLIENT_ERROR, event); displayErrorMsg('addStatError: db is not defined'); diff --git a/www/js/plugin/logger.ts b/www/js/plugin/logger.ts index 98e852978..12664bbed 100644 --- a/www/js/plugin/logger.ts +++ b/www/js/plugin/logger.ts @@ -1,3 +1,5 @@ +import { addStatError } from './clientStats'; + export const logDebug = (message: string) => window['Logger']?.log(window['Logger'].LEVEL_DEBUG, message); @@ -19,6 +21,7 @@ export function displayErrorMsg(errorMsg: string, title?: string) { } const displayMsg = `━━━━\n${title}\n━━━━\n` + errorMsg; window.alert(displayMsg); + addStatError(title ? `${title}: ${errorMsg}` : errorMsg); console.error(displayMsg); window['Logger']?.log(window['Logger'].LEVEL_ERROR, displayMsg); }