Skip to content

Commit

Permalink
feat: add option to set session id
Browse files Browse the repository at this point in the history
  • Loading branch information
wsbrunson committed Nov 15, 2023
1 parent 6ed54bd commit dcc354a
Show file tree
Hide file tree
Showing 4 changed files with 87 additions and 4 deletions.
10 changes: 7 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,15 +13,16 @@
"karma": "cross-env NODE_ENV=test babel-node --plugins=transform-es2015-modules-commonjs ./node_modules/.bin/karma start",
"babel": "babel src/ --out-dir dist/module",
"webpack": "babel-node --plugins=transform-es2015-modules-commonjs ./node_modules/.bin/webpack --progress",
"test": "npm run format:check && npm run lint && npm run flow-typed && npm run flow && npm run karma",
"test": "npm run format:check && npm run lint && npm run flow-typed && npm run flow && npm run vitest && npm run karma",
"build": "npm run test && npm run babel && npm run webpack",
"clean": "rimraf dist coverage",
"reinstall": "rimraf flow-typed && rimraf node_modules && npm install && flow-typed install",
"debug": "cross-env NODE_ENV=debug",
"prepare": "husky install",
"prerelease": "npm run clean && npm run build && git add dist && git commit -m 'ci: check in dist folder' || echo 'Nothing to distribute'",
"release": "standard-version",
"postrelease": "git push && git push --follow-tags && npm publish"
"postrelease": "git push && git push --follow-tags && npm publish",
"vitest": "vitest"
},
"standard-version": {
"types": [
Expand Down Expand Up @@ -86,6 +87,7 @@
"license": "Apache-2.0",
"readmeFilename": "README.md",
"devDependencies": {
"@bunchtogether/vite-plugin-flow": "^1.0.2",
"@commitlint/cli": "^16.2.1",
"@commitlint/config-conventional": "^16.2.1",
"@krakenjs/grumbler-scripts": "^8.0.5",
Expand All @@ -96,7 +98,9 @@
"lint-staged": "^12.4.0",
"mocha": "^4.1.0",
"prettier": "^2.6.2",
"standard-version": "^9.3.2"
"standard-version": "^9.3.2",
"vite": "^4.5.0",
"vitest": "^0.34.6"
},
"dependencies": {
"@krakenjs/cross-domain-safe-weakmap": "^2.0.2",
Expand Down
6 changes: 5 additions & 1 deletion src/storage.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,13 @@ const DEFAULT_SESSION_STORAGE = 20 * 60 * 1000;
export function getStorage({
name,
lifetime = DEFAULT_SESSION_STORAGE,
// a sticky session id helps to identify sdk sessions that were created by other sdks
// like the situation where the Braintree SDK loads the PP SDK
stickySessionId,
}: {|
name: string,
lifetime?: number,
stickySessionId?: string,
|}): Storage {
return inlineMemoize(
getStorage,
Expand Down Expand Up @@ -94,7 +98,7 @@ export function getStorage({

if (!session) {
session = {
guid: uniqueID(),
guid: stickySessionId || uniqueID(),
created: now,
};
}
Expand Down
44 changes: 44 additions & 0 deletions src/storage.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
import { vi, describe, test, expect, beforeEach } from "vitest";

Check failure on line 1 in src/storage.test.js

View workflow job for this annotation

GitHub Actions / main

Flow file annotation is missing

Check failure on line 1 in src/storage.test.js

View workflow job for this annotation

GitHub Actions / main

There should be at least one empty line between import groups
import { getStorage } from "./storage";
import { uniqueID, getGlobal, inlineMemoize, memoize } from "./util";

Check failure on line 3 in src/storage.test.js

View workflow job for this annotation

GitHub Actions / main

'getGlobal' is defined but never used

Check failure on line 3 in src/storage.test.js

View workflow job for this annotation

GitHub Actions / main

'inlineMemoize' is defined but never used

Check failure on line 3 in src/storage.test.js

View workflow job for this annotation

GitHub Actions / main

'memoize' is defined but never used

vi.mock("./util", async () => {
const actual = await vi.importActual("./util");

return {
...actual,
uniqueID: vi.fn(() => "unique-id-123"),
getGlobal: vi.fn(() => ({})),
inlineMemoize: vi.fn((_, impl) => impl()),
};
});

describe("storage", () => {
beforeEach(() => {
window.localStorage.clear();
});

test("happy path works", () => {
uniqueID.mockReturnValue("fake-id");
const { getID } = getStorage({ name: "test" });

expect(getID()).toEqual("fake-id");
});

test("unique id is used for session id", () => {
uniqueID.mockReturnValue("fake-session-id");
const { getSessionID } = getStorage({ name: "test" });

expect(getSessionID()).toEqual("fake-session-id");
});

test("sticky session id is used for session id", () => {
uniqueID.mockReturnValue("fake-session-id");
const { getSessionID } = getStorage({
name: "test",
stickySessionId: "sticky-session-id",
});

expect(getSessionID()).toEqual("sticky-session-id");
});
});
31 changes: 31 additions & 0 deletions vite.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
/* eslint-disable eslint-comments/disable-enable-pair */
/* eslint-disable spaced-comment */
/* eslint-disable import/no-default-export */
/// <reference types="vitest" />

// Configure Vitest (https://vitest.dev/config/)

/* @flow */

import { defineConfig } from "vite";
import { flowPlugin, esbuildFlowPlugin } from "@bunchtogether/vite-plugin-flow";

// $FlowIssue
export default defineConfig({
test: {
environment: "jsdom",
clearMocks: true,
include: ["**/src/**/*.test.js"],
},
optimizeDeps: {
esbuildOptions: {
plugins: [esbuildFlowPlugin()],
},
},
plugins: [
// $FlowIssue
flowPlugin({
exclude: "",
}),
],
});

0 comments on commit dcc354a

Please sign in to comment.