Files
privacy.sexy/tests/unit/shared/Stubs/CategoryParserStub.ts
undergroundwires ded55a66d6 Refactor executable IDs to use strings #262
This commit unifies executable ID structure across categories and
scripts, paving the way for more complex ID solutions for #262.
It also refactors related code to adapt to the changes.

Key changes:

- Change numeric IDs to string IDs for categories
- Use named types for string IDs to improve code clarity
- Add unit tests to verify ID uniqueness

Other supporting changes:

- Separate concerns in entities for data access and executables by using
  separate abstractions (`Identifiable` and `RepositoryEntity`)
- Simplify usage and construction of entities.
- Remove `BaseEntity` for simplicity.
- Move creation of categories/scripts to domain layer
- Refactor CategoryCollection for better validation logic isolation
- Rename some categories to keep the names (used as pseudo-IDs) unique
  on Windows.
2024-08-03 16:54:14 +02:00

35 lines
1.2 KiB
TypeScript

import type { CategoryParser } from '@/application/Parser/Executable/CategoryParser';
import type { CategoryData } from '@/application/collections/';
import type { Category } from '@/domain/Executables/Category/Category';
import type { CategoryCollectionSpecificUtilities } from '@/application/Parser/Executable/CategoryCollectionSpecificUtilities';
import { CategoryStub } from './CategoryStub';
export class CategoryParserStub {
private configuredParseResults = new Map<CategoryData, Category>();
private usedUtilities = new Array<CategoryCollectionSpecificUtilities>();
public get(): CategoryParser {
return (category, utilities) => {
const result = this.configuredParseResults.get(category);
this.usedUtilities.push(utilities);
if (result) {
return result;
}
return new CategoryStub(`[${CategoryParserStub.name}]-parsed-category`);
};
}
public withConfiguredParseResult(
givenCategory: CategoryData,
parsedCategory: Category,
): this {
this.configuredParseResults.set(givenCategory, parsedCategory);
return this;
}
public getUsedUtilities(): readonly CategoryCollectionSpecificUtilities[] {
return this.usedUtilities;
}
}