123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- const { ethers } = require('hardhat');
- const { expect } = require('chai');
- module.exports = function shouldBehaveLikeClone() {
- const assertProxyInitialization = function ({ value, balance }) {
- it('initializes the proxy', async function () {
- const dummy = await ethers.getContractAt('DummyImplementation', this.proxy);
- expect(await dummy.value()).to.equal(value);
- });
- it('has expected balance', async function () {
- expect(await ethers.provider.getBalance(this.proxy)).to.equal(balance);
- });
- };
- describe('initialization without parameters', function () {
- describe('non payable', function () {
- const expectedInitializedValue = 10n;
- beforeEach(async function () {
- this.initializeData = await this.implementation.interface.encodeFunctionData('initializeNonPayable');
- });
- describe('when not sending balance', function () {
- beforeEach('creating proxy', async function () {
- this.proxy = await this.createClone(this.initializeData);
- });
- assertProxyInitialization({
- value: expectedInitializedValue,
- balance: 0,
- });
- });
- describe('when sending some balance', function () {
- const value = 10n ** 6n;
- it('reverts', async function () {
- await expect(this.createClone(this.initializeData, { value })).to.be.reverted;
- });
- });
- });
- describe('payable', function () {
- const expectedInitializedValue = 100n;
- beforeEach(async function () {
- this.initializeData = await this.implementation.interface.encodeFunctionData('initializePayable');
- });
- describe('when not sending balance', function () {
- beforeEach('creating proxy', async function () {
- this.proxy = await this.createClone(this.initializeData);
- });
- assertProxyInitialization({
- value: expectedInitializedValue,
- balance: 0,
- });
- });
- describe('when sending some balance', function () {
- const value = 10n ** 6n;
- beforeEach('creating proxy', async function () {
- this.proxy = await this.createClone(this.initializeData, { value });
- });
- assertProxyInitialization({
- value: expectedInitializedValue,
- balance: value,
- });
- });
- });
- });
- describe('initialization with parameters', function () {
- describe('non payable', function () {
- const expectedInitializedValue = 10n;
- beforeEach(async function () {
- this.initializeData = await this.implementation.interface.encodeFunctionData('initializeNonPayableWithValue', [
- expectedInitializedValue,
- ]);
- });
- describe('when not sending balance', function () {
- beforeEach('creating proxy', async function () {
- this.proxy = await this.createClone(this.initializeData);
- });
- assertProxyInitialization({
- value: expectedInitializedValue,
- balance: 0,
- });
- });
- describe('when sending some balance', function () {
- const value = 10n ** 6n;
- it('reverts', async function () {
- await expect(this.createClone(this.initializeData, { value })).to.be.reverted;
- });
- });
- });
- describe('payable', function () {
- const expectedInitializedValue = 42n;
- beforeEach(function () {
- this.initializeData = this.implementation.interface.encodeFunctionData('initializePayableWithValue', [
- expectedInitializedValue,
- ]);
- });
- describe('when not sending balance', function () {
- beforeEach('creating proxy', async function () {
- this.proxy = await this.createClone(this.initializeData);
- });
- assertProxyInitialization({
- value: expectedInitializedValue,
- balance: 0,
- });
- });
- describe('when sending some balance', function () {
- const value = 10n ** 6n;
- beforeEach('creating proxy', async function () {
- this.proxy = await this.createClone(this.initializeData, { value });
- });
- assertProxyInitialization({
- value: expectedInitializedValue,
- balance: value,
- });
- });
- });
- });
- };
|