@carbonorm/carbonnode 6.0.17 → 6.0.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs.js +42 -6
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.esm.js +42 -7
- package/dist/index.esm.js.map +1 -1
- package/dist/types/ormInterfaces.d.ts +1 -0
- package/dist/utils/cacheManager.d.ts +1 -0
- package/package.json +2 -2
- package/src/__tests__/httpExecutor.cacheEviction.test.ts +70 -0
- package/src/__tests__/sakila-db/C6.js +1 -1
- package/src/__tests__/sakila-db/C6.mysqldump.json +1 -1
- package/src/__tests__/sakila-db/C6.mysqldump.sql +1 -1
- package/src/__tests__/sakila-db/C6.ts +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.actor.post.json +3 -3
- package/src/__tests__/sakila-db/sqlResponses/C6.actor.post.latest.json +3 -3
- package/src/__tests__/sakila-db/sqlResponses/C6.actor.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.actor.put.lookup.json +3 -3
- package/src/__tests__/sakila-db/sqlResponses/C6.address.post.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.address.post.latest.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.address.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.address.put.lookup.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.category.post.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.category.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.category.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.category.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.city.post.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.city.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.city.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.city.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.country.post.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.country.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.country.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.country.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.customer.post.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.customer.post.latest.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.customer.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.customer.put.lookup.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.film.post.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.film.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.film.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.film.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.inventory.post.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.inventory.post.latest.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.inventory.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.inventory.put.lookup.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.language.post.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.language.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.language.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.language.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.payment.post.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.payment.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.payment.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.join.json +10 -10
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.post.json +3 -3
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.post.latest.json +3 -3
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.put.lookup.json +3 -3
- package/src/__tests__/sqlExecutor.cacheEviction.test.ts +79 -0
- package/src/executors/HttpExecutor.ts +19 -3
- package/src/executors/SqlExecutor.ts +23 -5
- package/src/types/ormInterfaces.ts +4 -1
- package/src/utils/cacheManager.ts +9 -0
|
@@ -125,6 +125,7 @@ export type C6RestResponse<Method extends iRestMethods, RestData extends {
|
|
|
125
125
|
sql?: any;
|
|
126
126
|
} & (Method extends 'GET' ? {
|
|
127
127
|
next?: () => Promise<DetermineResponseDataType<'GET', RestData, Overrides>>;
|
|
128
|
+
evictFromCache?: () => boolean;
|
|
128
129
|
} : {
|
|
129
130
|
affected: number;
|
|
130
131
|
insertId?: number | string;
|
|
@@ -7,3 +7,4 @@ export declare function clearCache(props?: {
|
|
|
7
7
|
}): void;
|
|
8
8
|
export declare function checkCache<ResponseDataType = any>(method: string, tableName: string | string[], requestData: any, logContext: LogContext): Promise<iCacheResponse<ResponseDataType>> | false;
|
|
9
9
|
export declare function setCache<ResponseDataType = any>(method: string, tableName: string | string[], requestData: any, cacheEntry: iCacheAPI<ResponseDataType>): void;
|
|
10
|
+
export declare function evictCacheEntry(method: string, tableName: string | string[], requestData: any): boolean;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@carbonorm/carbonnode",
|
|
3
|
-
"version": "6.0.
|
|
3
|
+
"version": "6.0.18",
|
|
4
4
|
"browser": "dist/index.umd.js",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -25,7 +25,7 @@
|
|
|
25
25
|
"geojson": "^0.5.0",
|
|
26
26
|
"handlebars": "^4.7.8",
|
|
27
27
|
"named-placeholders": "^1.1.3",
|
|
28
|
-
"qs": "
|
|
28
|
+
"qs": "6.14.1",
|
|
29
29
|
"tslib": "^2.8.1"
|
|
30
30
|
},
|
|
31
31
|
"peerDependencies": {
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { beforeEach, describe, expect, it, vi } from "vitest";
|
|
2
|
+
import { C6C, restOrm, apiRequestCache, clearCache } from "@carbonorm/carbonnode";
|
|
3
|
+
import { buildTestConfig } from "./fixtures/c6.fixture";
|
|
4
|
+
|
|
5
|
+
describe("HttpExecutor cache eviction", () => {
|
|
6
|
+
const makeResponsePayload = () => ({
|
|
7
|
+
rest: [
|
|
8
|
+
{
|
|
9
|
+
actor_id: 1,
|
|
10
|
+
first_name: "ALICE",
|
|
11
|
+
last_name: "ONE",
|
|
12
|
+
},
|
|
13
|
+
],
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
const buildOrm = (get: ReturnType<typeof vi.fn>) => {
|
|
17
|
+
const baseConfig = buildTestConfig() as any;
|
|
18
|
+
|
|
19
|
+
return restOrm<any>(() => ({
|
|
20
|
+
...baseConfig,
|
|
21
|
+
requestMethod: C6C.GET,
|
|
22
|
+
restURL: "http://127.0.0.1:9999/rest/",
|
|
23
|
+
axios: { get },
|
|
24
|
+
verbose: false,
|
|
25
|
+
}));
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
beforeEach(() => {
|
|
29
|
+
clearCache({ ignoreWarning: true });
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
it("adds evictFromCache for cached GET responses", async () => {
|
|
33
|
+
const get = vi.fn().mockResolvedValue({ data: makeResponsePayload() });
|
|
34
|
+
const actorHttp = buildOrm(get);
|
|
35
|
+
|
|
36
|
+
const response = await actorHttp.Get({ actor_id: 1, cacheResults: true } as any);
|
|
37
|
+
|
|
38
|
+
expect(get).toHaveBeenCalledTimes(1);
|
|
39
|
+
expect(typeof response.evictFromCache).toBe("function");
|
|
40
|
+
expect(apiRequestCache.size).toBe(1);
|
|
41
|
+
|
|
42
|
+
expect(response.evictFromCache?.()).toBe(true);
|
|
43
|
+
expect(apiRequestCache.size).toBe(0);
|
|
44
|
+
expect(response.evictFromCache?.()).toBe(false);
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
it("does not add evictFromCache when cacheResults is false", async () => {
|
|
48
|
+
const get = vi.fn().mockResolvedValue({ data: makeResponsePayload() });
|
|
49
|
+
const actorHttp = buildOrm(get);
|
|
50
|
+
|
|
51
|
+
const response = await actorHttp.Get({ actor_id: 1, cacheResults: false } as any);
|
|
52
|
+
|
|
53
|
+
expect(get).toHaveBeenCalledTimes(1);
|
|
54
|
+
expect(response.evictFromCache).toBeUndefined();
|
|
55
|
+
expect(apiRequestCache.size).toBe(0);
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
it("keeps evictFromCache on cache hits", async () => {
|
|
59
|
+
const get = vi.fn().mockResolvedValue({ data: makeResponsePayload() });
|
|
60
|
+
const actorHttp = buildOrm(get);
|
|
61
|
+
|
|
62
|
+
await actorHttp.Get({ actor_id: 1, cacheResults: true } as any);
|
|
63
|
+
const cached = await actorHttp.Get({ actor_id: 1, cacheResults: true } as any);
|
|
64
|
+
|
|
65
|
+
expect(get).toHaveBeenCalledTimes(1);
|
|
66
|
+
expect(typeof cached.evictFromCache).toBe("function");
|
|
67
|
+
expect(cached.evictFromCache?.()).toBe(true);
|
|
68
|
+
expect(apiRequestCache.size).toBe(0);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
@@ -1342,7 +1342,7 @@ export const TABLES = {
|
|
|
1342
1342
|
};
|
|
1343
1343
|
export const C6 = {
|
|
1344
1344
|
...C6Constants,
|
|
1345
|
-
C6VERSION: '6.0.
|
|
1345
|
+
C6VERSION: '6.0.18',
|
|
1346
1346
|
IMPORT: async (tableName) => {
|
|
1347
1347
|
tableName = tableName.toLowerCase();
|
|
1348
1348
|
// if tableName is not a key in the TABLES object then throw an error
|