sakhi / frontend /src /lib /__tests__ /hindiNormalize.test.js
Tushar9802's picture
HF Space deploy — initial
745f62a
import { test } from 'node:test'
import assert from 'node:assert/strict'
import {
WORD_TO_NUM,
parseHindiNumber,
convertNumbers,
normalizeTranscript,
} from '../hindiNormalize.js'
test('WORD_TO_NUM has 160+ entries covering 0-99 + 100', () => {
assert.ok(Object.keys(WORD_TO_NUM).length >= 160)
assert.equal(WORD_TO_NUM['शून्य'], 0)
assert.equal(WORD_TO_NUM['एक'], 1)
assert.equal(WORD_TO_NUM['दस'], 10)
assert.equal(WORD_TO_NUM['सौ'], 100)
})
test('parseHindiNumber single-word lookups', () => {
assert.equal(parseHindiNumber('शून्य'), 0)
assert.equal(parseHindiNumber('एक'), 1)
assert.equal(parseHindiNumber('दस'), 10)
assert.equal(parseHindiNumber('सत्तर'), 70)
assert.equal(parseHindiNumber('अट्ठावन'), 58)
assert.equal(parseHindiNumber('सौ'), 100)
})
test('parseHindiNumber compound phrases', () => {
assert.equal(parseHindiNumber('एक सौ दस'), 110)
assert.equal(parseHindiNumber('एक सौ पचपन'), 155)
assert.equal(parseHindiNumber('दो सौ'), 200)
assert.equal(parseHindiNumber('पाँच सौ'), 500)
})
test('parseHindiNumber returns null on empty / non-number', () => {
assert.equal(parseHindiNumber(''), null)
assert.equal(parseHindiNumber(' '), null)
assert.equal(parseHindiNumber('नमस्ते'), null)
})
test('parseHindiNumber stops at first non-number word (mirrors Python bug)', () => {
// Python breaks the loop on unknown word, returns `total + current`.
// Since `total` is never incremented, it returns `current` so far.
assert.equal(parseHindiNumber('दस नमस्ते बीस'), 10)
})
test('convertNumbers replaces number words with digits', () => {
assert.equal(convertNumbers('एक सौ दस'), '110')
assert.equal(convertNumbers('एक सौ दस बटा सत्तर'), '110 बटा 70')
assert.equal(convertNumbers('अट्ठावन kg'), '58 kg')
// 'बटा' is a medical abbrev, normalizer replaces it with '/' — but convertNumbers alone doesn't.
})
test('convertNumbers handles compound splits (Whisper artifacts)', () => {
// "एकसो" (merged) should split to "एक सो" and become 100
assert.equal(convertNumbers('एकसो दस'), '110')
assert.equal(convertNumbers('दोसो पचास'), '250')
})
test('normalizeTranscript full pipeline - BP reading', () => {
const out = normalizeTranscript('आपका BP एक सौ दस बटा सत्तर है, वजन अट्ठावन kg')
// After medical-term replace + number convert + space-around-slash cleanup
assert.ok(out.includes('110/70'))
assert.ok(out.includes('58 kg'))
})
test('normalizeTranscript converts बीपी → BP', () => {
const out = normalizeTranscript('बीपी एक सौ दस')
assert.ok(out.startsWith('BP '))
assert.ok(out.includes('110'))
})
test('normalizeTranscript fixes repetition artifacts', () => {
const out = normalizeTranscript('ठीकठीकठीकठीक है')
// 4+ consecutive repeats should collapse to 1
assert.ok(!/(ठीक){4,}/.test(out))
})
test('normalizeTranscript handles decimal via दशमलव', () => {
const out = normalizeTranscript('ग्यारह दशमलव पाँच')
// दशमलव → '.', numbers → digits, then digit-dot-digit whitespace cleanup
assert.ok(out.includes('11'))
assert.ok(out.includes('5'))
})
test('normalizeTranscript adds line break after ।', () => {
const out = normalizeTranscript('वजन बढ़ रहा है। BP ठीक है।')
assert.ok(out.includes('।\n'))
})
test('normalizeTranscript trims trailing punctuation/whitespace', () => {
const out = normalizeTranscript(' ठीक है. ')
assert.equal(out, 'ठीक है')
})
test('normalizeTranscript preserves English medical terms', () => {
const out = normalizeTranscript('BP ठीक, IFA दे दी')
assert.ok(out.includes('BP'))
assert.ok(out.includes('IFA'))
})