mirror of
https://github.com/tornadocash/tornado-pool-factory
synced 2024-02-02 15:04:08 +01:00
TC-127 add proxy contracts
This commit is contained in:
parent
1d2105d8d8
commit
9d168730f2
@ -61,8 +61,10 @@ Check config.js for actual values.
|
|||||||
|
|
||||||
With `salt` = `0x0000000000000000000000000000000000000000000000000000000047941987` address must be:
|
With `salt` = `0x0000000000000000000000000000000000000000000000000000000047941987` address must be:
|
||||||
|
|
||||||
1. `MultipleInstanceFactory` - `0x49Be4c1dF49268066f97eD15fe4b4B90cc68d1A6`
|
1. `MultipleInstanceFactory` - `0x8a1BCFc608DdF6c4715277a24310B9E8ecc4c110`
|
||||||
2. `InstanceFactoryWithRegistry` - `0x7D4a76AF4b2d765D1D62Ac87Cc2aea0b7ECF6102`
|
2. `MultipleInstanceFactory proxy` - `0x0F9AE1d1ABbDd441B813ada0B038df130b2a6A86`
|
||||||
|
3. `InstanceFactoryWithRegistry` - `0x557fB18B66088728Ea975136de46714983aa4f2E`
|
||||||
|
4. `InstanceFactoryWithRegistry proxy` - `0x4D1b1c294dA4D14aC0e0Eed7BcD4Db3fe2bDe4C3`
|
||||||
|
|
||||||
Check addresses with current config:
|
Check addresses with current config:
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ module.exports = {
|
|||||||
compWhale: '0xF977814e90dA44bFA03b6295A0616a897441aceC',
|
compWhale: '0xF977814e90dA44bFA03b6295A0616a897441aceC',
|
||||||
creationFee: '200000000000000000000', // 200 TORN
|
creationFee: '200000000000000000000', // 200 TORN
|
||||||
deployGasLimit: 7000000,
|
deployGasLimit: 7000000,
|
||||||
owner: '0xBAE5aBfa98466Dbe68836763B087f2d189f4D28f',
|
admin: '0xBAE5aBfa98466Dbe68836763B087f2d189f4D28f', // TODO
|
||||||
WETH: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2',
|
WETH: '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2',
|
||||||
UniswapV3Factory: '0x1F98431c8aD98523631AE4a59f267346ea31F984',
|
UniswapV3Factory: '0x1F98431c8aD98523631AE4a59f267346ea31F984',
|
||||||
TWAPSlotsMin: 50,
|
TWAPSlotsMin: 50,
|
||||||
|
24
contracts/AdminUpgradeableProxy.sol
Normal file
24
contracts/AdminUpgradeableProxy.sol
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
pragma solidity 0.7.6;
|
||||||
|
|
||||||
|
import "@openzeppelin/contracts/proxy/TransparentUpgradeableProxy.sol";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev TransparentUpgradeableProxy where admin is allowed to call implementation methods.
|
||||||
|
*/
|
||||||
|
contract AdminUpgradeableProxy is TransparentUpgradeableProxy {
|
||||||
|
/**
|
||||||
|
* @dev Initializes an upgradeable proxy backed by the implementation at `_logic`.
|
||||||
|
*/
|
||||||
|
constructor(
|
||||||
|
address _logic,
|
||||||
|
address _admin,
|
||||||
|
bytes memory _data
|
||||||
|
) payable TransparentUpgradeableProxy(_logic, _admin, _data) {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dev Override to allow admin access the fallback function.
|
||||||
|
*/
|
||||||
|
function _beforeFallback() internal override {}
|
||||||
|
}
|
@ -3,15 +3,16 @@
|
|||||||
pragma solidity 0.7.6;
|
pragma solidity 0.7.6;
|
||||||
pragma abicoder v2;
|
pragma abicoder v2;
|
||||||
|
|
||||||
import { Ownable } from "@openzeppelin/contracts/access/Ownable.sol";
|
|
||||||
import { Address } from "@openzeppelin/contracts/utils/Address.sol";
|
import { Address } from "@openzeppelin/contracts/utils/Address.sol";
|
||||||
|
import { Initializable } from "@openzeppelin/contracts/proxy/Initializable.sol";
|
||||||
import "@openzeppelin/contracts/proxy/Clones.sol";
|
import "@openzeppelin/contracts/proxy/Clones.sol";
|
||||||
import "./ERC20TornadoCloneable.sol";
|
import "./ERC20TornadoCloneable.sol";
|
||||||
|
|
||||||
contract InstanceFactory is Ownable {
|
contract InstanceFactory is Initializable {
|
||||||
using Clones for address;
|
using Clones for address;
|
||||||
using Address for address;
|
using Address for address;
|
||||||
|
|
||||||
|
address public admin;
|
||||||
address public implementation;
|
address public implementation;
|
||||||
address public verifier;
|
address public verifier;
|
||||||
address public hasher;
|
address public hasher;
|
||||||
@ -21,20 +22,29 @@ contract InstanceFactory is Ownable {
|
|||||||
event NewImplementationSet(address indexed newImplemenentation, address verifier, address hasher);
|
event NewImplementationSet(address indexed newImplemenentation, address verifier, address hasher);
|
||||||
event NewInstanceCloneCreated(address indexed clone);
|
event NewInstanceCloneCreated(address indexed clone);
|
||||||
|
|
||||||
constructor(
|
modifier onlyAdmin() {
|
||||||
|
require(admin == msg.sender, "IF: caller is not the admin");
|
||||||
|
_;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notice initialize function for upgradeability
|
||||||
|
* @dev this contract will be deployed behind a proxy and should not assign values at logic address,
|
||||||
|
* params left out because self explainable
|
||||||
|
* */
|
||||||
|
function initialize(
|
||||||
address _verifier,
|
address _verifier,
|
||||||
address _hasher,
|
address _hasher,
|
||||||
uint32 _merkleTreeHeight,
|
uint32 _merkleTreeHeight,
|
||||||
address _owner
|
address _admin
|
||||||
) {
|
) public initializer {
|
||||||
verifier = _verifier;
|
verifier = _verifier;
|
||||||
hasher = _hasher;
|
hasher = _hasher;
|
||||||
merkleTreeHeight = _merkleTreeHeight;
|
merkleTreeHeight = _merkleTreeHeight;
|
||||||
|
admin = _admin;
|
||||||
|
|
||||||
ERC20TornadoCloneable implContract = new ERC20TornadoCloneable(_verifier, _hasher);
|
ERC20TornadoCloneable implContract = new ERC20TornadoCloneable(_verifier, _hasher);
|
||||||
implementation = address(implContract);
|
implementation = address(implContract);
|
||||||
|
|
||||||
transferOwnership(_owner);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -59,12 +69,12 @@ contract InstanceFactory is Ownable {
|
|||||||
return implementation.predictDeterministicAddress(salt);
|
return implementation.predictDeterministicAddress(salt);
|
||||||
}
|
}
|
||||||
|
|
||||||
function setMerkleTreeHeight(uint32 _merkleTreeHeight) external onlyOwner {
|
function setMerkleTreeHeight(uint32 _merkleTreeHeight) external onlyAdmin {
|
||||||
merkleTreeHeight = _merkleTreeHeight;
|
merkleTreeHeight = _merkleTreeHeight;
|
||||||
emit NewTreeHeightSet(merkleTreeHeight);
|
emit NewTreeHeightSet(merkleTreeHeight);
|
||||||
}
|
}
|
||||||
|
|
||||||
function generateNewImplementation(address _verifier, address _hasher) external onlyOwner {
|
function generateNewImplementation(address _verifier, address _hasher) external onlyAdmin {
|
||||||
verifier = _verifier;
|
verifier = _verifier;
|
||||||
hasher = _hasher;
|
hasher = _hasher;
|
||||||
implementation = address(new ERC20TornadoCloneable(_verifier, _hasher));
|
implementation = address(new ERC20TornadoCloneable(_verifier, _hasher));
|
||||||
|
@ -30,27 +30,38 @@ contract InstanceFactoryWithRegistry is InstanceFactory {
|
|||||||
* @dev Throws if called by any account other than the Governance.
|
* @dev Throws if called by any account other than the Governance.
|
||||||
*/
|
*/
|
||||||
modifier onlyGovernance() {
|
modifier onlyGovernance() {
|
||||||
require(owner() == _msgSender(), "Caller is not the Governance");
|
require(governance == msg.sender, "IF: caller is not the Governance");
|
||||||
_;
|
_;
|
||||||
}
|
}
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
address _verifier,
|
|
||||||
address _hasher,
|
|
||||||
uint32 _merkleTreeHeight,
|
|
||||||
address _governance,
|
address _governance,
|
||||||
address _instanceRegistry,
|
address _instanceRegistry,
|
||||||
address _torn,
|
address _torn,
|
||||||
address _UniswapV3Factory,
|
address _UniswapV3Factory,
|
||||||
address _WETH,
|
address _WETH
|
||||||
uint16 _TWAPSlotsMin,
|
) {
|
||||||
uint256 _creationFee
|
|
||||||
) InstanceFactory(_verifier, _hasher, _merkleTreeHeight, _governance) {
|
|
||||||
governance = _governance;
|
governance = _governance;
|
||||||
instanceRegistry = _instanceRegistry;
|
instanceRegistry = _instanceRegistry;
|
||||||
torn = _torn;
|
torn = _torn;
|
||||||
UniswapV3Factory = IUniswapV3Factory(_UniswapV3Factory);
|
UniswapV3Factory = IUniswapV3Factory(_UniswapV3Factory);
|
||||||
WETH = _WETH;
|
WETH = _WETH;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notice initialize function for upgradeability
|
||||||
|
* @dev this contract will be deployed behind a proxy and should not assign values at logic address,
|
||||||
|
* params left out because self explainable
|
||||||
|
* */
|
||||||
|
function initialize(
|
||||||
|
address _verifier,
|
||||||
|
address _hasher,
|
||||||
|
uint32 _merkleTreeHeight,
|
||||||
|
address _governance,
|
||||||
|
uint16 _TWAPSlotsMin,
|
||||||
|
uint256 _creationFee
|
||||||
|
) external initializer {
|
||||||
|
initialize(_verifier, _hasher, _merkleTreeHeight, _governance);
|
||||||
TWAPSlotsMin = _TWAPSlotsMin;
|
TWAPSlotsMin = _TWAPSlotsMin;
|
||||||
creationFee = _creationFee;
|
creationFee = _creationFee;
|
||||||
}
|
}
|
||||||
@ -140,12 +151,12 @@ contract InstanceFactoryWithRegistry is InstanceFactory {
|
|||||||
return proposal;
|
return proposal;
|
||||||
}
|
}
|
||||||
|
|
||||||
function setCreationFee(uint256 _creationFee) external onlyGovernance {
|
function setCreationFee(uint256 _creationFee) external onlyAdmin {
|
||||||
creationFee = _creationFee;
|
creationFee = _creationFee;
|
||||||
emit NewCreationFeeSet(_creationFee);
|
emit NewCreationFeeSet(_creationFee);
|
||||||
}
|
}
|
||||||
|
|
||||||
function setTWAPSlotsMin(uint16 _TWAPSlotsMin) external onlyGovernance {
|
function setTWAPSlotsMin(uint16 _TWAPSlotsMin) external onlyAdmin {
|
||||||
TWAPSlotsMin = _TWAPSlotsMin;
|
TWAPSlotsMin = _TWAPSlotsMin;
|
||||||
emit NewTWAPSlotsMinSet(_TWAPSlotsMin);
|
emit NewTWAPSlotsMinSet(_TWAPSlotsMin);
|
||||||
}
|
}
|
||||||
|
@ -5,13 +5,6 @@ pragma solidity 0.7.6;
|
|||||||
import "./InstanceFactory.sol";
|
import "./InstanceFactory.sol";
|
||||||
|
|
||||||
contract MultipleInstanceFactory is InstanceFactory {
|
contract MultipleInstanceFactory is InstanceFactory {
|
||||||
constructor(
|
|
||||||
address _verifier,
|
|
||||||
address _hasher,
|
|
||||||
uint32 _merkleTreeHeight,
|
|
||||||
address _owner
|
|
||||||
) InstanceFactory(_verifier, _hasher, _merkleTreeHeight, _owner) {}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Creates new Tornado instances.
|
* @dev Creates new Tornado instances.
|
||||||
* @param _token address of ERC20 token for a new instance
|
* @param _token address of ERC20 token for a new instance
|
||||||
|
@ -14,9 +14,13 @@ async function deploy({ address, bytecode, singletonFactory }) {
|
|||||||
async function main() {
|
async function main() {
|
||||||
const singletonFactory = await ethers.getContractAt('SingletonFactory', config.singletonFactory)
|
const singletonFactory = await ethers.getContractAt('SingletonFactory', config.singletonFactory)
|
||||||
const contracts = await generate()
|
const contracts = await generate()
|
||||||
await deploy({ ...contracts.factoryWithRegistryContract, singletonFactory })
|
await deploy({ ...contracts.factoryWithRegistryContract.implementation, singletonFactory })
|
||||||
|
await deploy({ ...contracts.factoryWithRegistryContract.proxy, singletonFactory })
|
||||||
console.log(
|
console.log(
|
||||||
`Instance factory with registry contract have been deployed on ${contracts.factoryWithRegistryContract.address} address`,
|
`Instance factory with registry contract have been deployed on ${contracts.factoryWithRegistryContract.implementation.address} address`,
|
||||||
|
)
|
||||||
|
console.log(
|
||||||
|
`Instance factory with registry proxy contract have been deployed on ${contracts.factoryWithRegistryContract.proxy.address} address`,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,9 +14,13 @@ async function deploy({ address, bytecode, singletonFactory }) {
|
|||||||
async function main() {
|
async function main() {
|
||||||
const singletonFactory = await ethers.getContractAt('SingletonFactory', config.singletonFactory)
|
const singletonFactory = await ethers.getContractAt('SingletonFactory', config.singletonFactory)
|
||||||
const contracts = await generate()
|
const contracts = await generate()
|
||||||
await deploy({ ...contracts.factoryContract, singletonFactory })
|
await deploy({ ...contracts.factoryContract.implementation, singletonFactory })
|
||||||
|
await deploy({ ...contracts.factoryContract.proxy, singletonFactory })
|
||||||
console.log(
|
console.log(
|
||||||
`MultipleInstanceFactory contract have been deployed on ${contracts.factoryContract.address} address`,
|
`MultipleInstanceFactory contract have been deployed on ${contracts.factoryContract.implementation.address} address`,
|
||||||
|
)
|
||||||
|
console.log(
|
||||||
|
`MultipleInstanceFactory proxy contract have been deployed on ${contracts.factoryContract.proxy.address} address`,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,55 +1,87 @@
|
|||||||
const { ethers } = require('hardhat')
|
const { ethers } = require('hardhat')
|
||||||
const defaultConfig = require('../config')
|
const defaultConfig = require('../config')
|
||||||
|
|
||||||
async function generate(config = defaultConfig) {
|
async function upgradableContract({ contractName, implConstructorArgs, proxyConstructorArgs, salt }) {
|
||||||
const FactoryFactory = await ethers.getContractFactory('MultipleInstanceFactory')
|
const Implementation = await ethers.getContractFactory(contractName)
|
||||||
const deploymentBytecodeFactory =
|
|
||||||
FactoryFactory.bytecode +
|
|
||||||
FactoryFactory.interface
|
|
||||||
.encodeDeploy([config.verifier, config.hasher, config.merkleTreeHeight, config.owner])
|
|
||||||
.slice(2)
|
|
||||||
|
|
||||||
const factoryAddress = ethers.utils.getCreate2Address(
|
const implementationBytecode =
|
||||||
config.singletonFactory,
|
Implementation.bytecode + Implementation.interface.encodeDeploy(implConstructorArgs).slice(2)
|
||||||
config.salt,
|
|
||||||
ethers.utils.keccak256(deploymentBytecodeFactory),
|
const implementationAddress = ethers.utils.getCreate2Address(
|
||||||
|
defaultConfig.singletonFactory,
|
||||||
|
salt,
|
||||||
|
ethers.utils.keccak256(implementationBytecode),
|
||||||
)
|
)
|
||||||
|
|
||||||
const FactoryWithRegistryFactory = await ethers.getContractFactory('InstanceFactoryWithRegistry')
|
const AdminUpgradeableProxy = await ethers.getContractFactory('AdminUpgradeableProxy')
|
||||||
const deploymentBytecodeFactoryWithRegistry =
|
const proxyConst = [implementationAddress, ...proxyConstructorArgs]
|
||||||
FactoryWithRegistryFactory.bytecode +
|
const proxyBytecode =
|
||||||
FactoryWithRegistryFactory.interface
|
AdminUpgradeableProxy.bytecode + AdminUpgradeableProxy.interface.encodeDeploy(proxyConst).slice(2)
|
||||||
.encodeDeploy([
|
|
||||||
|
const proxyAddress = ethers.utils.getCreate2Address(
|
||||||
|
defaultConfig.singletonFactory,
|
||||||
|
salt,
|
||||||
|
ethers.utils.keccak256(proxyBytecode),
|
||||||
|
)
|
||||||
|
|
||||||
|
return {
|
||||||
|
implementation: {
|
||||||
|
address: implementationAddress,
|
||||||
|
bytecode: implementationBytecode,
|
||||||
|
args: implConstructorArgs,
|
||||||
|
},
|
||||||
|
proxy: { address: proxyAddress, bytecode: proxyBytecode, args: proxyConst },
|
||||||
|
isProxy: true,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function generate(config = defaultConfig) {
|
||||||
|
// factory contract -----------------------------------------------
|
||||||
|
const FactoryFactory = await ethers.getContractFactory('MultipleInstanceFactory')
|
||||||
|
const FactoryInitData = FactoryFactory.interface.encodeFunctionData('initialize', [
|
||||||
config.verifier,
|
config.verifier,
|
||||||
config.hasher,
|
config.hasher,
|
||||||
config.merkleTreeHeight,
|
config.merkleTreeHeight,
|
||||||
|
config.admin,
|
||||||
|
])
|
||||||
|
|
||||||
|
const factoryContract = await upgradableContract({
|
||||||
|
contractName: 'MultipleInstanceFactory',
|
||||||
|
implConstructorArgs: [],
|
||||||
|
proxyConstructorArgs: [config.admin, FactoryInitData],
|
||||||
|
salt: config.salt,
|
||||||
|
})
|
||||||
|
|
||||||
|
// factory with registry contract ---------------------------------
|
||||||
|
const FactoryWithRegistryFactory = await ethers.getContractFactory('InstanceFactoryWithRegistry')
|
||||||
|
const FactoryWithRegistryInitData = FactoryWithRegistryFactory.interface.encodeFunctionData(
|
||||||
|
'initialize(address,address,uint32,address,uint16,uint256)',
|
||||||
|
[
|
||||||
|
config.verifier,
|
||||||
|
config.hasher,
|
||||||
|
config.merkleTreeHeight,
|
||||||
|
config.governance,
|
||||||
|
config.TWAPSlotsMin,
|
||||||
|
config.creationFee,
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
const factoryWithRegistryContract = await upgradableContract({
|
||||||
|
contractName: 'InstanceFactoryWithRegistry',
|
||||||
|
implConstructorArgs: [
|
||||||
config.governance,
|
config.governance,
|
||||||
config.instanceRegistry,
|
config.instanceRegistry,
|
||||||
config.TORN,
|
config.TORN,
|
||||||
config.UniswapV3Factory,
|
config.UniswapV3Factory,
|
||||||
config.WETH,
|
config.WETH,
|
||||||
config.TWAPSlotsMin,
|
],
|
||||||
config.creationFee,
|
proxyConstructorArgs: [config.governance, FactoryWithRegistryInitData],
|
||||||
])
|
salt: config.salt,
|
||||||
.slice(2)
|
})
|
||||||
|
|
||||||
const factoryWithRegistryAddress = ethers.utils.getCreate2Address(
|
|
||||||
config.singletonFactory,
|
|
||||||
config.salt,
|
|
||||||
ethers.utils.keccak256(deploymentBytecodeFactoryWithRegistry),
|
|
||||||
)
|
|
||||||
|
|
||||||
const result = {
|
const result = {
|
||||||
factoryContract: {
|
factoryContract,
|
||||||
address: factoryAddress,
|
factoryWithRegistryContract,
|
||||||
bytecode: deploymentBytecodeFactory,
|
|
||||||
isProxy: false,
|
|
||||||
},
|
|
||||||
factoryWithRegistryContract: {
|
|
||||||
address: factoryWithRegistryAddress,
|
|
||||||
bytecode: deploymentBytecodeFactoryWithRegistry,
|
|
||||||
isProxy: false,
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return result
|
return result
|
||||||
@ -57,8 +89,16 @@ async function generate(config = defaultConfig) {
|
|||||||
|
|
||||||
async function generateWithLog() {
|
async function generateWithLog() {
|
||||||
const contracts = await generate()
|
const contracts = await generate()
|
||||||
console.log('MultipleInstanceFactory contract: ', contracts.factoryContract.address)
|
console.log('MultipleInstanceFactory contract: ', contracts.factoryContract.implementation.address)
|
||||||
console.log('Instance factory with registry contract: ', contracts.factoryWithRegistryContract.address)
|
console.log('MultipleInstanceFactory proxy contract: ', contracts.factoryContract.proxy.address)
|
||||||
|
console.log(
|
||||||
|
'Instance factory with registry contract: ',
|
||||||
|
contracts.factoryWithRegistryContract.implementation.address,
|
||||||
|
)
|
||||||
|
console.log(
|
||||||
|
'Instance factory with registry proxy contract: ',
|
||||||
|
contracts.factoryWithRegistryContract.proxy.address,
|
||||||
|
)
|
||||||
return contracts
|
return contracts
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,14 +57,25 @@ describe('Instance Factory With Registry Tests', () => {
|
|||||||
config.singletonFactoryVerboseWrapper,
|
config.singletonFactoryVerboseWrapper,
|
||||||
)
|
)
|
||||||
const contracts = await generate()
|
const contracts = await generate()
|
||||||
if ((await ethers.provider.getCode(contracts.factoryWithRegistryContract.address)) == '0x') {
|
if (
|
||||||
await singletonFactory.deploy(contracts.factoryWithRegistryContract.bytecode, config.salt, {
|
(await ethers.provider.getCode(contracts.factoryWithRegistryContract.implementation.address)) == '0x'
|
||||||
|
) {
|
||||||
|
await singletonFactory.deploy(
|
||||||
|
contracts.factoryWithRegistryContract.implementation.bytecode,
|
||||||
|
config.salt,
|
||||||
|
{
|
||||||
|
gasLimit: config.deployGasLimit,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
}
|
||||||
|
if ((await ethers.provider.getCode(contracts.factoryWithRegistryContract.proxy.address)) == '0x') {
|
||||||
|
await singletonFactory.deploy(contracts.factoryWithRegistryContract.proxy.bytecode, config.salt, {
|
||||||
gasLimit: config.deployGasLimit,
|
gasLimit: config.deployGasLimit,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
const instanceFactory = await ethers.getContractAt(
|
const instanceFactory = await ethers.getContractAt(
|
||||||
'InstanceFactoryWithRegistry',
|
'InstanceFactoryWithRegistry',
|
||||||
contracts.factoryWithRegistryContract.address,
|
contracts.factoryWithRegistryContract.proxy.address,
|
||||||
)
|
)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
@ -14,10 +14,10 @@ describe('Multiple Instance Factory Tests', () => {
|
|||||||
async function fixture() {
|
async function fixture() {
|
||||||
const [sender, deployer] = await ethers.getSigners()
|
const [sender, deployer] = await ethers.getSigners()
|
||||||
|
|
||||||
const owner = await getSignerFromAddress(config.owner)
|
const owner = await getSignerFromAddress(config.admin)
|
||||||
|
|
||||||
await sender.sendTransaction({
|
await sender.sendTransaction({
|
||||||
to: config.owner,
|
to: config.admin,
|
||||||
value: ethers.utils.parseEther('1'),
|
value: ethers.utils.parseEther('1'),
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -34,14 +34,19 @@ describe('Multiple Instance Factory Tests', () => {
|
|||||||
config.singletonFactoryVerboseWrapper,
|
config.singletonFactoryVerboseWrapper,
|
||||||
)
|
)
|
||||||
const contracts = await generate()
|
const contracts = await generate()
|
||||||
if ((await ethers.provider.getCode(contracts.factoryContract.address)) == '0x') {
|
if ((await ethers.provider.getCode(contracts.factoryContract.implementation.address)) == '0x') {
|
||||||
await singletonFactory.deploy(contracts.factoryContract.bytecode, config.salt, {
|
await singletonFactory.deploy(contracts.factoryContract.implementation.bytecode, config.salt, {
|
||||||
|
gasLimit: config.deployGasLimit,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
if ((await ethers.provider.getCode(contracts.factoryContract.proxy.address)) == '0x') {
|
||||||
|
await singletonFactory.deploy(contracts.factoryContract.proxy.bytecode, config.salt, {
|
||||||
gasLimit: config.deployGasLimit,
|
gasLimit: config.deployGasLimit,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
const instanceFactory = await ethers.getContractAt(
|
const instanceFactory = await ethers.getContractAt(
|
||||||
'MultipleInstanceFactory',
|
'MultipleInstanceFactory',
|
||||||
contracts.factoryContract.address,
|
contracts.factoryContract.proxy.address,
|
||||||
)
|
)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
Loading…
Reference in New Issue
Block a user