From b4e8342f549dc47024c47d5633cb64bce5a6470b Mon Sep 17 00:00:00 2001 From: Usame Algan Date: Tue, 10 Dec 2024 16:41:26 +0100 Subject: [PATCH 1/2] fix: CheckWallet sdk only if safe is also loaded --- src/components/common/CheckWallet/index.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/common/CheckWallet/index.tsx b/src/components/common/CheckWallet/index.tsx index dcf1b786de..f79f1e531e 100644 --- a/src/components/common/CheckWallet/index.tsx +++ b/src/components/common/CheckWallet/index.tsx @@ -44,7 +44,7 @@ const CheckWallet = ({ const sdk = useSafeSDK() const isProposer = useIsWalletProposer() - const { safe } = useSafeInfo() + const { safe, safeLoaded } = useSafeInfo() const isNestedSafeOwner = useIsNestedSafeOwner() @@ -54,7 +54,7 @@ const CheckWallet = ({ if (!wallet) { return Message.WalletNotConnected } - if (!sdk) { + if (!sdk && safeLoaded) { return Message.SDKNotInitialized } From a21109741f9c1e87efe5bfe4654478eb173f16b1 Mon Sep 17 00:00:00 2001 From: Usame Algan Date: Tue, 10 Dec 2024 17:01:05 +0100 Subject: [PATCH 2/2] fix: Failing test and add another one --- .../common/CheckWallet/index.test.tsx | 34 ++++++++++++++++++- src/components/common/CheckWallet/index.tsx | 1 + 2 files changed, 34 insertions(+), 1 deletion(-) diff --git a/src/components/common/CheckWallet/index.test.tsx b/src/components/common/CheckWallet/index.test.tsx index 56e66dfe31..bfa0a64bd7 100644 --- a/src/components/common/CheckWallet/index.test.tsx +++ b/src/components/common/CheckWallet/index.test.tsx @@ -231,9 +231,18 @@ describe('CheckWallet', () => { expect(getByText('Continue')).toBeDisabled() }) - it('should disable the button if SDK is not initialized', () => { + it('should disable the button if SDK is not initialized and safe is loaded', () => { mockUseSafeSdk.mockReturnValue(undefined) + const mockSafeInfo = { + safeLoaded: true, + safe: extendedSafeInfoBuilder(), + } + + ;(useSafeInfo as jest.MockedFunction).mockReturnValueOnce( + mockSafeInfo as unknown as ReturnType, + ) + const { getByText, getByLabelText } = render( {(isOk) => }, ) @@ -241,6 +250,29 @@ describe('CheckWallet', () => { expect(getByText('Continue')).toBeDisabled() expect(getByLabelText('SDK is not initialized yet')) }) + + it('should not disable the button if SDK is not initialized and safe is not loaded', () => { + mockUseSafeSdk.mockReturnValue(undefined) + + const safeAddress = faker.finance.ethereumAddress() + const mockSafeInfo = { + safeAddress, + safe: extendedSafeInfoBuilder() + .with({ address: { value: safeAddress } }) + .with({ deployed: true }) + .build(), + safeLoaded: false, + } + + ;(useSafeInfo as jest.MockedFunction).mockReturnValueOnce( + mockSafeInfo as unknown as ReturnType, + ) + + const { queryByText } = render({(isOk) => }) + + expect(queryByText('Continue')).not.toBeDisabled() + }) + it('should allow nested Safe owners', () => { ;(useIsSafeOwner as jest.MockedFunction).mockReturnValueOnce(false) mockUseNestedSafeOwners.mockReturnValue([faker.finance.ethereumAddress()]) diff --git a/src/components/common/CheckWallet/index.tsx b/src/components/common/CheckWallet/index.tsx index f79f1e531e..16794ea8a3 100644 --- a/src/components/common/CheckWallet/index.tsx +++ b/src/components/common/CheckWallet/index.tsx @@ -87,6 +87,7 @@ const CheckWallet = ({ isUndeployedSafe, sdk, wallet, + safeLoaded, ]) if (checkNetwork && isWrongChain) return children(false)