diff --git a/CHANGELOG.md b/CHANGELOG.md index b5f3953..c194aaf 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # Changelog +## [2.0.1] - 06-09-2024 + +- (fix): skip pre-processing step if opencv did not load + ## [2.0.0] - 10-06-2024 - (feat): `init` is now initialised with config and callbacks to retrieve image blob diff --git a/package.json b/package.json index 5da9dd8..9b0e662 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "author": "Anyline", "name": "@anyline/anyline-guidance-sdk", - "version": "2.0.0", + "version": "2.0.1", "main": "dist/cjs/index.js", "module": "dist/esm/index.js", "types": "dist/esm/index.d.ts", diff --git a/src/modules/OpenCVManager.ts b/src/modules/OpenCVManager.ts index bcbccd4..79a6e18 100644 --- a/src/modules/OpenCVManager.ts +++ b/src/modules/OpenCVManager.ts @@ -6,6 +6,7 @@ export default class OpenCVManager { private readonly opencvLoadedPromise: Promise; private opencvLoadedResolve: (() => void) | null = null; private opencvLoadedReject: ((reason?: any) => void) | null = null; + public isOpenCVLoaded: boolean = false; private constructor() { this.opencvLoadedPromise = new Promise((resolve, reject) => { @@ -24,6 +25,7 @@ export default class OpenCVManager { public loadOpenCV(): void { if (Boolean((window as any)?.cv) && this.opencvLoadedResolve !== null) { this.opencvLoadedResolve(); + this.isOpenCVLoaded = true; return; } @@ -40,6 +42,7 @@ export default class OpenCVManager { cv.onRuntimeInitialized = () => { if (this.opencvLoadedResolve !== null) { this.opencvLoadedResolve(); + this.isOpenCVLoaded = true; } }; }; @@ -53,6 +56,11 @@ export default class OpenCVManager { } public onLoad(callback: (error?: Error) => Promise): void { + if (!this.isOpenCVLoaded) { + void callback(new Error('OpenCV is not fully loaded yet')); + return; + } + this.opencvLoadedPromise .then(async () => { await callback(); @@ -68,5 +76,6 @@ export default class OpenCVManager { } OpenCVManager.instance = null; delete (global as any).cv; + this.isOpenCVLoaded = false; } } diff --git a/tests/unit/OpenCVManager.test.ts b/tests/unit/OpenCVManager.test.ts index 4123a66..9375446 100644 --- a/tests/unit/OpenCVManager.test.ts +++ b/tests/unit/OpenCVManager.test.ts @@ -17,6 +17,7 @@ describe('OpenCVManager', () => { it('loads opencv successfully', async () => { void expect((global as any).cv).toBeUndefined(); + opencvManager.isOpenCVLoaded = true; const mockCallback = jest.fn(); opencvManager.onLoad(mockCallback); @@ -46,6 +47,7 @@ describe('OpenCVManager', () => { it('handles opencv load error', async () => { void expect((global as any).cv).toBeUndefined(); + opencvManager.isOpenCVLoaded = true; const mockCallback = jest.fn(); opencvManager.onLoad(mockCallback); @@ -66,4 +68,14 @@ describe('OpenCVManager', () => { void expect((global as any).cv).toBeUndefined(); }); }); + + it('throws error when opencv has not finished loading', async () => { + opencvManager.isOpenCVLoaded = false; + const mockCallback = jest.fn().mockResolvedValue(undefined); + opencvManager.onLoad(mockCallback); + + await waitFor(() => { + void expect(mockCallback).toHaveBeenCalledWith(expect.any(Error)); + }); + }); });