mirror of
https://github.com/cerc-io/watcher-ts
synced 2025-01-23 19:49:06 +00:00
Tests for nested dynamic array.
This commit is contained in:
parent
7c4fef153e
commit
7d609f9a2b
@ -48,9 +48,9 @@ $ yarn test
|
|||||||
* [x] Dynamically-sized byte array
|
* [x] Dynamically-sized byte array
|
||||||
* [x] Struct Type
|
* [x] Struct Type
|
||||||
* [x] Mapping Type
|
* [x] Mapping Type
|
||||||
* [ ] Nested Arrays
|
* [x] Nested Arrays
|
||||||
* [x] Fixed size arrays
|
* [x] Fixed size arrays
|
||||||
* [ ] Dynamically-sized arrays
|
* [x] Dynamically-sized arrays
|
||||||
* [x] Dynamically-sized byte array
|
* [x] Dynamically-sized byte array
|
||||||
* [x] Bytes
|
* [x] Bytes
|
||||||
* [x] String
|
* [x] String
|
||||||
|
@ -710,6 +710,19 @@ describe('Get value from storage', () => {
|
|||||||
describe('nested arrays', () => {
|
describe('nested arrays', () => {
|
||||||
let testNestedArrays: Contract, storageLayout: StorageLayout;
|
let testNestedArrays: Contract, storageLayout: StorageLayout;
|
||||||
const nestedStructArray: Array<Array<{[key: string]: any}>> = [];
|
const nestedStructArray: Array<Array<{[key: string]: any}>> = [];
|
||||||
|
const nestedAddressArray: Array<Array<string>> = [];
|
||||||
|
|
||||||
|
const nestedFixedDynamicArray = [
|
||||||
|
[1, 2, 3].map(BigInt),
|
||||||
|
[4, 5, 6].map(BigInt)
|
||||||
|
];
|
||||||
|
|
||||||
|
const nestedDynamicArray = [
|
||||||
|
[1, 2, 3, 4].map(BigInt),
|
||||||
|
[5, 6].map(BigInt),
|
||||||
|
[7, 8, 9, 10, 11, 12].map(BigInt),
|
||||||
|
[13, 14, 15].map(BigInt)
|
||||||
|
];
|
||||||
|
|
||||||
before(async () => {
|
before(async () => {
|
||||||
const TestNestedArrays = await ethers.getContractFactory('TestNestedArrays');
|
const TestNestedArrays = await ethers.getContractFactory('TestNestedArrays');
|
||||||
@ -735,6 +748,18 @@ describe('Get value from storage', () => {
|
|||||||
await testNestedArrays.setNestedStructArray(i, j, value);
|
await testNestedArrays.setNestedStructArray(i, j, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Set value for nestedAddressArray.
|
||||||
|
for (let i = 0; i < 3; i++) {
|
||||||
|
nestedAddressArray[i] = signers.slice(i, i + 4).map(signer => signer.address.toLowerCase());
|
||||||
|
}
|
||||||
|
|
||||||
|
await testNestedArrays.setNestedAddressArray(nestedAddressArray);
|
||||||
|
|
||||||
|
// Set value for nested dynamic arrays
|
||||||
|
await testNestedArrays.setNestedFixedDynamicArray(nestedFixedDynamicArray);
|
||||||
|
await testNestedArrays.setNestedDynamicFixedArray(nestedDynamicArray);
|
||||||
|
await testNestedArrays.setNestedDynamicArray(nestedDynamicArray);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Get all elements of array.
|
// Get all elements of array.
|
||||||
@ -748,6 +773,40 @@ describe('Get value from storage', () => {
|
|||||||
expect(proofData[0]).to.have.all.keys(Object.keys(nestedStructArray[0]));
|
expect(proofData[0]).to.have.all.keys(Object.keys(nestedStructArray[0]));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('get value for fixed size nested array of address type', async () => {
|
||||||
|
const blockHash = await getBlockHash();
|
||||||
|
const { value, proof } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedAddressArray');
|
||||||
|
expect(value).to.eql(nestedAddressArray);
|
||||||
|
const proofData = JSON.parse(proof.data);
|
||||||
|
expect(proofData.length).to.equal(nestedAddressArray.length);
|
||||||
|
expect(proofData[0].length).to.equal(nestedAddressArray[0].length);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('get value for nested dynamic array of integer type', async () => {
|
||||||
|
const blockHash = await getBlockHash();
|
||||||
|
|
||||||
|
// Test for variable nestedFixedDynamicArray.
|
||||||
|
let { value, proof } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedFixedDynamicArray');
|
||||||
|
expect(value).to.eql(nestedFixedDynamicArray);
|
||||||
|
let proofData = JSON.parse(proof.data);
|
||||||
|
expect(proofData.length).to.equal(nestedFixedDynamicArray.length);
|
||||||
|
expect(proofData[0].length).to.equal(nestedFixedDynamicArray[0].length);
|
||||||
|
|
||||||
|
// Test for variable nestedFixedDynamicArray.
|
||||||
|
({ value, proof } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedDynamicFixedArray'));
|
||||||
|
expect(value).to.eql(nestedDynamicArray);
|
||||||
|
proofData = JSON.parse(proof.data);
|
||||||
|
expect(proofData.length).to.equal(nestedDynamicArray.length);
|
||||||
|
expect(proofData[0].length).to.equal(nestedDynamicArray[0].length);
|
||||||
|
|
||||||
|
// Test for variable nestedDynamicArray.
|
||||||
|
({ value, proof } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedDynamicArray'));
|
||||||
|
expect(value).to.eql(nestedDynamicArray);
|
||||||
|
proofData = JSON.parse(proof.data);
|
||||||
|
expect(proofData.length).to.equal(nestedDynamicArray.length);
|
||||||
|
expect(proofData[0].length).to.equal(nestedDynamicArray[0].length);
|
||||||
|
});
|
||||||
|
|
||||||
// Get element of array by index.
|
// Get element of array by index.
|
||||||
it('get value of fixed size struct type nested array by index', async () => {
|
it('get value of fixed size struct type nested array by index', async () => {
|
||||||
const arrayIndex = 2;
|
const arrayIndex = 2;
|
||||||
@ -760,6 +819,36 @@ describe('Get value from storage', () => {
|
|||||||
({ value } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedStructArray', arrayIndex, nestedArrayIndex, structMember));
|
({ value } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedStructArray', arrayIndex, nestedArrayIndex, structMember));
|
||||||
expect(value).to.equal(nestedStructArray[arrayIndex][nestedArrayIndex][structMember]);
|
expect(value).to.equal(nestedStructArray[arrayIndex][nestedArrayIndex][structMember]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('get value of fixed size address type nested array by index', async () => {
|
||||||
|
const arrayIndex = 2;
|
||||||
|
const nestedArrayIndex = 1;
|
||||||
|
const blockHash = await getBlockHash();
|
||||||
|
const { value } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedAddressArray', arrayIndex, nestedArrayIndex);
|
||||||
|
expect(value).to.eql(nestedAddressArray[arrayIndex][nestedArrayIndex]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('get value of dynamically sized nested array by index', async () => {
|
||||||
|
const blockHash = await getBlockHash();
|
||||||
|
|
||||||
|
// Test for variable nestedFixedDynamicArray.
|
||||||
|
let arrayIndex = 1;
|
||||||
|
let nestedArrayIndex = 2;
|
||||||
|
let { value } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedFixedDynamicArray', arrayIndex, nestedArrayIndex);
|
||||||
|
expect(value).to.eql(nestedFixedDynamicArray[arrayIndex][nestedArrayIndex]);
|
||||||
|
|
||||||
|
// Test for variable nestedDynamicFixedArray.
|
||||||
|
arrayIndex = 2;
|
||||||
|
nestedArrayIndex = 3;
|
||||||
|
({ value } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedDynamicFixedArray', arrayIndex, nestedArrayIndex));
|
||||||
|
expect(value).to.eql(nestedDynamicArray[arrayIndex][nestedArrayIndex]);
|
||||||
|
|
||||||
|
// Test for variable nestedDynamicArray.
|
||||||
|
arrayIndex = 3;
|
||||||
|
nestedArrayIndex = 2;
|
||||||
|
({ value } = await getStorageValue(storageLayout, getStorageAt, blockHash, testNestedArrays.address, 'nestedDynamicArray', arrayIndex, nestedArrayIndex));
|
||||||
|
expect(value).to.eql(nestedDynamicArray[arrayIndex][nestedArrayIndex]);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('structs with value type members', () => {
|
describe('structs with value type members', () => {
|
||||||
@ -945,7 +1034,8 @@ describe('Get value from storage', () => {
|
|||||||
let fixedArrayStruct: {[key: string]: any},
|
let fixedArrayStruct: {[key: string]: any},
|
||||||
bytesStruct: {[key: string]: any},
|
bytesStruct: {[key: string]: any},
|
||||||
stringStruct: {[key: string]: any},
|
stringStruct: {[key: string]: any},
|
||||||
nestedStruct: {[key: string]: any};
|
nestedStruct: {[key: string]: any},
|
||||||
|
dynamicArrayStruct: {[key: string]: any};
|
||||||
|
|
||||||
before(async () => {
|
before(async () => {
|
||||||
const TestReferenceStructs = await ethers.getContractFactory('TestReferenceStructs');
|
const TestReferenceStructs = await ethers.getContractFactory('TestReferenceStructs');
|
||||||
@ -980,6 +1070,11 @@ describe('Get value from storage', () => {
|
|||||||
bytesStruct,
|
bytesStruct,
|
||||||
address1: signers[3].address.toLowerCase()
|
address1: signers[3].address.toLowerCase()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
dynamicArrayStruct = {
|
||||||
|
address1: signers[4].address,
|
||||||
|
uintArray: [1, 2, 3, 4, 5].map(BigInt)
|
||||||
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
// Get all members of a struct.
|
// Get all members of a struct.
|
||||||
@ -1004,6 +1099,13 @@ describe('Get value from storage', () => {
|
|||||||
expect(value).to.eql(stringStruct);
|
expect(value).to.eql(stringStruct);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it.skip('get value for struct with dynamic array members', async () => {
|
||||||
|
await testReferenceStructs.setDynamicArrayStruct(dynamicArrayStruct);
|
||||||
|
const blockHash = await getBlockHash();
|
||||||
|
const { value } = await getStorageValue(storageLayout, getStorageAt, blockHash, testReferenceStructs.address, 'dynamicArrayStruct');
|
||||||
|
expect(value).to.eql(dynamicArrayStruct);
|
||||||
|
});
|
||||||
|
|
||||||
it('get value for nested struct with struct type members', async () => {
|
it('get value for nested struct with struct type members', async () => {
|
||||||
await testReferenceStructs.setNestedStruct(nestedStruct);
|
await testReferenceStructs.setNestedStruct(nestedStruct);
|
||||||
const blockHash = await getBlockHash();
|
const blockHash = await getBlockHash();
|
||||||
@ -1036,6 +1138,13 @@ describe('Get value from storage', () => {
|
|||||||
expect(value).to.eql(stringStruct[member]);
|
expect(value).to.eql(stringStruct[member]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it.skip('get value of dynamic array member in a struct', async () => {
|
||||||
|
const member = 'uintArray';
|
||||||
|
const blockHash = await getBlockHash();
|
||||||
|
const { value } = await getStorageValue(storageLayout, getStorageAt, blockHash, testReferenceStructs.address, 'dynamicArrayStruct', member);
|
||||||
|
expect(value).to.eql(dynamicArrayStruct[member]);
|
||||||
|
});
|
||||||
|
|
||||||
it('get value of mapping type member in a struct', async () => {
|
it('get value of mapping type member in a struct', async () => {
|
||||||
const [signer1, signer2] = await ethers.getSigners();
|
const [signer1, signer2] = await ethers.getSigners();
|
||||||
|
|
||||||
|
@ -5,6 +5,8 @@ pragma solidity ^0.7.6;
|
|||||||
pragma abicoder v2;
|
pragma abicoder v2;
|
||||||
|
|
||||||
contract TestNestedArrays {
|
contract TestNestedArrays {
|
||||||
|
address[4][3] nestedAddressArray;
|
||||||
|
|
||||||
struct TestStruct {
|
struct TestStruct {
|
||||||
uint256 uint1;
|
uint256 uint1;
|
||||||
address address1;
|
address address1;
|
||||||
@ -12,8 +14,34 @@ contract TestNestedArrays {
|
|||||||
|
|
||||||
TestStruct[3][5] nestedStructArray;
|
TestStruct[3][5] nestedStructArray;
|
||||||
|
|
||||||
|
int128[3][] nestedFixedDynamicArray;
|
||||||
|
|
||||||
|
uint32[][4] nestedDynamicFixedArray;
|
||||||
|
|
||||||
|
int64[][] nestedDynamicArray;
|
||||||
|
|
||||||
// Set variable nestedStructArray.
|
// Set variable nestedStructArray.
|
||||||
function setNestedStructArray(uint index, uint nestedIndex, TestStruct calldata value) external {
|
function setNestedStructArray(uint index, uint nestedIndex, TestStruct calldata value) external {
|
||||||
nestedStructArray[index][nestedIndex] = value;
|
nestedStructArray[index][nestedIndex] = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Set variable nestedAddressArray.
|
||||||
|
function setNestedAddressArray(address[4][3] calldata value) external {
|
||||||
|
nestedAddressArray = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set variable nestedFixedDynamicArray.
|
||||||
|
function setNestedFixedDynamicArray(int128[3][] calldata value) external {
|
||||||
|
nestedFixedDynamicArray = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set variable nestedDynamicFixedArray.
|
||||||
|
function setNestedDynamicFixedArray(uint32[][4] memory value) external {
|
||||||
|
nestedDynamicFixedArray = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set variable nestedDynamicArray.
|
||||||
|
function setNestedDynamicArray(int64[][] memory value) external {
|
||||||
|
nestedDynamicArray = value;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -32,6 +32,13 @@ contract TestReferenceStructs {
|
|||||||
|
|
||||||
StringStruct stringStruct;
|
StringStruct stringStruct;
|
||||||
|
|
||||||
|
struct DynamicArrayStruct {
|
||||||
|
address address1;
|
||||||
|
uint160[] uintArray;
|
||||||
|
}
|
||||||
|
|
||||||
|
DynamicArrayStruct dynamicArrayStruct;
|
||||||
|
|
||||||
struct ValueMappingStruct {
|
struct ValueMappingStruct {
|
||||||
mapping(uint => address) uintAddressMap;
|
mapping(uint => address) uintAddressMap;
|
||||||
uint32 uint1;
|
uint32 uint1;
|
||||||
@ -88,4 +95,9 @@ contract TestReferenceStructs {
|
|||||||
function setNestedStruct(NestedStruct calldata value) external {
|
function setNestedStruct(NestedStruct calldata value) external {
|
||||||
nestedStruct = value;
|
nestedStruct = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Set variable dynamicArrayStruct.
|
||||||
|
function setDynamicArrayStruct(DynamicArrayStruct calldata value) external {
|
||||||
|
dynamicArrayStruct = value;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user