@grafana/faro-web-sdk 1.0.0-beta2 → 1.0.0-beta4
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/README.md +15 -8
- package/dist/bundle/faro-web-sdk.iife.js +1 -0
- package/dist/cjs/config/getWebInstrumentations.js.map +1 -1
- package/dist/cjs/config/index.js.map +1 -1
- package/dist/cjs/config/makeCoreConfig.js.map +1 -1
- package/dist/cjs/config/types.js.map +1 -1
- package/dist/cjs/consts.js.map +1 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/initialize.js.map +1 -1
- package/dist/cjs/instrumentations/console/index.js.map +1 -1
- package/dist/cjs/instrumentations/console/instrumentation.js.map +1 -1
- package/dist/cjs/instrumentations/console/types.js.map +1 -1
- package/dist/cjs/instrumentations/errors/const.js.map +1 -1
- package/dist/cjs/instrumentations/errors/getErrorDetails.js.map +1 -1
- package/dist/cjs/instrumentations/errors/getValueAndTypeFromMessage.js.map +1 -1
- package/dist/cjs/instrumentations/errors/index.js.map +1 -1
- package/dist/cjs/instrumentations/errors/instrumentation.js.map +1 -1
- package/dist/cjs/instrumentations/errors/registerOnerror.js.map +1 -1
- package/dist/cjs/instrumentations/errors/registerOnunhandledrejection.js.map +1 -1
- package/dist/cjs/instrumentations/errors/stackFrames/buildStackFrame.js.map +1 -1
- package/dist/cjs/instrumentations/errors/stackFrames/const.js.map +1 -1
- package/dist/cjs/instrumentations/errors/stackFrames/getDataFromSafariExtensions.js.map +1 -1
- package/dist/cjs/instrumentations/errors/stackFrames/getStackFramesFromError.js.map +1 -1
- package/dist/cjs/instrumentations/errors/stackFrames/index.js.map +1 -1
- package/dist/cjs/instrumentations/errors/stackFrames/parseStacktrace.js.map +1 -1
- package/dist/cjs/instrumentations/errors/types.js.map +1 -1
- package/dist/cjs/instrumentations/index.js.map +1 -1
- package/dist/cjs/instrumentations/session/index.js.map +1 -1
- package/dist/cjs/instrumentations/session/instrumentation.js.map +1 -1
- package/dist/cjs/instrumentations/webVitals/index.js.map +1 -1
- package/dist/cjs/instrumentations/webVitals/instrumentation.js.map +1 -1
- package/dist/cjs/metas/browser/index.js.map +1 -1
- package/dist/cjs/metas/browser/meta.js.map +1 -1
- package/dist/cjs/metas/const.js.map +1 -1
- package/dist/cjs/metas/index.js.map +1 -1
- package/dist/cjs/metas/page/index.js.map +1 -1
- package/dist/cjs/metas/page/meta.js.map +1 -1
- package/dist/cjs/session.js.map +1 -1
- package/dist/cjs/transports/console/index.js.map +1 -1
- package/dist/cjs/transports/console/transport.js.map +1 -1
- package/dist/cjs/transports/console/types.js.map +1 -1
- package/dist/cjs/transports/fetch/index.js.map +1 -1
- package/dist/cjs/transports/fetch/transport.js +1 -1
- package/dist/cjs/transports/fetch/transport.js.map +1 -1
- package/dist/cjs/transports/fetch/types.js.map +1 -1
- package/dist/cjs/transports/index.js.map +1 -1
- package/dist/esm/config/getWebInstrumentations.js.map +1 -1
- package/dist/esm/config/index.js.map +1 -1
- package/dist/esm/config/makeCoreConfig.js.map +1 -1
- package/dist/esm/config/types.js.map +1 -1
- package/dist/esm/consts.js.map +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/initialize.js.map +1 -1
- package/dist/esm/instrumentations/console/index.js.map +1 -1
- package/dist/esm/instrumentations/console/instrumentation.js.map +1 -1
- package/dist/esm/instrumentations/console/types.js.map +1 -1
- package/dist/esm/instrumentations/errors/const.js.map +1 -1
- package/dist/esm/instrumentations/errors/getErrorDetails.js.map +1 -1
- package/dist/esm/instrumentations/errors/getValueAndTypeFromMessage.js.map +1 -1
- package/dist/esm/instrumentations/errors/index.js.map +1 -1
- package/dist/esm/instrumentations/errors/instrumentation.js.map +1 -1
- package/dist/esm/instrumentations/errors/registerOnerror.js.map +1 -1
- package/dist/esm/instrumentations/errors/registerOnunhandledrejection.js.map +1 -1
- package/dist/esm/instrumentations/errors/stackFrames/buildStackFrame.js.map +1 -1
- package/dist/esm/instrumentations/errors/stackFrames/const.js.map +1 -1
- package/dist/esm/instrumentations/errors/stackFrames/getDataFromSafariExtensions.js.map +1 -1
- package/dist/esm/instrumentations/errors/stackFrames/getStackFramesFromError.js.map +1 -1
- package/dist/esm/instrumentations/errors/stackFrames/index.js.map +1 -1
- package/dist/esm/instrumentations/errors/stackFrames/parseStacktrace.js.map +1 -1
- package/dist/esm/instrumentations/errors/types.js.map +1 -1
- package/dist/esm/instrumentations/index.js.map +1 -1
- package/dist/esm/instrumentations/session/index.js.map +1 -1
- package/dist/esm/instrumentations/session/instrumentation.js.map +1 -1
- package/dist/esm/instrumentations/webVitals/index.js.map +1 -1
- package/dist/esm/instrumentations/webVitals/instrumentation.js.map +1 -1
- package/dist/esm/metas/browser/index.js.map +1 -1
- package/dist/esm/metas/browser/meta.js.map +1 -1
- package/dist/esm/metas/const.js.map +1 -1
- package/dist/esm/metas/index.js.map +1 -1
- package/dist/esm/metas/page/index.js.map +1 -1
- package/dist/esm/metas/page/meta.js.map +1 -1
- package/dist/esm/session.js.map +1 -1
- package/dist/esm/transports/console/index.js.map +1 -1
- package/dist/esm/transports/console/transport.js.map +1 -1
- package/dist/esm/transports/console/types.js.map +1 -1
- package/dist/esm/transports/fetch/index.js.map +1 -1
- package/dist/esm/transports/fetch/transport.js.map +1 -1
- package/dist/esm/transports/fetch/types.js.map +1 -1
- package/dist/esm/transports/index.js.map +1 -1
- package/dist/{cjs → types}/config/getWebInstrumentations.d.ts +0 -0
- package/dist/{cjs → types}/config/index.d.ts +0 -0
- package/dist/{cjs → types}/config/makeCoreConfig.d.ts +0 -0
- package/dist/{cjs → types}/config/types.d.ts +0 -0
- package/dist/{cjs → types}/consts.d.ts +0 -0
- package/dist/{cjs → types}/index.d.ts +1 -1
- package/dist/{cjs → types}/initialize.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/console/index.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/console/instrumentation.d.ts +1 -1
- package/dist/{cjs → types}/instrumentations/console/types.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/const.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/getErrorDetails.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/getValueAndTypeFromMessage.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/index.d.ts +0 -0
- package/dist/{esm → types}/instrumentations/errors/instrumentation.d.ts +1 -1
- package/dist/{cjs → types}/instrumentations/errors/registerOnerror.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/registerOnunhandledrejection.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/stackFrames/buildStackFrame.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/stackFrames/const.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/stackFrames/getDataFromSafariExtensions.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/stackFrames/getStackFramesFromError.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/stackFrames/index.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/errors/stackFrames/parseStacktrace.d.ts +0 -0
- package/dist/{esm → types}/instrumentations/errors/types.d.ts +1 -1
- package/dist/{cjs → types}/instrumentations/index.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/session/index.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/session/instrumentation.d.ts +0 -0
- package/dist/{cjs → types}/instrumentations/webVitals/index.d.ts +0 -0
- package/dist/{esm → types}/instrumentations/webVitals/instrumentation.d.ts +1 -1
- package/dist/{cjs → types}/metas/browser/index.d.ts +0 -0
- package/dist/{cjs → types}/metas/browser/meta.d.ts +0 -0
- package/dist/{cjs → types}/metas/const.d.ts +0 -0
- package/dist/{cjs → types}/metas/index.d.ts +0 -0
- package/dist/{cjs → types}/metas/page/index.d.ts +0 -0
- package/dist/{cjs → types}/metas/page/meta.d.ts +0 -0
- package/dist/{cjs → types}/session.d.ts +0 -0
- package/dist/{cjs → types}/transports/console/index.d.ts +0 -0
- package/dist/{esm → types}/transports/console/transport.d.ts +1 -1
- package/dist/{cjs → types}/transports/console/types.d.ts +0 -0
- package/dist/{cjs → types}/transports/fetch/index.d.ts +0 -0
- package/dist/{cjs → types}/transports/fetch/transport.d.ts +1 -1
- package/dist/{cjs → types}/transports/fetch/types.d.ts +1 -1
- package/dist/{cjs → types}/transports/index.d.ts +0 -0
- package/package.json +30 -13
- package/dist/cjs/instrumentations/errors/instrumentation.d.ts +0 -6
- package/dist/cjs/instrumentations/errors/registerOnerror.test.d.ts +0 -1
- package/dist/cjs/instrumentations/errors/registerOnerror.test.js +0 -23
- package/dist/cjs/instrumentations/errors/registerOnerror.test.js.map +0 -1
- package/dist/cjs/instrumentations/errors/types.d.ts +0 -8
- package/dist/cjs/instrumentations/session/instrumentation.test.d.ts +0 -1
- package/dist/cjs/instrumentations/session/instrumentation.test.js +0 -47
- package/dist/cjs/instrumentations/session/instrumentation.test.js.map +0 -1
- package/dist/cjs/instrumentations/webVitals/instrumentation.d.ts +0 -14
- package/dist/cjs/transports/console/transport.d.ts +0 -10
- package/dist/cjs/transports/fetch/transport.test.d.ts +0 -1
- package/dist/cjs/transports/fetch/transport.test.js +0 -193
- package/dist/cjs/transports/fetch/transport.test.js.map +0 -1
- package/dist/esm/config/getWebInstrumentations.d.ts +0 -3
- package/dist/esm/config/index.d.ts +0 -3
- package/dist/esm/config/makeCoreConfig.d.ts +0 -3
- package/dist/esm/config/types.d.ts +0 -9
- package/dist/esm/consts.d.ts +0 -1
- package/dist/esm/index.d.ts +0 -12
- package/dist/esm/initialize.d.ts +0 -3
- package/dist/esm/instrumentations/console/index.d.ts +0 -2
- package/dist/esm/instrumentations/console/instrumentation.d.ts +0 -10
- package/dist/esm/instrumentations/console/types.d.ts +0 -4
- package/dist/esm/instrumentations/errors/const.d.ts +0 -7
- package/dist/esm/instrumentations/errors/getErrorDetails.d.ts +0 -3
- package/dist/esm/instrumentations/errors/getValueAndTypeFromMessage.d.ts +0 -1
- package/dist/esm/instrumentations/errors/index.d.ts +0 -3
- package/dist/esm/instrumentations/errors/registerOnerror.d.ts +0 -2
- package/dist/esm/instrumentations/errors/registerOnerror.test.d.ts +0 -1
- package/dist/esm/instrumentations/errors/registerOnerror.test.js +0 -21
- package/dist/esm/instrumentations/errors/registerOnerror.test.js.map +0 -1
- package/dist/esm/instrumentations/errors/registerOnunhandledrejection.d.ts +0 -2
- package/dist/esm/instrumentations/errors/stackFrames/buildStackFrame.d.ts +0 -2
- package/dist/esm/instrumentations/errors/stackFrames/const.d.ts +0 -15
- package/dist/esm/instrumentations/errors/stackFrames/getDataFromSafariExtensions.d.ts +0 -1
- package/dist/esm/instrumentations/errors/stackFrames/getStackFramesFromError.d.ts +0 -2
- package/dist/esm/instrumentations/errors/stackFrames/index.d.ts +0 -4
- package/dist/esm/instrumentations/errors/stackFrames/parseStacktrace.d.ts +0 -2
- package/dist/esm/instrumentations/index.d.ts +0 -6
- package/dist/esm/instrumentations/session/index.d.ts +0 -1
- package/dist/esm/instrumentations/session/instrumentation.d.ts +0 -8
- package/dist/esm/instrumentations/session/instrumentation.test.d.ts +0 -1
- package/dist/esm/instrumentations/session/instrumentation.test.js +0 -45
- package/dist/esm/instrumentations/session/instrumentation.test.js.map +0 -1
- package/dist/esm/instrumentations/webVitals/index.d.ts +0 -1
- package/dist/esm/metas/browser/index.d.ts +0 -1
- package/dist/esm/metas/browser/meta.d.ts +0 -2
- package/dist/esm/metas/const.d.ts +0 -2
- package/dist/esm/metas/index.d.ts +0 -3
- package/dist/esm/metas/page/index.d.ts +0 -1
- package/dist/esm/metas/page/meta.d.ts +0 -2
- package/dist/esm/session.d.ts +0 -2
- package/dist/esm/transports/console/index.d.ts +0 -2
- package/dist/esm/transports/console/types.d.ts +0 -4
- package/dist/esm/transports/fetch/index.d.ts +0 -2
- package/dist/esm/transports/fetch/transport.d.ts +0 -16
- package/dist/esm/transports/fetch/transport.test.d.ts +0 -1
- package/dist/esm/transports/fetch/transport.test.js +0 -119
- package/dist/esm/transports/fetch/transport.test.js.map +0 -1
- package/dist/esm/transports/fetch/types.d.ts +0 -13
- package/dist/esm/transports/index.d.ts +0 -4
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { Conventions, initializeFaro } from '@grafana/faro-core';
|
|
2
|
-
import { mockConfig, MockTransport } from '@grafana/faro-core/src/testUtils';
|
|
3
|
-
import { createSession } from '../../session';
|
|
4
|
-
import { SessionInstrumentation } from './instrumentation';
|
|
5
|
-
describe('SessionInstrumentation', () => {
|
|
6
|
-
it('will send session start event on initialize', () => {
|
|
7
|
-
var _a, _b;
|
|
8
|
-
const transport = new MockTransport();
|
|
9
|
-
const session = createSession({ foo: 'bar' });
|
|
10
|
-
const config = mockConfig({
|
|
11
|
-
transports: [transport],
|
|
12
|
-
instrumentations: [new SessionInstrumentation()],
|
|
13
|
-
session,
|
|
14
|
-
});
|
|
15
|
-
initializeFaro(config);
|
|
16
|
-
expect(transport.items).toHaveLength(1);
|
|
17
|
-
const event = transport.items[0];
|
|
18
|
-
expect(event.payload.name).toEqual(Conventions.EventNames.SESSION_START);
|
|
19
|
-
expect((_a = event.meta.session) === null || _a === void 0 ? void 0 : _a.attributes).toEqual({ foo: 'bar' });
|
|
20
|
-
expect((_b = event.meta.session) === null || _b === void 0 ? void 0 : _b.id).toEqual(session.id);
|
|
21
|
-
});
|
|
22
|
-
it('will send session new start event if setSession is called.', () => {
|
|
23
|
-
var _a, _b;
|
|
24
|
-
const transport = new MockTransport();
|
|
25
|
-
const session = createSession({ foo: 'bar' });
|
|
26
|
-
const config = mockConfig({
|
|
27
|
-
transports: [transport],
|
|
28
|
-
instrumentations: [new SessionInstrumentation()],
|
|
29
|
-
session,
|
|
30
|
-
});
|
|
31
|
-
const faro = initializeFaro(config);
|
|
32
|
-
expect(transport.items).toHaveLength(1);
|
|
33
|
-
let event = transport.items[0];
|
|
34
|
-
expect(event.payload.name).toEqual(Conventions.EventNames.SESSION_START);
|
|
35
|
-
expect((_a = event.meta.session) === null || _a === void 0 ? void 0 : _a.id).toEqual(session.id);
|
|
36
|
-
faro.metas.add({ user: { id: 'foo' } });
|
|
37
|
-
expect(transport.items).toHaveLength(1);
|
|
38
|
-
const newSession = createSession();
|
|
39
|
-
faro.api.setSession(newSession);
|
|
40
|
-
expect(transport.items).toHaveLength(2);
|
|
41
|
-
event = transport.items[0];
|
|
42
|
-
expect((_b = event.meta.session) === null || _b === void 0 ? void 0 : _b.id).toEqual(session.id);
|
|
43
|
-
});
|
|
44
|
-
});
|
|
45
|
-
//# sourceMappingURL=instrumentation.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"instrumentation.test.js","sourceRoot":"","sources":["../../../../src/instrumentations/session/instrumentation.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { WebVitalsInstrumentation } from './instrumentation';
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { browserMeta } from './meta';
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { pageMeta } from './meta';
|
package/dist/esm/session.d.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { BaseTransport, PromiseBuffer } from '@grafana/faro-core';
|
|
2
|
-
import type { TransportItem } from '@grafana/faro-core';
|
|
3
|
-
import type { FetchTransportOptions } from './types';
|
|
4
|
-
export declare class FetchTransport extends BaseTransport {
|
|
5
|
-
private options;
|
|
6
|
-
readonly name = "@grafana/faro-web-sdk:transport-fetch";
|
|
7
|
-
readonly version = "1.0.0-beta1";
|
|
8
|
-
promiseBuffer: PromiseBuffer<Response | void>;
|
|
9
|
-
private rateLimitBackoffMs;
|
|
10
|
-
private getNow;
|
|
11
|
-
private disabledUntil;
|
|
12
|
-
constructor(options: FetchTransportOptions);
|
|
13
|
-
send(item: TransportItem): Promise<void>;
|
|
14
|
-
getIgnoreUrls(): Array<string | RegExp>;
|
|
15
|
-
private getRetryAfterDate;
|
|
16
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
|
-
import { getTransportBody, LogLevel, TransportItemType } from '@grafana/faro-core';
|
|
11
|
-
import { FetchTransport } from './transport';
|
|
12
|
-
const fetch = jest.fn(() => Promise.resolve({ status: 202 }));
|
|
13
|
-
global.fetch = fetch;
|
|
14
|
-
const item = {
|
|
15
|
-
type: TransportItemType.LOG,
|
|
16
|
-
payload: {
|
|
17
|
-
context: {},
|
|
18
|
-
level: LogLevel.INFO,
|
|
19
|
-
message: 'hi',
|
|
20
|
-
timestamp: new Date().toISOString(),
|
|
21
|
-
},
|
|
22
|
-
meta: {},
|
|
23
|
-
};
|
|
24
|
-
describe('FetchTransport', () => {
|
|
25
|
-
beforeEach(() => {
|
|
26
|
-
fetch.mockClear();
|
|
27
|
-
});
|
|
28
|
-
it('will send event over fetch', () => {
|
|
29
|
-
const transport = new FetchTransport({
|
|
30
|
-
url: 'http://example.com/collect',
|
|
31
|
-
});
|
|
32
|
-
transport.send(item);
|
|
33
|
-
expect(fetch).toHaveBeenCalledTimes(1);
|
|
34
|
-
expect(fetch).toHaveBeenCalledWith('http://example.com/collect', {
|
|
35
|
-
body: JSON.stringify(getTransportBody(item)),
|
|
36
|
-
headers: {
|
|
37
|
-
'Content-Type': 'application/json',
|
|
38
|
-
},
|
|
39
|
-
keepalive: true,
|
|
40
|
-
method: 'POST',
|
|
41
|
-
});
|
|
42
|
-
});
|
|
43
|
-
it('will not sending events if buffer size is exhausted', () => {
|
|
44
|
-
const transport = new FetchTransport({
|
|
45
|
-
url: 'http://example.com/collect',
|
|
46
|
-
bufferSize: 3,
|
|
47
|
-
});
|
|
48
|
-
for (let idx = 0; idx < 6; idx++) {
|
|
49
|
-
transport.send(item);
|
|
50
|
-
}
|
|
51
|
-
expect(fetch).toHaveBeenCalledTimes(3);
|
|
52
|
-
});
|
|
53
|
-
it('will back off on 429 for default interval if no retry-after header present', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
54
|
-
let now = Date.now();
|
|
55
|
-
const transport = new FetchTransport({
|
|
56
|
-
url: 'http://example.com/collect',
|
|
57
|
-
defaultRateLimitBackoffMs: 1000,
|
|
58
|
-
getNow: () => now,
|
|
59
|
-
});
|
|
60
|
-
fetch.mockImplementationOnce(() => Promise.resolve({
|
|
61
|
-
status: 429,
|
|
62
|
-
headers: {
|
|
63
|
-
get: () => '',
|
|
64
|
-
},
|
|
65
|
-
}));
|
|
66
|
-
yield transport.send(item);
|
|
67
|
-
expect(fetch).toHaveBeenCalledTimes(1);
|
|
68
|
-
yield transport.send(item);
|
|
69
|
-
expect(fetch).toHaveBeenCalledTimes(1);
|
|
70
|
-
now += 1001;
|
|
71
|
-
yield transport.send(item);
|
|
72
|
-
expect(fetch).toHaveBeenCalledTimes(2);
|
|
73
|
-
}));
|
|
74
|
-
it('will back off on 429 for default interval if retry-after header present, with delay', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
75
|
-
let now = Date.now();
|
|
76
|
-
const transport = new FetchTransport({
|
|
77
|
-
url: 'http://example.com/collect',
|
|
78
|
-
defaultRateLimitBackoffMs: 1000,
|
|
79
|
-
getNow: () => now,
|
|
80
|
-
});
|
|
81
|
-
fetch.mockImplementationOnce(() => Promise.resolve({
|
|
82
|
-
status: 429,
|
|
83
|
-
headers: {
|
|
84
|
-
get: () => '2',
|
|
85
|
-
},
|
|
86
|
-
}));
|
|
87
|
-
yield transport.send(item);
|
|
88
|
-
expect(fetch).toHaveBeenCalledTimes(1);
|
|
89
|
-
now += 1001;
|
|
90
|
-
yield transport.send(item);
|
|
91
|
-
expect(fetch).toHaveBeenCalledTimes(1);
|
|
92
|
-
now += 1001;
|
|
93
|
-
yield transport.send(item);
|
|
94
|
-
expect(fetch).toHaveBeenCalledTimes(2);
|
|
95
|
-
}));
|
|
96
|
-
it('will back off on 429 for default interval if retry-after header present, with delay', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
97
|
-
let now = Date.now();
|
|
98
|
-
const transport = new FetchTransport({
|
|
99
|
-
url: 'http://example.com/collect',
|
|
100
|
-
defaultRateLimitBackoffMs: 1000,
|
|
101
|
-
getNow: () => now,
|
|
102
|
-
});
|
|
103
|
-
fetch.mockImplementationOnce(() => Promise.resolve({
|
|
104
|
-
status: 429,
|
|
105
|
-
headers: {
|
|
106
|
-
get: () => new Date(now + 3000).toISOString(),
|
|
107
|
-
},
|
|
108
|
-
}));
|
|
109
|
-
yield transport.send(item);
|
|
110
|
-
expect(fetch).toHaveBeenCalledTimes(1);
|
|
111
|
-
now += 1001;
|
|
112
|
-
yield transport.send(item);
|
|
113
|
-
expect(fetch).toHaveBeenCalledTimes(1);
|
|
114
|
-
now += 2001;
|
|
115
|
-
yield transport.send(item);
|
|
116
|
-
expect(fetch).toHaveBeenCalledTimes(2);
|
|
117
|
-
}));
|
|
118
|
-
});
|
|
119
|
-
//# sourceMappingURL=transport.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"transport.test.js","sourceRoot":"","sources":["../../../../src/transports/fetch/transport.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export interface FetchTransportRequestOptions extends Omit<RequestInit, 'body' | 'headers'> {
|
|
2
|
-
headers?: Record<string, string>;
|
|
3
|
-
}
|
|
4
|
-
export interface FetchTransportOptions {
|
|
5
|
-
url: string;
|
|
6
|
-
apiKey?: string;
|
|
7
|
-
bufferSize?: number;
|
|
8
|
-
concurrency?: number;
|
|
9
|
-
defaultRateLimitBackoffMs?: number;
|
|
10
|
-
getNow?: ClockFn;
|
|
11
|
-
requestOptions?: FetchTransportRequestOptions;
|
|
12
|
-
}
|
|
13
|
-
export declare type ClockFn = () => number;
|