Skip to content

Commit

Permalink
fix: make sdk-next tests run in ci (#10003)
Browse files Browse the repository at this point in the history
Co-authored-by: Will Cory <willcory@Wills-MacBook-Pro.local>
  • Loading branch information
2 people authored and 0xfuturistic committed Apr 1, 2024
1 parent 829a13d commit 7d93794
Show file tree
Hide file tree
Showing 7 changed files with 123 additions and 39 deletions.
21 changes: 9 additions & 12 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -682,22 +682,22 @@ jobs:
keys:
- pnpm-packages-v2-{{ checksum "pnpm.lock.yaml" }}
- check-changed:
patterns: sdk,contracts-bedrock,contracts
patterns: sdk
# populate node modules from the cache
- run:
name: Install dependencies
command: pnpm install:ci
- run:
name: anvil-l1
name: sepolia-fork
background: true
# atm this is goerli but we should use mainnet after bedrock is live
command: anvil --fork-url $ANVIL_L1_FORK_URL --fork-block-number 9256679
command: anvil --fork-url $ANVIL_SEPOLIA_FORK_URL --fork-block-number 5580113 --port 8545

- run:
name: anvil-l2
name: op-sepolia-fork
background: true
# atm this is goerli but we should use mainnet after bedrock is live
command: anvil --fork-url $ANVIL_L2_FORK_URL --port 9545 --fork-block-number 11276409
command: anvil --fork-url $ANVIL_OP_SEPOLIA_FORK_URL --port 9545 --fork-block-number 9925328

- run:
name: build
Expand Down Expand Up @@ -1544,13 +1544,6 @@ workflows:
dependencies: '(contracts-bedrock|contracts-ts)'
requires:
- pnpm-monorepo
- js-lint-test:
name: sdk-next-tests
coverage_flag: sdk-next-tests
package_name: sdk
dependencies: "(common-ts|contracts-bedrock|core-utils)"
requires:
- pnpm-monorepo
- js-lint-test:
name: sdk-tests
coverage_flag: sdk-tests
Expand All @@ -1565,6 +1558,10 @@ workflows:
name: proxyd-tests
binary_name: proxyd
working_directory: proxyd
- sdk-next-tests:
name: sdk-next-tests
requires:
- pnpm-monorepo
- indexer-tests:
name: indexer-tests<< matrix.fpac >>
matrix:
Expand Down
6 changes: 3 additions & 3 deletions packages/sdk/test-next/README.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# test-next

- The new tests for the next version of sdk will use vitest
- The vitest tests are kept here seperated from mocha tests for now
- Can find values needed in a `.env` file in `example.env`
To run these tests it is expected that anvil is already running.

See [circle config sdk-next tests](../../../.circleci/config.yml) for which anvil commands you should run
2 changes: 1 addition & 1 deletion packages/sdk/test-next/bridgeEcoToken.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ const getL2ERC20TokenBalance = async (ownerAddress: Address) => {
)
}

describe('ECO token', () => {
describe.skip('ECO token', () => {
it('sdk should be able to deposit to l1 bridge contract correctly', async () => {
await l1TestClient.impersonateAccount({ address: ECO_WHALE })

Expand Down
2 changes: 1 addition & 1 deletion packages/sdk/test-next/messageStatus.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ const crossChainMessenger = new CrossChainMessenger({
bedrock: true,
})

describe('getMessageStatus', () => {
describe.skip('getMessageStatus', () => {
it(`should be able to correctly find a finalized withdrawal`, async () => {
/**
* Tx hash of a withdrawal
Expand Down
2 changes: 1 addition & 1 deletion packages/sdk/test-next/proveMessage.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ const crossChainMessenger = new CrossChainMessenger({
bedrock: true,
})

describe('prove message', () => {
describe.skip('prove message', () => {
it(`should prove a legacy tx
`, async () => {
/**
Expand Down
40 changes: 35 additions & 5 deletions packages/sdk/test-next/testUtils/ethersProviders.ts
Original file line number Diff line number Diff line change
@@ -1,28 +1,58 @@
import ethers from 'ethers'
import { z } from 'zod'

/**
* @deprecated
*/
const E2E_RPC_URL_L1 = z
.string()
.url()
.default('http://localhost:8545')
.describe('L1 ethereum rpc Url')
.parse(import.meta.env.VITE_E2E_RPC_URL_L1)
/**
* @deprecated
*/
const E2E_RPC_URL_L2 = z
.string()
.url()
.describe('L1 ethereum rpc Url')
.default('http://localhost:9545')
.describe('L2 ethereum rpc Url')
.parse(import.meta.env.VITE_E2E_RPC_URL_L2)

const jsonRpcHeaders = { 'User-Agent': 'eth-optimism/@gateway/backend' }
/**
* Initialize the signer, prover, and cross chain messenger
* @deprecated
*/
const l1Provider = new ethers.providers.JsonRpcProvider({
export const l1Provider = new ethers.providers.JsonRpcProvider({
url: E2E_RPC_URL_L1,
headers: jsonRpcHeaders,
})
const l2Provider = new ethers.providers.JsonRpcProvider({
/**
* @deprecated
*/
export const l2Provider = new ethers.providers.JsonRpcProvider({
url: E2E_RPC_URL_L2,
headers: jsonRpcHeaders,
})

export { l1Provider, l2Provider }
export const E2E_RPC_URL_SEPOLIA = z
.string()
.url()
.default('http://localhost:8545')
.describe('SEPOLIA ethereum rpc Url')
.parse(import.meta.env.VITE_E2E_RPC_URL_SEPOLIA)
export const E2E_RPC_URL_OP_SEPOLIA = z
.string()
.url()
.default('http://localhost:9545')
.describe('OP_SEPOLIA ethereum rpc Url')
.parse(import.meta.env.VITE_E2E_RPC_URL_OP_SEPOLIA)
export const sepoliaProvider = new ethers.providers.JsonRpcProvider({
url: E2E_RPC_URL_SEPOLIA,
headers: jsonRpcHeaders,
})
export const opSepoliaProvider = new ethers.providers.JsonRpcProvider({
url: E2E_RPC_URL_OP_SEPOLIA,
headers: jsonRpcHeaders,
})
89 changes: 73 additions & 16 deletions packages/sdk/test-next/testUtils/viemClients.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,51 +4,108 @@ import {
createWalletClient,
http,
} from 'viem'
import { goerli, optimismGoerli } from 'viem/chains'
import { goerli, optimismGoerli, optimismSepolia, sepolia } from 'viem/chains'

// we should instead use .env to determine chain so we can support alternate l1/l2 pairs
import { E2E_RPC_URL_OP_SEPOLIA, E2E_RPC_URL_SEPOLIA } from './ethersProviders'

/**
* @deprecated
*/
const L1_CHAIN = goerli
/**
* @deprecated
*/
const L2_CHAIN = optimismGoerli
/**
* @deprecated
*/
const L1_RPC_URL = 'http://localhost:8545'
/**
* @deprecated
*/
const L2_RPC_URL = 'http://localhost:9545'

const l1TestClient = createTestClient({
/**
* @deprecated
*/
export const l1TestClient = createTestClient({
mode: 'anvil',
chain: L1_CHAIN,
transport: http(L1_RPC_URL),
})

const l2TestClient = createTestClient({
/**
* @deprecated
*/
export const l2TestClient = createTestClient({
mode: 'anvil',
chain: L2_CHAIN,
transport: http(L2_RPC_URL),
})

const l1PublicClient = createPublicClient({
/**
* @deprecated
*/
export const l1PublicClient = createPublicClient({
chain: L1_CHAIN,
transport: http(L1_RPC_URL),
})

const l2PublicClient = createPublicClient({
/**
* @deprecated
*/
export const l2PublicClient = createPublicClient({
chain: L2_CHAIN,
transport: http(L2_RPC_URL),
})

const l1WalletClient = createWalletClient({
/**
* @deprecated
*/
export const l1WalletClient = createWalletClient({
chain: L1_CHAIN,
transport: http(L1_RPC_URL),
})

const l2WalletClient = createWalletClient({
/**
* @deprecated
*/
export const l2WalletClient = createWalletClient({
chain: L2_CHAIN,
transport: http(L2_RPC_URL),
})

export {
l1TestClient,
l2TestClient,
l1PublicClient,
l2PublicClient,
l1WalletClient,
l2WalletClient,
}
const SEPOLIA_CHAIN = sepolia
const OP_SEPOLIA_CHAIN = optimismSepolia

export const sepoliaTestClient = createTestClient({
mode: 'anvil',
chain: SEPOLIA_CHAIN,
transport: http(E2E_RPC_URL_SEPOLIA),
})

export const opSepoliaTestClient = createTestClient({
mode: 'anvil',
chain: OP_SEPOLIA_CHAIN,
transport: http(E2E_RPC_URL_OP_SEPOLIA),
})

export const sepoliaPublicClient = createPublicClient({
chain: SEPOLIA_CHAIN,
transport: http(E2E_RPC_URL_SEPOLIA),
})

export const opSepoliaPublicClient = createPublicClient({
chain: OP_SEPOLIA_CHAIN,
transport: http(E2E_RPC_URL_OP_SEPOLIA),
})

export const sepoliaWalletClient = createWalletClient({
chain: SEPOLIA_CHAIN,
transport: http(E2E_RPC_URL_SEPOLIA),
})

export const opSepoliaWalletClient = createWalletClient({
chain: OP_SEPOLIA_CHAIN,
transport: http(E2E_RPC_URL_OP_SEPOLIA),
})

0 comments on commit 7d93794

Please sign in to comment.