Skip to content

Commit 59e3cec

Browse files
committed
update
1 parent 3718020 commit 59e3cec

21 files changed

+1118
-61
lines changed
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
import { describe, expect, it } from "vitest";
2+
import { renderHook } from "~test/react-render.js";
3+
import { useConnectionManager } from "./connection-manager.js";
4+
5+
describe("useConnectionManager", () => {
6+
it("throws an error when used outside of ThirdwebProvider", () => {
7+
expect(() => {
8+
renderHook(() => useConnectionManager());
9+
}).toThrow("useConnectionManager must be used within <ThirdwebProvider>");
10+
});
11+
});
Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
import { describe, expect, it } from "vitest";
2+
import { ANVIL_CHAIN } from "~test/chains.js";
3+
import { createWallet } from "../../../wallets/create-wallet.js";
4+
import { hasSmartAccount } from "./isSmartWallet.js";
5+
6+
describe("isSmartWallet", () => {
7+
it("should work if id is inApp and has smartAccount in wallet config", () => {
8+
const wallet = createWallet("inApp", {
9+
smartAccount: {
10+
chain: ANVIL_CHAIN,
11+
sponsorGas: true,
12+
overrides: {
13+
bundlerUrl: "your-bundler-url",
14+
},
15+
},
16+
});
17+
expect(hasSmartAccount(wallet)).toBe(true);
18+
});
19+
});
Lines changed: 57 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,57 @@
1+
import { beforeEach, describe, expect, it, vi } from "vitest";
2+
import type { AsyncStorage } from "../../../utils/storage/AsyncStorage.js";
3+
import type { AuthArgsType } from "../../../wallets/in-app/core/authentication/types.js";
4+
import {
5+
LAST_AUTH_PROVIDER_STORAGE_KEY,
6+
getLastAuthProvider,
7+
setLastAuthProvider,
8+
} from "./storage.js";
9+
10+
describe("Auth Provider Storage", () => {
11+
let mockStorage: AsyncStorage;
12+
13+
beforeEach(() => {
14+
mockStorage = {
15+
getItem: vi.fn(),
16+
setItem: vi.fn(),
17+
removeItem: vi.fn(),
18+
};
19+
});
20+
21+
describe("setLastAuthProvider", () => {
22+
it("should store the auth provider in storage", async () => {
23+
const authProvider: AuthArgsType["strategy"] = "email";
24+
await setLastAuthProvider(authProvider, mockStorage);
25+
26+
expect(mockStorage.setItem).toHaveBeenCalledWith(
27+
LAST_AUTH_PROVIDER_STORAGE_KEY,
28+
authProvider,
29+
);
30+
});
31+
});
32+
33+
describe("getLastAuthProvider", () => {
34+
it("should retrieve the last auth provider from storage", async () => {
35+
const mockAuthProvider: AuthArgsType["strategy"] = "google";
36+
vi.mocked(mockStorage.getItem).mockResolvedValue(mockAuthProvider);
37+
38+
const result = await getLastAuthProvider(mockStorage);
39+
40+
expect(mockStorage.getItem).toHaveBeenCalledWith(
41+
LAST_AUTH_PROVIDER_STORAGE_KEY,
42+
);
43+
expect(result).toBe(mockAuthProvider);
44+
});
45+
46+
it("should return null if no auth provider is stored", async () => {
47+
vi.mocked(mockStorage.getItem).mockResolvedValue(null);
48+
49+
const result = await getLastAuthProvider(mockStorage);
50+
51+
expect(mockStorage.getItem).toHaveBeenCalledWith(
52+
LAST_AUTH_PROVIDER_STORAGE_KEY,
53+
);
54+
expect(result).toBeNull();
55+
});
56+
});
57+
});
Lines changed: 55 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
import { describe, expect, it } from "vitest";
2+
import { structuralSharing } from "./structuralSharing.js";
3+
4+
describe("structuralSharing", () => {
5+
it("should return the old data if it is deeply equal to the new data", () => {
6+
const oldData = { a: 1, b: { c: 2 } };
7+
const newData = { a: 1, b: { c: 2 } };
8+
const result = structuralSharing(oldData, newData);
9+
expect(result).toBe(oldData);
10+
});
11+
12+
it("should return a new object with shared structure for equal parts", () => {
13+
const oldData = { a: 1, b: { c: 2 }, d: 3 };
14+
const newData = { a: 1, b: { c: 2 }, d: 4 };
15+
const result = structuralSharing(oldData, newData);
16+
expect(result).not.toBe(oldData);
17+
expect(result).not.toBe(newData);
18+
expect(result.a).toBe(oldData.a);
19+
expect(result.b).toBe(oldData.b);
20+
expect(result.d).toBe(newData.d);
21+
});
22+
23+
it("should handle arrays correctly", () => {
24+
const oldData = [1, 2, [3, 4]];
25+
const newData = [1, 2, [3, 5]];
26+
const result = structuralSharing(oldData, newData);
27+
expect(result).not.toBe(oldData);
28+
expect(result).not.toBe(newData);
29+
expect(result[0]).toBe(oldData[0]);
30+
expect(result[1]).toBe(oldData[1]);
31+
expect(result[2]).not.toBe(oldData[2]);
32+
});
33+
34+
it("should handle undefined oldData", () => {
35+
const oldData = undefined;
36+
const newData = { a: 1 };
37+
const result = structuralSharing(oldData, newData);
38+
expect(result).toBe(newData);
39+
});
40+
41+
it("should handle NaN values correctly", () => {
42+
const oldData = { a: Number.NaN };
43+
const newData = { a: Number.NaN };
44+
const result = structuralSharing(oldData, newData);
45+
expect(result).toBe(oldData);
46+
});
47+
48+
it("should handle objects with different constructors", () => {
49+
class CustomClass {}
50+
const oldData = new CustomClass();
51+
const newData = { a: 1 };
52+
const result = structuralSharing(oldData, newData);
53+
expect(result).toBe(newData);
54+
});
55+
});
Lines changed: 81 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,81 @@
1+
import { describe, expect, it } from "vitest";
2+
import { genericWalletIcon, getSocialIcon, socialIcons } from "./walletIcon.js";
3+
4+
const emailIcon =
5+
"";
6+
const phoneIcon =
7+
"";
8+
const guestIcon =
9+
"";
10+
const passkeyIcon =
11+
"";
12+
13+
describe("walletIcon", () => {
14+
it("should return google icon", () => {
15+
expect(getSocialIcon("google")).toBe(socialIcons.google);
16+
});
17+
18+
it("should return coinbase icon", () => {
19+
expect(getSocialIcon("coinbase")).toBe(socialIcons.coinbase);
20+
});
21+
22+
it("should return apple icon", () => {
23+
expect(getSocialIcon("apple")).toBe(socialIcons.apple);
24+
});
25+
26+
it("should return facebook icon", () => {
27+
expect(getSocialIcon("facebook")).toBe(socialIcons.facebook);
28+
});
29+
30+
it("should return phone icon", () => {
31+
expect(getSocialIcon("phone")).toBe(phoneIcon);
32+
});
33+
34+
it("should return email icon", () => {
35+
expect(getSocialIcon("email")).toBe(emailIcon);
36+
});
37+
38+
it("should return passkey icon", () => {
39+
expect(getSocialIcon("passkey")).toBe(passkeyIcon);
40+
});
41+
42+
it("should return discord icon", () => {
43+
expect(getSocialIcon("discord")).toBe(socialIcons.discord);
44+
});
45+
46+
it("should return line icon", () => {
47+
expect(getSocialIcon("line")).toBe(socialIcons.line);
48+
});
49+
50+
it("should return x icon", () => {
51+
expect(getSocialIcon("x")).toBe(socialIcons.x);
52+
});
53+
54+
it("should return farcaster icon", () => {
55+
expect(getSocialIcon("farcaster")).toBe(socialIcons.farcaster);
56+
});
57+
58+
it("should return telegram icon", () => {
59+
expect(getSocialIcon("telegram")).toBe(socialIcons.telegram);
60+
});
61+
62+
it("should return twitch icon", () => {
63+
expect(getSocialIcon("twitch")).toBe(socialIcons.twitch);
64+
});
65+
66+
it("should return github icon", () => {
67+
expect(getSocialIcon("github")).toBe(socialIcons.github);
68+
});
69+
70+
it("should return steam icon", () => {
71+
expect(getSocialIcon("steam")).toBe(socialIcons.steam);
72+
});
73+
74+
it("should return guest icon", () => {
75+
expect(getSocialIcon("guest")).toBe(guestIcon);
76+
});
77+
78+
it("should return generic wallet icon for unknown provider", () => {
79+
expect(getSocialIcon("unknown")).toBe(genericWalletIcon);
80+
});
81+
});

packages/thirdweb/src/react/core/utils/walletIcon.ts

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,9 @@ export const genericWalletIcon =
3838
const passkeyIcon =
3939
"";
4040

41+
/**
42+
* @internal
43+
*/
4144
export const socialIcons = {
4245
google: googleIconUri,
4346
apple: appleIconUri,

0 commit comments

Comments
 (0)