UNPKG

devextreme

Version:

JavaScript/TypeScript Component Suite for Responsive Web Development

259 lines (258 loc) • 9.05 kB
/** * DevExtreme (cjs/__internal/core/di/index.test.js) * Version: 25.2.5 * Build date: Fri Feb 20 2026 * * Copyright (c) 2012 - 2026 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; var _globals = require("@jest/globals"); var _index = require("./index"); (0, _globals.describe)("basic", (() => { (0, _globals.describe)("register", (() => { class MyClass { getNumber() { return 1 } } MyClass.dependencies = []; (0, _globals.it)("should return registered class", (() => { const ctx = new _index.DIContext; ctx.register(MyClass); (0, _globals.expect)(ctx.get(MyClass)).toBeInstanceOf(MyClass); (0, _globals.expect)(ctx.get(MyClass).getNumber()).toBe(1) })); (0, _globals.it)("should return registered class with tryGet", (() => { var _ctx$tryGet; const ctx = new _index.DIContext; ctx.register(MyClass); (0, _globals.expect)(ctx.tryGet(MyClass)).toBeInstanceOf(MyClass); (0, _globals.expect)(null === (_ctx$tryGet = ctx.tryGet(MyClass)) || void 0 === _ctx$tryGet ? void 0 : _ctx$tryGet.getNumber()).toBe(1) })); (0, _globals.it)("should return same instance each time", (() => { const ctx = new _index.DIContext; ctx.register(MyClass); (0, _globals.expect)(ctx.get(MyClass)).toBe(ctx.get(MyClass)) })) })); (0, _globals.describe)("registerInstance", (() => { class MyClass { getNumber() { return 1 } } MyClass.dependencies = []; const ctx = new _index.DIContext; const instance = new MyClass; ctx.registerInstance(MyClass, instance); (0, _globals.it)("should work", (() => { (0, _globals.expect)(ctx.get(MyClass)).toBe(instance) })) })); (0, _globals.describe)("non registered items", (() => { const ctx = new _index.DIContext; class MyClass { getNumber() { return 1 } } MyClass.dependencies = []; (0, _globals.it)("should throw", (() => { (0, _globals.expect)((() => ctx.get(MyClass))).toThrow() })); (0, _globals.it)("should not throw if tryGet", (() => { (0, _globals.expect)(ctx.tryGet(MyClass)).toBe(null) })) })) })); (0, _globals.describe)("dependencies", (() => { class MyUtilityClass { getNumber() { return 2 } } MyUtilityClass.dependencies = []; class MyClass { constructor(utility) { this.utility = utility } getSuperNumber() { return 2 * this.utility.getNumber() } } MyClass.dependencies = [MyUtilityClass]; const ctx = new _index.DIContext; ctx.register(MyUtilityClass); ctx.register(MyClass); (0, _globals.it)("should return registered class", (() => { (0, _globals.expect)(ctx.get(MyClass)).toBeInstanceOf(MyClass); (0, _globals.expect)(ctx.get(MyUtilityClass)).toBeInstanceOf(MyUtilityClass) })); (0, _globals.it)("dependecies should work", (() => { (0, _globals.expect)(ctx.get(MyClass).getSuperNumber()).toBe(4) })) })); (0, _globals.describe)("mocks", (() => { class MyClass { getNumber() { return 1 } } MyClass.dependencies = []; class MyClassMock { getNumber() { return 2 } } MyClassMock.dependencies = []; const ctx = new _index.DIContext; ctx.register(MyClass, MyClassMock); (0, _globals.it)("should return mock class when they are registered", (() => { (0, _globals.expect)(ctx.get(MyClass)).toBeInstanceOf(MyClassMock); (0, _globals.expect)(ctx.get(MyClass).getNumber()).toBe(2) })) })); (0, _globals.it)("should work regardless of registration order", (() => { class MyClass { getNumber() { return 1 } } MyClass.dependencies = []; class MyDependentClass { constructor(myClass) { this.myClass = myClass } getSuperNumber() { return 2 * this.myClass.getNumber() } } MyDependentClass.dependencies = [MyClass]; const ctx = new _index.DIContext; ctx.register(MyDependentClass); ctx.register(MyClass); (0, _globals.expect)(ctx.get(MyDependentClass).getSuperNumber()).toBe(2) })); (0, _globals.describe)("dependency cycle", (() => { class MyClass1 { constructor(myClass2) { this.myClass2 = myClass2 } } MyClass1.dependencies = []; class MyClass2 { constructor(myClass1) { this.myClass1 = myClass1 } } MyClass2.dependencies = [MyClass1]; MyClass1.dependencies = [MyClass2]; const ctx = new _index.DIContext; ctx.register(MyClass1); ctx.register(MyClass2); (0, _globals.it)("should throw", (() => { (0, _globals.expect)((() => ctx.get(MyClass1))).toThrow(); (0, _globals.expect)((() => ctx.get(MyClass2))).toThrow() })) })); (0, _globals.describe)("decorators", (() => { class MyClass { constructor() { this.value = 1; this.tag = "" } } MyClass.dependencies = []; class AnotherClass { constructor() { this.counter = 0 } } AnotherClass.dependencies = []; (0, _globals.it)("should apply global decorators to created instances", (() => { const ctx = new _index.DIContext; ctx.register(MyClass); ctx.registerDecorator((instance => { if (instance instanceof MyClass) { instance.value = 2 } return instance })); (0, _globals.expect)(ctx.get(MyClass).value).toBe(2) })); (0, _globals.it)("should apply global decorators to registered instances", (() => { const ctx = new _index.DIContext; const instance = new MyClass; ctx.registerDecorator((obj => { if (obj instanceof MyClass) { obj.value = 3 } return obj })); ctx.registerInstance(MyClass, instance); (0, _globals.expect)(ctx.get(MyClass).value).toBe(3); (0, _globals.expect)(instance.value).toBe(3) })); (0, _globals.it)("should apply multiple global decorators in the correct order", (() => { const ctx = new _index.DIContext; ctx.register(MyClass); ctx.registerDecorator((instance => { if (instance instanceof MyClass) { instance.value += 1; instance.tag += "A" } return instance })); ctx.registerDecorator((instance => { if (instance instanceof MyClass) { instance.value += 2; instance.tag += "B" } return instance })); const result = ctx.get(MyClass); (0, _globals.expect)(result.value).toBe(4); (0, _globals.expect)(result.tag).toBe("AB") })); (0, _globals.it)("should apply global decorators to instances created from fabrics", (() => { const ctx = new _index.DIContext; class BaseClass { constructor() { this.value = 1 } } BaseClass.dependencies = []; class ExtendedClass extends BaseClass { constructor() { super(...arguments); this.extraValue = 10 } } ExtendedClass.dependencies = []; ctx.register(BaseClass, ExtendedClass); ctx.registerDecorator((instance => { if (instance instanceof ExtendedClass) { instance.extraValue = 20 } return instance })); const result = ctx.get(BaseClass); (0, _globals.expect)(result).toBeInstanceOf(ExtendedClass); (0, _globals.expect)(result.extraValue).toBe(20) })); (0, _globals.it)("should prevent adding decorators after instance creation", (() => { const ctx = new _index.DIContext; ctx.register(MyClass); ctx.register(AnotherClass); const myClassInstance = ctx.get(MyClass); (0, _globals.expect)((() => ctx.registerDecorator((obj => { if (obj instanceof MyClass) { obj.value = 42; obj.tag = "decorated" } })))).toThrowError(); (0, _globals.expect)(myClassInstance.value).toBe(1); (0, _globals.expect)(myClassInstance.tag).toBe("") })) }));