kiwix-js/tests/unit/js/init.js
Anuj Kumar Sharma b3c404451b
Converted Q Unit tests to Mocha Tests (#1301)
* Added Files

* Fixed the init file

Signed-off-by: THEBOSS0369 <anujkumsharma9876@gmail.com>

* Trying again

* Adding coverage folders in gitignore

* Fixed fallback errors & some grammatical checks

Signed-off-by: THEBOSS0369 <anujkumsharma9876@gmail.com>

* Added unit test coverage

Signed-off-by: THEBOSS0369 <anujkumsharma9876@gmail.com>

* Revert "Added unit test coverage"

This reverts commit 444e215d79665da1cb8631b9268bdea1f8e701d8.

* Fixing merge conflicts

Signed-off-by: THEBOSS0369 <anujkumsharma9876@gmail.com>

* Integrate tests into workflows

Signed-off-by: THEBOSS0369 <anujkumsharma9876@gmail.com>

* removing unit-watch

Signed-off-by: THEBOSS0369 <anujkumsharma9876@gmail.com>

---------

Signed-off-by: THEBOSS0369 <anujkumsharma9876@gmail.com>
2025-03-17 18:27:36 +05:30

92 lines
3.1 KiB
JavaScript

/* eslint-disable no-useless-constructor */
/**
* init.js : Global configuration of the app
* This file handles the dependencies between javascript libraries, for the unit tests
*
* Copyright 2013-2014 Mossroy and contributors
* Licence GPL v3:
*
* This file is part of Kiwix.
*
* Kiwix is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public Licence as published by
* the Free Software Foundation, either version 3 of the Licence, or
* (at your option) any later version.
*
* Kiwix is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public Licence for more details.
*
* You should have received a copy of the GNU General Public Licence
* along with Kiwix (file LICENSE-GPLv3.txt). If not, see <http://www.gnu.org/licenses/>
*/
'use strict';
/* global webpHero */
// Define global params needed for tests to run on existing app code
// eslint-disable-next-line no-unused-vars
var params = {};
// We need to turn off source verification so that the test files can be loaded normally without interruption
params['sourceVerification'] = false;
// Test if WebP is natively supported, and if not, load a webpMachine instance. This is used in uiUtils.js.
// eslint-disable-next-line no-unused-vars
var webpMachine = false;
// Create a mock Image class for Node.js environment
if (typeof window === 'undefined') {
// We're in Node.js
global.Image = class Image {
constructor () {
this.height = 0;
setTimeout(() => {
// Simulate successful WebP support
this.height = 2;
if (typeof this.onload === 'function') {
this.onload();
}
}, 0);
}
};
global.document = {
head: {
appendChild: function () {} // Mock appendChild
},
createElement: function () {
return {
onload: null,
src: ''
};
}
};
global.webpHero = {
WebpMachine: class WebpMachine {
constructor () {}
}
};
}
// We use a self-invoking function here to avoid defining unnecessary global functions and variables
(function (callback) {
// Tests for native WebP support
var webP = new Image();
webP.onload = webP.onerror = function () {
callback(webP.height === 2);
};
webP.src = '';
})(function (support) {
if (!support) {
// Note we set the location of this to be the directory where scripts reside **after bundling**
var webpScript = document.createElement('script');
webpScript.onload = function () {
webpMachine = new webpHero.WebpMachine({ useCanvasElements: true });
}
webpScript.src = '../../www/js/lib/webpHeroBundle_0.0.2.js';
document.head.appendChild(webpScript);
}
});