refactor: test

This commit is contained in:
手瓜一十雪 2024-06-18 23:23:19 +08:00
parent d9315bf309
commit 7519825303
2 changed files with 50 additions and 33 deletions

View File

@ -62,41 +62,58 @@ export function simpleDecorator(target: any, context: any) {
// return CacheClassFuncDecoratorInternal;
// }
// }
export function CacheClassFuncAsync(ttl: number = 3600 * 1000, customKey: string = ''): any {
const cache = new Map<string, { expiry: number; value: any }>();
// 注意在JavaScript装饰器中我们通常不直接处理ClassMethodDecoratorContext这样的类型
// 因为装饰器的参数通常是目标类(对于类装饰器)、属性名(对于属性装饰器)等。
// 对于方法装饰器,我们关注的是方法本身及其描述符。
// 但这里我们维持原逻辑,假设有一个自定义的处理上下文的方式。
return function (originalMethod: Function): any {
// 由于JavaScript装饰器原生不支持异步直接定义我们保持async定义以便处理异步方法。
async function decoratorWrapper(this: any, ...args: any[]): Promise<any> {
const key = `${customKey}${originalMethod.name}.(${args.map(arg => JSON.stringify(arg)).join(', ')})`;
const cachedValue = cache.get(key);
// 遍历cache 清除expiry内容
cache.forEach((value, key) => {
if (value.expiry < Date.now()) {
cache.delete(key);
}
});
if (cachedValue && cachedValue.expiry > Date.now()) {
return cachedValue.value;
}
// 直接await异步方法的结果
const result = await originalMethod.apply(this, args);
cache.set(key, { expiry: Date.now() + ttl, value: result });
export function CacheClassFuncAsync(ttl: number = 3600 * 1000, customKey: string = '') {
console.log('CacheClassFuncAsync', ttl, customKey);
function logExecutionTime(target: any, methodName: string, descriptor: PropertyDescriptor) {
console.log('logExecutionTime', target, methodName, descriptor);
const originalMethod = descriptor.value;
descriptor.value = function (...args: any[]) {
const start = Date.now();
const result = originalMethod.apply(this, args);
const end = Date.now();
console.log(`Method ${methodName} executed in ${end - start} ms.`);
return result;
}
// 返回装饰后的方法保持与原方法相同的名称和描述符如果需要更精细的控制可以考虑使用Object.getOwnPropertyDescriptor等
return decoratorWrapper;
};
};
}
return logExecutionTime;
}
// export function CacheClassFuncAsync(ttl: number = 3600 * 1000, customKey: string = ''): any {
// const cache = new Map<string, { expiry: number; value: any }>();
// // 注意在JavaScript装饰器中我们通常不直接处理ClassMethodDecoratorContext这样的类型
// // 因为装饰器的参数通常是目标类(对于类装饰器)、属性名(对于属性装饰器)等。
// // 对于方法装饰器,我们关注的是方法本身及其描述符。
// // 但这里我们维持原逻辑,假设有一个自定义的处理上下文的方式。
// return function (originalMethod: Function): any {
// console.log(originalMethod);
// // 由于JavaScript装饰器原生不支持异步直接定义我们保持async定义以便处理异步方法。
// async function decoratorWrapper(this: any, ...args: any[]): Promise<any> {
// console.log(...args);
// const key = `${customKey}${originalMethod.name}.(${args.map(arg => JSON.stringify(arg)).join(', ')})`;
// const cachedValue = cache.get(key);
// // 遍历cache 清除expiry内容
// cache.forEach((value, key) => {
// if (value.expiry < Date.now()) {
// cache.delete(key);
// }
// });
// if (cachedValue && cachedValue.expiry > Date.now()) {
// return cachedValue.value;
// }
// // 直接await异步方法的结果
// const result = await originalMethod.apply(this, args);
// cache.set(key, { expiry: Date.now() + ttl, value: result });
// return result;
// }
// // 返回装饰后的方法保持与原方法相同的名称和描述符如果需要更精细的控制可以考虑使用Object.getOwnPropertyDescriptor等
// return decoratorWrapper;
// };
// }
/**
* key生成缓存键
* @param ttl

View File

@ -40,7 +40,7 @@ if (process.env.NAPCAT_BUILDSYS == 'linux') {
const baseConfigPlugin: PluginOption[] = [
// PreprocessorDirectives(),
babel({
filter: /.*\.(ts)$/,
filter: /.*\.(ts|js)$/,
babelConfig: {
babelrc: false,
configFile: false,