Tests for nested dynamic array.

This commit is contained in:
nikugogoi 2021-06-16 17:42:51 +05:30 committed by Ashwin Phatak
parent 7c4fef153e
commit 7d609f9a2b
4 changed files with 152 additions and 3 deletions

View File

@ -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

View File

@ -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();

View File

@ -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;
}
} }

View File

@ -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;
}
} }