Install
openclaw skills install setup-local-testnetSpin up a local Anvil testnet with Uniswap deployed and pre-seeded liquidity. One command gives you a full development environment with funded accounts, real Uniswap pools, and zero gas costs. Use when developing, testing, or demoing Uniswap agent workflows.
openclaw skills install setup-local-testnetSpins up a local Anvil testnet forking a live chain with all Uniswap contracts available, pre-funded test accounts, and real pool state. This is the foundation for all local testing -- every other testnet skill depends on it.
Why this is 10x better than doing it manually:
create-test-pool and time-travel skills.Activate when the user says anything like:
Do NOT use when the user already has a testnet running and just wants to add pools (use create-test-pool) or advance time (use time-travel).
| Parameter | Required | Default | How to Extract |
|---|---|---|---|
| mode | No | fork | "fork" or "mock" -- fork is the default and recommended |
| forkFrom | No | ethereum | "ethereum", "base", "arbitrum", "optimism", "polygon" |
| blockNumber | No | latest | Specific block number if the user mentions one |
| seedLiquidity | No | true | Set to false only if user says "empty testnet" or "no tokens" |
| fundedAccounts | No | 3 | Number of accounts (1-5) if user specifies |
| port | No | auto | Specific port if user mentions one |
Before calling the MCP tool, verify the environment:
Anvil availability: The tool will return a clear error if Anvil is not installed. If you see TESTNET_ANVIL_NOT_FOUND, tell the user:
Anvil (Foundry) is required but not installed.
Install: curl -L https://foundry.paradigm.xyz | bash && foundryup
Network access: Fork mode requires network access to the chain's RPC. If you see TESTNET_STARTUP_TIMEOUT, suggest checking network connectivity or trying a different chain.
Parse the user's request for any specific requirements:
forkFrom: "base"blockNumber: 19000000fundedAccounts: 5seedLiquidity: falseIf the user doesn't specify, use all defaults (fork Ethereum, 3 funded accounts, seed liquidity).
Call mcp__uniswap__setup_local_testnet with the extracted parameters.
Format the response as a rich summary:
Local Testnet Ready
RPC URL: http://127.0.0.1:8545
Chain ID: 31337
Mode: Fork of Ethereum at block 19,234,567
Funded Accounts:
┌──────────────────────────────────────────────────────────────────────┐
│ # Address ETH USDC │
│ 1 0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266 10,000 1,000,000 │
│ 2 0x70997970C51812dc3A010C7d01b50e0d17dc79C8 10,000 1,000,000 │
│ 3 0x3C44CdDdB6a900fa2b585dd299e03d12FA4293BC 10,000 1,000,000 │
└──────────────────────────────────────────────────────────────────────┘
Key Contracts:
V3Factory: 0x1F98431c8aD98523631AE4a59f267346ea31F984
NonfungiblePositionManager: 0xC36442b4a4522E871399CD717aBDD847Ab11FE88
UniversalRouter: 0x3fC91A3afd70395Cd496C647d5a6CC9D4B2b7FAD
Permit2: 0x000000000022D473030F116dDEE9F6B43aC78BA3
QuoterV2: 0x61fFE014bA17989E743c5F6cB21bF9697530B21e
Available Pools (from fork):
USDC/WETH 0.05% (V3) — 0x88e6A0c2dDD26FEEb64F039a2c41296FcB3f5640
USDC/WETH 0.30% (V3) — 0x8ad599c3A0ff1De082011EFDDc58f1908eb6e6D8
USDT/WETH 0.30% (V3) — 0x4e68Ccd3E89f51C3074ca5072bbAC773960dFa36
WBTC/WETH 0.30% (V3) — 0xCBCdF9626bC03E24f779434178A73a0B4bad62eD
Private Keys (for wallet config):
Account #1: 0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80
Account #2: 0x59c6995e998f97a5a0044966f0945389dc9e86dae88c7a8412f4603b6b78690d
Account #3: 0x5de4111afa1a4b94908f83103eb1f1706367c2e68ca870fc3fb9a804cdab365a
Always end with actionable follow-ups:
Next Steps:
- Create a custom pool: "Create a WETH/DAI pool with thin liquidity"
- Test time-dependent logic: "Advance time by 7 days"
- Test a swap: "Get a quote for 1 WETH → USDC on the local testnet"
- Fund more tokens: "Fund account #1 with 10,000 WBTC"
- Configure your MCP server: Set RPC_URL_1=http://127.0.0.1:8545 in .env
| Error | User-Facing Message | Suggested Action |
|---|---|---|
TESTNET_ANVIL_NOT_FOUND | "Anvil (Foundry) is not installed." | Install: curl -L https://foundry.paradigm.xyz | bash && foundryup |
TESTNET_STARTUP_TIMEOUT | "Anvil did not start within 30s. Fork RPC may be unreachable." | Check network, try a different chain, or retry |
TESTNET_INVALID_FORK_CHAIN | "Chain X is not supported for forking." | Use ethereum, base, arbitrum, optimism, or polygon |
TESTNET_MOCK_NOT_IMPLEMENTED | "Mock mode is not yet implemented." | Use fork mode instead |
TESTNET_SETUP_FAILED | "Failed to set up testnet: {reason}" | Check Anvil installation and network access |