mirror of
https://github.com/arthurfiorette/axios-cache-interceptor.git
synced 2025-12-08 17:36:16 +00:00
* feat(WIP): etag and if-modified-since support * test: fixed test name * fix: merge response headers * test: add etag / last-modified tests * test: add must-revalidate tests * fix: handle expirationTime 0 as true. * tests: refactored some tests * test: added keepIfStale tests * fix: remove axios error for 304 requests * fix: possible infinite loop on validateStatus function * tests: ignore code that is hard test from coverage * fix: use Last-Modified header for modifiedSince If-Modified-Since is never sent by a server, it's a client only header. However Last-Modified is sent by the server to indicate the last time the returned version was modified (it might not be the last version depending on cache configuration on intermediate servers) * test: use validateStatus in mock This more closely match default axios adapter. * fix: validateStatus handling all cases * refactor: use cache.createdAt if the last-modified header isn't present * test: etag with predefined value * test: added more test cases * fix: fixed logic in some tests * docs: initial documentation * fix: manual values work out of the box This removes header requirement from server. * docs: add details to etag and modifiedSince features * fix: delete custom headers from response * feat: accept all configurations from global axios Merging global into local configuration enable user to use global configuration for all options and remove the need to check local and global values every time. * fix: preserve original types from AxiosInstance The only value axios needs is a URL, and in the second definition of the method, there is already a URL parameter, so it can be undefined. * Fix: defaults modifiedSince back to false. Avoids breaking changes. * docs: fix etag examples * docs: document internal headers * refactor: ternary operator :) * style: prettified code * test: remove modifiedSince: false in tests since this is the default * docs: fix headers examples * docs: fixed example formatting * tests: split tests into multiple files to test them faster * docs: correct jsdoc empty object Co-authored-by: Charly Koza <cka@f4-group.com>
89 lines
2.3 KiB
TypeScript
89 lines
2.3 KiB
TypeScript
import type { AxiosCacheInstance, CachedStorageValue } from '../../src';
|
|
import { updateCache } from '../../src/util/update-cache';
|
|
import { mockAxios } from '../mocks/axios';
|
|
import { EMPTY_RESPONSE } from '../utils';
|
|
|
|
const KEY = 'cacheKey';
|
|
const EMPTY_STATE = { state: 'empty' };
|
|
const DEFAULT_DATA = 'random-data';
|
|
const INITIAL_DATA: CachedStorageValue = {
|
|
data: {
|
|
...EMPTY_RESPONSE,
|
|
data: true
|
|
},
|
|
createdAt: Date.now(),
|
|
ttl: Infinity,
|
|
state: 'cached'
|
|
};
|
|
|
|
describe('Tests update-cache', () => {
|
|
let axios: AxiosCacheInstance;
|
|
|
|
beforeEach(() => {
|
|
axios = mockAxios({});
|
|
axios.storage.set(KEY, INITIAL_DATA);
|
|
});
|
|
|
|
it('tests for delete key', async () => {
|
|
await updateCache(axios.storage, DEFAULT_DATA, {
|
|
[KEY]: 'delete'
|
|
});
|
|
|
|
const response = await axios.storage.get(KEY);
|
|
|
|
expect(response).not.toBeFalsy();
|
|
expect(response).toStrictEqual(EMPTY_STATE);
|
|
});
|
|
|
|
it('tests for returning undefined', async () => {
|
|
await updateCache(axios.storage, DEFAULT_DATA, {
|
|
[KEY]: () => undefined
|
|
});
|
|
|
|
const response = await axios.storage.get(KEY);
|
|
|
|
expect(response).not.toBeFalsy();
|
|
expect(response).toStrictEqual(EMPTY_STATE);
|
|
});
|
|
|
|
it('tests for returning an new value', async () => {
|
|
await updateCache(axios.storage, DEFAULT_DATA, {
|
|
[KEY]: (cached, newData) => ({
|
|
state: 'cached',
|
|
ttl: Infinity,
|
|
createdAt: Date.now(),
|
|
data: {
|
|
...EMPTY_RESPONSE,
|
|
data: `${cached.data?.data}:${newData}`
|
|
}
|
|
})
|
|
});
|
|
|
|
const response = await axios.storage.get(KEY);
|
|
|
|
expect(response).not.toBeFalsy();
|
|
expect(response).not.toStrictEqual(EMPTY_STATE);
|
|
|
|
expect(response.state).toBe('cached');
|
|
expect(response.data?.data).toBe(`${INITIAL_DATA.data?.data}:${DEFAULT_DATA}`);
|
|
});
|
|
|
|
it('check if the state is loading while updating', async () => {
|
|
axios.storage.set(KEY, { state: 'loading' });
|
|
|
|
const result = updateCache(axios.storage, DEFAULT_DATA, {
|
|
[KEY]: (cached, newData) => ({
|
|
state: 'cached',
|
|
ttl: Infinity,
|
|
createdAt: Date.now(),
|
|
data: {
|
|
...EMPTY_RESPONSE,
|
|
data: `${cached.data?.data}:${newData}`
|
|
}
|
|
})
|
|
});
|
|
|
|
expect(result).rejects.toThrowError();
|
|
});
|
|
});
|