diff --git a/.env.example b/.env.example index 80b79ff3..2c074f1c 100644 --- a/.env.example +++ b/.env.example @@ -8,5 +8,4 @@ PAYMASTER_URL= PIMLICO_API_KEY= TENDERLY_API_KEY= TENDERLY_ACCOUNT_SLUG= -TENDERLY_PROJECT_SLUG= -VIRTUAL_BASE_SEPOLIA= \ No newline at end of file +TENDERLY_PROJECT_SLUG= \ No newline at end of file diff --git a/.github/workflows/unit-tests.yml b/.github/workflows/unit-tests.yml index c1bfeed5..83d440bf 100644 --- a/.github/workflows/unit-tests.yml +++ b/.github/workflows/unit-tests.yml @@ -28,7 +28,6 @@ jobs: PIMLICO_API_KEY: ${{ secrets.PIMLICO_API_KEY }} PAYMASTER_URL: ${{ secrets.PAYMASTER_URL }} BUNDLER_URL: ${{ secrets.BUNDLER_URL }} - VIRTUAL_BASE_SEPOLIA: ${{ secrets.VIRTUAL_BASE_SEPOLIA }} CHAIN_ID: 84532 ALT_CHAIN_ID: 11155420 CI: true diff --git a/CHANGELOG.md b/CHANGELOG.md index 2de658b1..7409be5a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ # @biconomy/sdk +## 0.0.24 + +### Patch Changes + +- Remove tenderlyUrl from env vars + ## 0.0.23 ### Patch Changes diff --git a/package.json b/package.json index 84f5f9dc..e30b042a 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@biconomy/sdk", - "version": "0.0.23", + "version": "0.0.24", "author": "Biconomy", "repository": "github:bcnmy/sdk", "main": "./dist/_cjs/index.js", diff --git a/src/sdk/clients/createBicoPaymasterClient.test.ts b/src/sdk/clients/createBicoPaymasterClient.test.ts index 5b8ca88c..91584ab1 100644 --- a/src/sdk/clients/createBicoPaymasterClient.test.ts +++ b/src/sdk/clients/createBicoPaymasterClient.test.ts @@ -11,7 +11,7 @@ import { parseUnits } from "viem" import { afterAll, beforeAll, describe, expect, test } from "vitest" -import { toNetworks } from "../../test/testSetup" +import { paymasterTruthy, toNetworks } from "../../test/testSetup" import { killNetwork } from "../../test/testUtils" import type { NetworkConfig } from "../../test/testUtils" import { type NexusAccount, toNexusAccount } from "../account/toNexusAccount" @@ -25,8 +25,7 @@ import { createSmartAccountClient } from "./createSmartAccountClient" -describe.skip("bico.paymaster", async () => { - // describe.runIf(paymasterTruthy())("bico.paymaster", async () => { +describe.runIf(paymasterTruthy())("bico.paymaster", async () => { let network: NetworkConfig let chain: Chain @@ -48,6 +47,8 @@ describe.skip("bico.paymaster", async () => { const baseSepoliaDAIAddress: Address = "0x7683022d84f726a96c4a6611cd31dbf5409c0ac9" + const index = 5n + beforeAll(async () => { ;[network] = await toNetworks("TESTNET_FROM_ENV_VARS") @@ -76,17 +77,21 @@ describe.skip("bico.paymaster", async () => { nexusAccount = await toNexusAccount({ signer: account, chain, - transport: http() + transport: http(), + index }) nexusAccountAddress = await nexusAccount.getCounterFactualAddress() + console.log("nexusAccountAddress", nexusAccountAddress) + nexusClient = await createSmartAccountClient({ signer: account, chain, transport: http(), bundlerTransport: http(bundlerUrl), - paymaster + paymaster, + index }) }) afterAll(async () => { @@ -142,7 +147,8 @@ describe.skip("bico.paymaster", async () => { }), paymasterContext, transport: http(), - bundlerTransport: http(bundlerUrl) + bundlerTransport: http(bundlerUrl), + index }) const initialBalance = await publicClient.getBalance({ @@ -184,7 +190,8 @@ describe.skip("bico.paymaster", async () => { }), paymasterContext, transport: http(), - bundlerTransport: http(bundlerUrl) + bundlerTransport: http(bundlerUrl), + index }) const initialBalance = await publicClient.getBalance({ @@ -230,7 +237,8 @@ describe.skip("bico.paymaster", async () => { }), paymasterContext, transport: http(), - bundlerTransport: http(bundlerUrl) + bundlerTransport: http(bundlerUrl), + index }) const usdcBalance = await publicClient.readContract({ @@ -299,7 +307,8 @@ describe.skip("bico.paymaster", async () => { }), paymasterContext, transport: http(), - bundlerTransport: http(bundlerUrl) + bundlerTransport: http(bundlerUrl), + index }) const supportedTokens = await paymaster.getSupportedTokens(nexusClient) diff --git a/src/sdk/modules/smartSessionsValidator/toSmartSessionValidator.enable.mode.test.ts b/src/sdk/modules/smartSessionsValidator/toSmartSessionValidator.enable.mode.test.ts index 989ce959..a9dbad3d 100644 --- a/src/sdk/modules/smartSessionsValidator/toSmartSessionValidator.enable.mode.test.ts +++ b/src/sdk/modules/smartSessionsValidator/toSmartSessionValidator.enable.mode.test.ts @@ -16,9 +16,9 @@ import { beforeAll, describe, expect, test } from "vitest" import { CounterAbi } from "../../../test/__contracts/abi/CounterAbi" import { testAddresses } from "../../../test/callDatas" import { toNetwork } from "../../../test/testSetup" -import { getTestParamsForTestnet } from "../../../test/testUtils" -import type { NetworkConfig, TestnetParams } from "../../../test/testUtils" +import type { NetworkConfig } from "../../../test/testUtils" import { type NexusAccount, toNexusAccount } from "../../account/toNexusAccount" +import { safeMultiplier } from "../../account/utils/Utils" import { type NexusClient, createSmartAccountClient @@ -63,6 +63,8 @@ describe("modules.smartSessions.enable.mode.dx", async () => { let stringifiedSessionDatum: string + const index = 2n + beforeAll(async () => { network = await toNetwork("TESTNET_FROM_ENV_VARS") @@ -88,7 +90,7 @@ describe("modules.smartSessions.enable.mode.dx", async () => { }) nexusAccount = await toNexusAccount({ - index: 1n, + index, signer: eoaAccount, chain, transport: http() @@ -97,7 +99,7 @@ describe("modules.smartSessions.enable.mode.dx", async () => { nexusAccountAddress = await nexusAccount.getCounterFactualAddress() nexusClient = await createSmartAccountClient({ - index: 1n, + index, account: nexusAccount, signer: eoaAccount, chain, @@ -191,7 +193,7 @@ describe("modules.smartSessions.enable.mode.dx", async () => { const userOperation = await nexusClient.prepareUserOperation({ verificationGasLimit: 10000000n, callGasLimit: 10000000n, - preVerificationGas: 10000000n, + preVerificationGas: 100000000n, calls, signature: encodeSmartSessionSignature(sessionDetails), nonce: await nexusClient.account.getNonce({ @@ -278,7 +280,7 @@ describe("modules.smartSessions.enable.mode.dx", async () => { // Create a new Nexus client for the session // This client will be used to interact with the smart contract account using the session key const smartSessionNexusClient = await createSmartAccountClient({ - index: 1n, + index, accountAddress: usersSessionData.granter, signer: eoaAccount, chain, @@ -301,7 +303,7 @@ describe("modules.smartSessions.enable.mode.dx", async () => { const userOpHash = await useSmartSessionNexusClient.usePermission({ verificationGasLimit: 10000000n, callGasLimit: 10000000n, - preVerificationGas: 10000000n, + preVerificationGas: 100000000n, calls: [ { to: testAddresses.Counter, diff --git a/src/test/testUtils.ts b/src/test/testUtils.ts index 9b9c9b8e..3fef3257 100644 --- a/src/test/testUtils.ts +++ b/src/test/testUtils.ts @@ -42,6 +42,9 @@ import type { TestFileNetworkType } from "./testSetup" config() +const BASE_SEPOLIA_RPC_URL = + "https://virtual.base-sepolia.rpc.tenderly.co/6ccdd33d-d8f4-4476-8d37-63ba0ed0ea8f" + type AnvilInstance = ReturnType type BundlerInstance = ReturnType type BundlerDto = { @@ -215,17 +218,18 @@ export const toConfiguredAnvil = async ({ chainId: rpcPort, port: rpcPort, codeSizeLimit: 1000000000000, - forkUrl: shouldForkBaseSepolia - ? process.env.VIRTUAL_BASE_SEPOLIA - : undefined + forkUrl: shouldForkBaseSepolia ? BASE_SEPOLIA_RPC_URL : undefined } const instance = anvil(config) await instance.start() - await initDeployments(rpcPort) + await initDeployments(rpcPort, shouldForkBaseSepolia) return instance } -export const initDeployments = async (rpcPort: number) => { +export const initDeployments = async ( + rpcPort: number, + shouldForkBaseSepolia = false +) => { // Hardhat deployment of nexus repo: console.log( `using hardhat to deploy nexus contracts to http://localhost:${rpcPort}` @@ -234,19 +238,21 @@ export const initDeployments = async (rpcPort: number) => { await hardhatExec.deploy(rpcPort) console.log("hardhat deployment complete.") - // Hardcoded bytecode deployment of contracts using setCode: - console.log("setting bytecode with hardcoded calldata.") - const chain = getTestChainFromPort(rpcPort) - const account = getTestAccount() - const testClient = toTestClient(chain, account) - // Dynamic bytecode deployment of contracts using setCode: - console.log("setting bytecode with dynamic calldata from a testnet") - await setByteCodeHardcoded(testClient) - await setByteCodeDynamic(testClient, TEST_CONTRACTS) - - console.log("bytecode deployment complete.") - console.log("") + if (!shouldForkBaseSepolia) { + // Hardcoded bytecode deployment of contracts using setCode: + console.log("setting bytecode with hardcoded calldata.") + const chain = getTestChainFromPort(rpcPort) + const account = getTestAccount() + const testClient = toTestClient(chain, account) + + console.log("setting bytecode with dynamic calldata from a testnet") + await setByteCodeHardcoded(testClient) + await setByteCodeDynamic(testClient, TEST_CONTRACTS) + + console.log("bytecode deployment complete.") + console.log("") + } } const portOptions = { exclude: [] as number[] }