Bundles the prior autonomous-session output that was sitting unstaged: - Em-dash sweep across src/ + tests/ (en-dash/em-dash to hyphen, ~2280 instances) - country-flag-icons rollout (CountryFlag component, replaces emoji glyphs that never rendered on Windows; lazy-loads the 3x2 SVG index as a single chunk after the per-subpath dynamic-import approach silently failed in webpack) - Admin IA Phase 1+2: 7-domain regroup, 41 to 38 pages, /admin/berths index, redirects (ocr to ai, reports to dashboard, invitations to users), docs/admin-ia-proposal.md - Per-template email tester (registry + endpoint + UI on Email admin page) - Cancel-document mode picker (delete-from-Documenso vs keep-for-audit) - Dashboard PDF report: 25 widgets, SVG charts, date-range picker, 11 resolvers - Customize-widgets per-region sortables at xl+ (charts/rails/feed); single flat sortable below xl when the layout stacks; per-viewport saved orders - Audit doc updates capturing each shipped item - Lint fixes: react-compiler immutability in DonutChart (reduce instead of let-reassign), set-state-in-effect disables in CountryFlag and UploadForSigning preview-bytes effect, unused 'confirm' destructures in interest contract + reservation tabs, unescaped apostrophe in test-template card copy
88 lines
3.0 KiB
TypeScript
88 lines
3.0 KiB
TypeScript
/**
|
|
* i18n PR1 - country dataset.
|
|
*
|
|
* Validates:
|
|
* 1. The dataset includes every common ISO-3166-1 alpha-2 code we'd
|
|
* reasonably want (sanity sample, not exhaustive)
|
|
* 2. `isValidCountryCode` rejects bogus inputs
|
|
* 3. `getCountryName` returns localized names; falls back to the code
|
|
* 4. `detectDefaultCountry` returns the fallback in non-browser envs
|
|
*/
|
|
|
|
import { describe, it, expect } from 'vitest';
|
|
import {
|
|
ALL_COUNTRY_CODES,
|
|
ISO_COUNTRIES,
|
|
isValidCountryCode,
|
|
getCountryName,
|
|
detectDefaultCountry,
|
|
} from '@/lib/i18n/countries';
|
|
|
|
describe('i18n countries', () => {
|
|
it('includes core anglophone, EU, MENA, APAC, and Americas codes', () => {
|
|
const sample = ['US', 'GB', 'PL', 'DE', 'FR', 'AU', 'JP', 'BR', 'AE', 'NG', 'AI'];
|
|
for (const code of sample) {
|
|
expect(ISO_COUNTRIES.has(code)).toBe(true);
|
|
}
|
|
});
|
|
|
|
it('has at least 240 codes and is unique', () => {
|
|
expect(ALL_COUNTRY_CODES.length).toBeGreaterThanOrEqual(240);
|
|
expect(new Set(ALL_COUNTRY_CODES).size).toBe(ALL_COUNTRY_CODES.length);
|
|
});
|
|
|
|
it('isValidCountryCode rejects unknown / lowercased / 3-letter codes', () => {
|
|
expect(isValidCountryCode('US')).toBe(true);
|
|
expect(isValidCountryCode('us')).toBe(false);
|
|
expect(isValidCountryCode('USA')).toBe(false);
|
|
expect(isValidCountryCode('XX')).toBe(false);
|
|
expect(isValidCountryCode('')).toBe(false);
|
|
});
|
|
|
|
it('getCountryName returns localized names and falls back to the code on error', () => {
|
|
expect(getCountryName('US', 'en')).toMatch(/United States/);
|
|
expect(getCountryName('GB', 'en')).toMatch(/United Kingdom/);
|
|
expect(getCountryName('PL', 'pl')).toMatch(/Polska/i);
|
|
// Unknown code -> code itself.
|
|
expect(getCountryName('ZZ', 'en')).toBe('ZZ');
|
|
});
|
|
|
|
it('detectDefaultCountry returns the navigator region when valid', () => {
|
|
const original = globalThis.navigator;
|
|
Object.defineProperty(globalThis, 'navigator', {
|
|
value: { language: 'en-GB' },
|
|
configurable: true,
|
|
});
|
|
expect(detectDefaultCountry()).toBe('GB');
|
|
Object.defineProperty(globalThis, 'navigator', {
|
|
value: original,
|
|
configurable: true,
|
|
});
|
|
});
|
|
|
|
it('detectDefaultCountry uses the fallback when navigator is unset', () => {
|
|
const original = globalThis.navigator;
|
|
// @ts-expect-error force navigator to undefined for the duration of this test
|
|
delete globalThis.navigator;
|
|
expect(detectDefaultCountry()).toBe('US');
|
|
expect(detectDefaultCountry('GB')).toBe('GB');
|
|
Object.defineProperty(globalThis, 'navigator', {
|
|
value: original,
|
|
configurable: true,
|
|
});
|
|
});
|
|
|
|
it('detectDefaultCountry falls back when the navigator region is unknown', () => {
|
|
const original = globalThis.navigator;
|
|
Object.defineProperty(globalThis, 'navigator', {
|
|
value: { language: 'xx-ZZ' },
|
|
configurable: true,
|
|
});
|
|
expect(detectDefaultCountry()).toBe('US');
|
|
Object.defineProperty(globalThis, 'navigator', {
|
|
value: original,
|
|
configurable: true,
|
|
});
|
|
});
|
|
});
|