mirror of
https://github.com/openfrontio/OpenFrontIO.git
synced 2026-06-21 17:46:46 +00:00
26f5d40819
- Replace Webpack with Vite for faster client bundling and HMR. - Migrate tests from Jest to Vitest and update configuration. - Update Web Worker instantiation to standard ESM syntax. - Implement Env utility in `src/core` for safe, hybrid environment variable access (Vite vs Node). - Refactor configuration loaders to remove direct `process.env` dependencies in shared code. - Update TypeScript environment definitions and project scripts for the new toolchain. - Remove the [depracated usage of the husky](https://github.com/typicode/husky/releases/tag/v9.0.1). ## Description: migrate build system to Vite and test runner to Vitest & Remove depracated husky usage ## Please complete the following: - [X] I have added screenshots for all UI updates - [X] I process any text displayed to the user through translateText() and I've added it to the en.json file - [ ] I have added relevant tests to the test directory - [X] I confirm I have thoroughly tested these changes and take full responsibility for any bugs introduced ## Please put your Discord username so you can be contacted if a bug or regression is found: wraith4081 --------- Co-authored-by: evanpelle <evanpelle@gmail.com>
159 lines
4.6 KiB
TypeScript
159 lines
4.6 KiB
TypeScript
import { UILayer } from "../../../src/client/graphics/layers/UILayer";
|
|
import { UnitSelectionEvent } from "../../../src/client/InputHandler";
|
|
import { UnitView } from "../../../src/core/game/GameView";
|
|
|
|
describe("UILayer", () => {
|
|
let game: any;
|
|
let eventBus: any;
|
|
let transformHandler: any;
|
|
|
|
beforeEach(() => {
|
|
game = {
|
|
width: () => 100,
|
|
height: () => 100,
|
|
config: () => ({
|
|
theme: () => ({
|
|
territoryColor: () => ({
|
|
lighten: () => ({ alpha: () => ({ toRgbString: () => "#fff" }) }),
|
|
}),
|
|
}),
|
|
}),
|
|
x: () => 10,
|
|
y: () => 10,
|
|
unitInfo: () => ({ maxHealth: 10, constructionDuration: 5 }),
|
|
myPlayer: () => ({ id: () => 1 }),
|
|
ticks: () => 1,
|
|
updatesSinceLastTick: () => undefined,
|
|
};
|
|
eventBus = { on: vi.fn() };
|
|
transformHandler = {};
|
|
});
|
|
|
|
it("should initialize and redraw canvas", () => {
|
|
const ui = new UILayer(game, eventBus, transformHandler);
|
|
ui.redraw();
|
|
expect(ui["canvas"].width).toBe(100);
|
|
expect(ui["canvas"].height).toBe(100);
|
|
expect(ui["context"]).not.toBeNull();
|
|
});
|
|
|
|
it("should handle unit selection event", () => {
|
|
const ui = new UILayer(game, eventBus, transformHandler);
|
|
ui.redraw();
|
|
const unit = {
|
|
type: () => "Warship",
|
|
isActive: () => true,
|
|
tile: () => ({}),
|
|
owner: () => ({}),
|
|
};
|
|
const event = { isSelected: true, unit };
|
|
ui.drawSelectionBox = vi.fn();
|
|
ui["onUnitSelection"](event as UnitSelectionEvent);
|
|
expect(ui.drawSelectionBox).toHaveBeenCalledWith(unit);
|
|
});
|
|
|
|
it("should add and clear health bars", () => {
|
|
const ui = new UILayer(game, eventBus, transformHandler);
|
|
ui.redraw();
|
|
const unit = {
|
|
id: () => 1,
|
|
type: () => "Warship",
|
|
health: () => 5,
|
|
tile: () => ({}),
|
|
owner: () => ({}),
|
|
isActive: () => true,
|
|
createdAt: () => 1,
|
|
} as unknown as UnitView;
|
|
ui.drawHealthBar(unit);
|
|
expect(ui["allHealthBars"].has(1)).toBe(true);
|
|
|
|
// a full hp unit doesn't have a health bar
|
|
unit.health = () => 10;
|
|
ui.drawHealthBar(unit);
|
|
expect(ui["allHealthBars"].has(1)).toBe(false);
|
|
|
|
// a dead unit doesn't have a health bar
|
|
unit.health = () => 5;
|
|
ui.drawHealthBar(unit);
|
|
expect(ui["allHealthBars"].has(1)).toBe(true);
|
|
unit.health = () => 0;
|
|
ui.drawHealthBar(unit);
|
|
expect(ui["allHealthBars"].has(1)).toBe(false);
|
|
});
|
|
|
|
it("should remove health bars for inactive units", () => {
|
|
const ui = new UILayer(game, eventBus, transformHandler);
|
|
ui.redraw();
|
|
const unit = {
|
|
id: () => 1,
|
|
type: () => "Warship",
|
|
health: () => 5,
|
|
tile: () => ({}),
|
|
owner: () => ({}),
|
|
isActive: () => true,
|
|
} as unknown as UnitView;
|
|
ui.drawHealthBar(unit);
|
|
expect(ui["allHealthBars"].has(1)).toBe(true);
|
|
|
|
// an inactive unit doesn't have a health bar
|
|
unit.isActive = () => false;
|
|
ui.drawHealthBar(unit);
|
|
expect(ui["allHealthBars"].has(1)).toBe(false);
|
|
});
|
|
|
|
it("should add loading bar for unit", () => {
|
|
const ui = new UILayer(game, eventBus, transformHandler);
|
|
ui.redraw();
|
|
const unit = {
|
|
id: () => 2,
|
|
tile: () => ({}),
|
|
isActive: () => true,
|
|
} as unknown as UnitView;
|
|
ui.createLoadingBar(unit);
|
|
expect(ui["allProgressBars"].has(2)).toBe(true);
|
|
});
|
|
|
|
it("should remove loading bar for inactive unit", () => {
|
|
const ui = new UILayer(game, eventBus, transformHandler);
|
|
ui.redraw();
|
|
const unit = {
|
|
id: () => 2,
|
|
type: () => "City",
|
|
isUnderConstruction: () => true,
|
|
owner: () => ({ id: () => 1 }),
|
|
tile: () => ({}),
|
|
isActive: () => true,
|
|
} as unknown as UnitView;
|
|
ui.onUnitEvent(unit);
|
|
expect(ui["allProgressBars"].has(2)).toBe(true);
|
|
|
|
// an inactive unit should not have a loading bar
|
|
unit.isActive = () => false;
|
|
ui.tick();
|
|
expect(ui["allProgressBars"].has(2)).toBe(false);
|
|
});
|
|
|
|
it("should remove loading bar for a finished progress bar", () => {
|
|
const ui = new UILayer(game, eventBus, transformHandler);
|
|
ui.redraw();
|
|
const unit = {
|
|
id: () => 2,
|
|
type: () => "City",
|
|
isUnderConstruction: () => true,
|
|
owner: () => ({ id: () => 1 }),
|
|
tile: () => ({}),
|
|
isActive: () => true,
|
|
createdAt: () => 1,
|
|
markedForDeletion: () => false,
|
|
} as unknown as UnitView;
|
|
ui.onUnitEvent(unit);
|
|
expect(ui["allProgressBars"].has(2)).toBe(true);
|
|
|
|
game.ticks = () => 6; // simulate enough ticks for completion
|
|
// simulate construction finished
|
|
(unit as any).isUnderConstruction = () => false;
|
|
ui.tick();
|
|
expect(ui["allProgressBars"].has(2)).toBe(false);
|
|
});
|
|
});
|