Files
privacy.sexy/tests/unit/application/Common/ScriptingLanguage/ScriptingLanguageFactoryTestRunner.ts
undergroundwires 949fac1a7c Refactor to enforce strictNullChecks
This commit applies `strictNullChecks` to the entire codebase to improve
maintainability and type safety. Key changes include:

- Remove some explicit null-checks where unnecessary.
- Add necessary null-checks.
- Refactor static factory functions for a more functional approach.
- Improve some test names and contexts for better debugging.
- Add unit tests for any additional logic introduced.
- Refactor `createPositionFromRegexFullMatch` to its own function as the
  logic is reused.
- Prefer `find` prefix on functions that may return `undefined` and
  `get` prefix for those that always return a value.
2023-11-12 22:54:00 +01:00

88 lines
2.7 KiB
TypeScript

import { describe, it, expect } from 'vitest';
import { IScriptingLanguageFactory } from '@/application/Common/ScriptingLanguage/IScriptingLanguageFactory';
import { ScriptingLanguage } from '@/domain/ScriptingLanguage';
import { EnumRangeTestRunner } from '@tests/unit/application/Common/EnumRangeTestRunner';
type Constructible<T = object> = new (...args: unknown[]) => T;
export class ScriptingLanguageFactoryTestRunner<T> {
private expectedLanguageTypes = new Map<ScriptingLanguage, Constructible<T>>();
private expectedValues = new Map<ScriptingLanguage, T>();
public expectInstance(language: ScriptingLanguage, resultType: Constructible<T>) {
this.expectedLanguageTypes.set(language, resultType);
return this;
}
public expectValue(language: ScriptingLanguage, resultType: T) {
this.expectedValues.set(language, resultType);
return this;
}
public testCreateMethod(sut: IScriptingLanguageFactory<T>) {
testLanguageValidation(sut);
if (this.expectedLanguageTypes.size) {
testExpectedInstanceTypes(sut, this.expectedLanguageTypes);
}
if (this.expectedValues.size) {
testExpectedValues(sut, this.expectedValues);
}
}
}
function testExpectedInstanceTypes<T>(
sut: IScriptingLanguageFactory<T>,
expectedTypes: Map<ScriptingLanguage, Constructible<T>>,
) {
if (!expectedTypes.size) {
throw new Error('No expected types provided.');
}
describe('`create` creates expected instances', () => {
// arrange
for (const language of expectedTypes.keys()) {
it(ScriptingLanguage[language], () => {
// act
const expected = expectedTypes.get(language);
const result = sut.create(language);
// assert
expect(result).to.be.instanceOf(expected, `Actual was: ${result}`);
});
}
});
}
function testExpectedValues<T>(
sut: IScriptingLanguageFactory<T>,
expectedValues: Map<ScriptingLanguage, T>,
) {
if (!expectedValues.size) {
throw new Error('No expected values provided.');
}
describe('`create` creates expected values', () => {
// arrange
for (const language of expectedValues.keys()) {
it(ScriptingLanguage[language], () => {
// act
const expected = expectedValues.get(language);
const result = sut.create(language);
// assert
expect(result).to.equal(expected);
});
}
});
}
function testLanguageValidation<T>(sut: IScriptingLanguageFactory<T>) {
describe('`create` validates language selection', () => {
// arrange
const validValue = ScriptingLanguage.batchfile;
// act
const act = (value: ScriptingLanguage) => sut.create(value);
// assert
new EnumRangeTestRunner(act)
.testOutOfRangeThrows()
.testValidValueDoesNotThrow(validValue);
});
}