Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
N
nebula
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
exchain
nebula
Commits
3c5fd4c3
Unverified
Commit
3c5fd4c3
authored
Nov 09, 2021
by
Matthew Slipper
Committed by
Kelvin Fichter
Nov 10, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Itests mainnet prep
parent
23ec66f7
Changes
9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
82 additions
and
21 deletions
+82
-21
README.md
integration-tests/README.md
+7
-0
basic-l1-l2-communication.spec.ts
integration-tests/test/basic-l1-l2-communication.spec.ts
+8
-1
contracts.spec.ts
integration-tests/test/contracts.spec.ts
+33
-1
native-eth-ovm-calls.spec.ts
integration-tests/test/native-eth-ovm-calls.spec.ts
+3
-3
rpc.spec.ts
integration-tests/test/rpc.spec.ts
+8
-9
env.ts
integration-tests/test/shared/env.ts
+2
-2
stress-test-helpers.ts
integration-tests/test/shared/stress-test-helpers.ts
+2
-2
utils.ts
integration-tests/test/shared/utils.ts
+12
-1
stress-tests.spec.ts
integration-tests/test/stress-tests.spec.ts
+7
-2
No files found.
integration-tests/README.md
View file @
3c5fd4c3
...
...
@@ -33,3 +33,10 @@ You can also set environment variables on the command line instead of inside `.e
```
bash
L1_URL
=
whatever
L2_URL
=
whatever yarn
test
:integration:live
```
To run the Uniswap integration tests against a deployed set of Uniswap contracts, add the following env vars:
```
UNISWAP_POSITION_MANAGER_ADDRESS=<non fungible position manager address>
UNISWAP_ROUTER_ADDRESS=<router address>
```
integration-tests/test/basic-l1-l2-communication.spec.ts
View file @
3c5fd4c3
...
...
@@ -9,6 +9,7 @@ import simpleStorageJson from '../artifacts/contracts/SimpleStorage.sol/SimpleSt
import
l2ReverterJson
from
'
../artifacts/contracts/Reverter.sol/Reverter.json
'
import
{
Direction
}
from
'
./shared/watcher-utils
'
import
{
OptimismEnv
}
from
'
./shared/env
'
import
{
isMainnet
}
from
'
./shared/utils
'
describe
(
'
Basic L1<>L2 Communication
'
,
async
()
=>
{
let
Factory__L1SimpleStorage
:
ContractFactory
...
...
@@ -48,7 +49,13 @@ describe('Basic L1<>L2 Communication', async () => {
})
describe
(
'
L2 => L1
'
,
()
=>
{
it
(
'
should be able to perform a withdrawal from L2 -> L1
'
,
async
()
=>
{
it
(
'
should be able to perform a withdrawal from L2 -> L1
'
,
async
function
()
{
if
(
await
isMainnet
(
env
))
{
console
.
log
(
'
Skipping withdrawals test on mainnet.
'
)
this
.
skip
()
return
}
const
value
=
`0x
${
'
77
'
.
repeat
(
32
)}
`
// Send L2 -> L1 message.
...
...
integration-tests/test/contracts.spec.ts
View file @
3c5fd4c3
...
...
@@ -7,6 +7,9 @@ import { UniswapV3Deployer } from 'uniswap-v3-deploy-plugin/dist/deployer/Uniswa
import
{
OptimismEnv
}
from
'
./shared/env
'
import
{
FeeAmount
,
TICK_SPACINGS
}
from
'
@uniswap/v3-sdk
'
import
{
abi
as
NFTABI
}
from
'
@uniswap/v3-periphery/artifacts/contracts/NonfungiblePositionManager.sol/NonfungiblePositionManager.json
'
import
{
abi
as
RouterABI
}
from
'
@uniswap/v3-periphery/artifacts/contracts/SwapRouter.sol/SwapRouter.json
'
chai
.
use
(
solidity
)
// Below methods taken from the Uniswap test suite, see
...
...
@@ -97,6 +100,27 @@ describe('Contract interactions', () => {
let
tokens
:
Contract
[]
before
(
async
()
=>
{
if
(
process
.
env
.
UNISWAP_POSITION_MANAGER_ADDRESS
&&
process
.
env
.
UNISWAP_ROUTER_ADDRESS
)
{
console
.
log
(
'
Using predeployed Uniswap. Addresses:
'
)
console
.
log
(
`Position manager:
${
process
.
env
.
UNISWAP_POSITION_MANAGER_ADDRESS
}
`
)
console
.
log
(
`Router:
${
process
.
env
.
UNISWAP_ROUTER_ADDRESS
}
`
)
contracts
=
{
positionManager
:
new
Contract
(
process
.
env
.
UNISWAP_POSITION_MANAGER_ADDRESS
,
NFTABI
).
connect
(
env
.
l2Wallet
),
router
:
new
Contract
(
process
.
env
.
UNISWAP_ROUTER_ADDRESS
,
RouterABI
).
connect
(
env
.
l2Wallet
),
}
}
const
tokenA
=
await
Factory__ERC20
.
deploy
(
100000000
,
'
OVM1
'
,
8
,
'
OVM1
'
)
await
tokenA
.
deployed
()
const
tokenB
=
await
Factory__ERC20
.
deploy
(
100000000
,
'
OVM2
'
,
8
,
'
OVM2
'
)
...
...
@@ -118,7 +142,15 @@ describe('Contract interactions', () => {
await
tx
.
wait
()
})
it
(
'
should deploy the Uniswap ecosystem
'
,
async
()
=>
{
it
(
'
should deploy the Uniswap ecosystem
'
,
async
function
()
{
if
(
contracts
)
{
console
.
log
(
'
Skipping Uniswap deployment since addresses are already defined.
'
)
this
.
skip
()
return
}
contracts
=
await
UniswapV3Deployer
.
deploy
(
env
.
l2Wallet
)
})
...
...
integration-tests/test/native-eth-ovm-calls.spec.ts
View file @
3c5fd4c3
...
...
@@ -47,7 +47,7 @@ describe('Native ETH value integration tests', () => {
const
there
=
await
wallet
.
sendTransaction
({
to
:
other
.
address
,
value
,
gasPrice
:
await
gasPriceForL2
(),
gasPrice
:
await
gasPriceForL2
(
env
),
})
const
thereReceipt
=
await
there
.
wait
()
const
thereGas
=
thereReceipt
.
gasUsed
.
mul
(
there
.
gasPrice
)
...
...
@@ -65,7 +65,7 @@ describe('Native ETH value integration tests', () => {
const
backAgain
=
await
other
.
sendTransaction
({
to
:
wallet
.
address
,
value
:
backVal
,
gasPrice
:
await
gasPriceForL2
(),
gasPrice
:
await
gasPriceForL2
(
env
),
})
const
backReceipt
=
await
backAgain
.
wait
()
const
backGas
=
backReceipt
.
gasUsed
.
mul
(
backAgain
.
gasPrice
)
...
...
@@ -171,7 +171,7 @@ describe('Native ETH value integration tests', () => {
it
(
'
should allow ETH to be sent
'
,
async
()
=>
{
const
sendAmount
=
15
const
tx
=
await
ValueCalls0
.
simpleSend
(
ValueCalls1
.
address
,
sendAmount
,
{
gasPrice
:
await
gasPriceForL2
(),
gasPrice
:
await
gasPriceForL2
(
env
),
})
await
tx
.
wait
()
...
...
integration-tests/test/rpc.spec.ts
View file @
3c5fd4c3
...
...
@@ -9,7 +9,6 @@ import {
defaultTransactionFactory
,
fundUser
,
L2_CHAINID
,
IS_LIVE_NETWORK
,
isLiveNetwork
,
gasPriceForL2
,
}
from
'
./shared/utils
'
...
...
@@ -62,7 +61,7 @@ describe('Basic RPC tests', () => {
describe
(
'
eth_sendRawTransaction
'
,
()
=>
{
it
(
'
should correctly process a valid transaction
'
,
async
()
=>
{
const
tx
=
defaultTransactionFactory
()
tx
.
gasPrice
=
await
gasPriceForL2
()
tx
.
gasPrice
=
await
gasPriceForL2
(
env
)
const
nonce
=
await
wallet
.
getTransactionCount
()
const
result
=
await
wallet
.
sendTransaction
(
tx
)
...
...
@@ -76,7 +75,7 @@ describe('Basic RPC tests', () => {
it
(
'
should not accept a transaction with the wrong chain ID
'
,
async
()
=>
{
const
tx
=
{
...
defaultTransactionFactory
(),
gasPrice
:
await
gasPriceForL2
(),
gasPrice
:
await
gasPriceForL2
(
env
),
chainId
:
(
await
wallet
.
getChainId
())
+
1
,
}
...
...
@@ -88,7 +87,7 @@ describe('Basic RPC tests', () => {
it
(
'
should not accept a transaction without a chain ID
'
,
async
()
=>
{
const
tx
=
{
...
defaultTransactionFactory
(),
gasPrice
:
await
gasPriceForL2
(),
gasPrice
:
await
gasPriceForL2
(
env
),
chainId
:
null
,
// Disables EIP155 transaction signing.
}
...
...
@@ -100,7 +99,7 @@ describe('Basic RPC tests', () => {
it
(
'
should accept a transaction with a value
'
,
async
()
=>
{
const
tx
=
{
...
defaultTransactionFactory
(),
gasPrice
:
await
gasPriceForL2
(),
gasPrice
:
await
gasPriceForL2
(
env
),
chainId
:
await
env
.
l2Wallet
.
getChainId
(),
data
:
'
0x
'
,
value
:
ethers
.
utils
.
parseEther
(
'
0.1
'
),
...
...
@@ -120,7 +119,7 @@ describe('Basic RPC tests', () => {
const
balance
=
await
env
.
l2Wallet
.
getBalance
()
const
tx
=
{
...
defaultTransactionFactory
(),
gasPrice
:
await
gasPriceForL2
(),
gasPrice
:
await
gasPriceForL2
(
env
),
chainId
:
await
env
.
l2Wallet
.
getChainId
(),
data
:
'
0x
'
,
value
:
balance
.
add
(
ethers
.
utils
.
parseEther
(
'
1
'
)),
...
...
@@ -284,7 +283,7 @@ describe('Basic RPC tests', () => {
describe
(
'
eth_getTransactionByHash
'
,
()
=>
{
it
(
'
should be able to get all relevant l1/l2 transaction data
'
,
async
()
=>
{
const
tx
=
defaultTransactionFactory
()
tx
.
gasPrice
=
await
gasPriceForL2
()
tx
.
gasPrice
=
await
gasPriceForL2
(
env
)
const
result
=
await
wallet
.
sendTransaction
(
tx
)
await
result
.
wait
()
...
...
@@ -299,7 +298,7 @@ describe('Basic RPC tests', () => {
it
(
'
should return the block and all included transactions
'
,
async
()
=>
{
// Send a transaction and wait for it to be mined.
const
tx
=
defaultTransactionFactory
()
tx
.
gasPrice
=
await
gasPriceForL2
()
tx
.
gasPrice
=
await
gasPriceForL2
(
env
)
const
result
=
await
wallet
.
sendTransaction
(
tx
)
const
receipt
=
await
result
.
wait
()
...
...
@@ -326,7 +325,7 @@ describe('Basic RPC tests', () => {
// other people are sending transactions to the Sequencer at the same time
// as this test is running.
it
(
'
should return the same result when new transactions are not applied
'
,
async
function
()
{
if
(
IS_LIVE_NETWORK
)
{
if
(
isLiveNetwork
()
)
{
this
.
skip
()
}
...
...
integration-tests/test/shared/env.ts
View file @
3c5fd4c3
...
...
@@ -78,8 +78,8 @@ export class OptimismEnv {
// fund the user if needed
const
balance
=
await
l2Wallet
.
getBalance
()
if
(
balance
.
isZero
(
))
{
await
fundUser
(
watcher
,
l1Bridge
,
utils
.
parseEther
(
'
20
'
))
if
(
balance
.
lt
(
utils
.
parseEther
(
'
1
'
)
))
{
await
fundUser
(
watcher
,
l1Bridge
,
utils
.
parseEther
(
'
1
'
).
sub
(
balance
))
}
const
l1Messenger
=
getContractFactory
(
'
L1CrossDomainMessenger
'
)
.
connect
(
l1Wallet
)
...
...
integration-tests/test/shared/stress-test-helpers.ts
View file @
3c5fd4c3
...
...
@@ -71,7 +71,7 @@ export const executeL2ToL1Transaction = async (
),
MESSAGE_GAS
,
{
gasPrice
:
gasPriceForL2
(),
gasPrice
:
gasPriceForL2
(
env
),
}
)
)
...
...
@@ -90,7 +90,7 @@ export const executeL2Transaction = async (
tx
.
contract
.
connect
(
signer
)
.
functions
[
tx
.
functionName
](...
tx
.
functionParams
,
{
gasPrice
:
gasPriceForL2
(),
gasPrice
:
gasPriceForL2
(
env
),
})
)
await
result
.
wait
()
...
...
integration-tests/test/shared/utils.ts
View file @
3c5fd4c3
...
...
@@ -174,7 +174,12 @@ export const waitForL2Geth = async (
return
injectL2Context
(
provider
)
}
export
const
gasPriceForL2
=
async
()
=>
{
// eslint-disable-next-line @typescript-eslint/no-shadow
export
const
gasPriceForL2
=
async
(
env
:
OptimismEnv
)
=>
{
if
(
await
isMainnet
(
env
))
{
return
env
.
l2Wallet
.
getGasPrice
()
}
if
(
isLiveNetwork
())
{
return
Promise
.
resolve
(
BigNumber
.
from
(
10000
))
}
...
...
@@ -198,3 +203,9 @@ export const gasPriceForL1 = async (env: OptimismEnv) => {
return
BigNumber
.
from
(
0
)
}
}
// eslint-disable-next-line @typescript-eslint/no-shadow
export
const
isMainnet
=
async
(
env
:
OptimismEnv
)
=>
{
const
chainId
=
await
env
.
l1Wallet
.
getChainId
()
return
chainId
===
1
}
integration-tests/test/stress-tests.spec.ts
View file @
3c5fd4c3
...
...
@@ -17,7 +17,7 @@ import {
/* Imports: Artifacts */
import
simpleStorageJson
from
'
../artifacts/contracts/SimpleStorage.sol/SimpleStorage.json
'
import
{
fundUser
,
isLiveNetwork
}
from
'
./shared/utils
'
import
{
fundUser
,
isLiveNetwork
,
isMainnet
}
from
'
./shared/utils
'
// Need a big timeout to allow for all transactions to be processed.
// For some reason I can't figure out how to set the timeout on a per-suite basis
...
...
@@ -31,8 +31,13 @@ describe('stress tests', () => {
const
wallets
:
Wallet
[]
=
[]
before
(
async
()
=>
{
before
(
async
function
()
{
env
=
await
OptimismEnv
.
new
()
if
(
await
isMainnet
(
env
))
{
console
.
log
(
'
Skipping stress tests on mainnet.
'
)
this
.
skip
()
return
}
for
(
let
i
=
0
;
i
<
numTransactions
;
i
++
)
{
wallets
.
push
(
Wallet
.
createRandom
())
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment