UNPKG

@graphprotocol/graph-cli

Version:

CLI for building for and deploying to The Graph

800 lines (700 loc) • 33.9 kB
const codegen = require('.') describe('ethereum.Value -> AssemblyScript', () => { // Scalar values test('address -> Address', () => { expect(codegen.ethereumToAsc('x', 'address')).toBe('x.toAddress()') expect(codegen.ascTypeForEthereum('address')).toBe('Address') }) test('bool -> boolean', () => { expect(codegen.ethereumToAsc('x', 'bool')).toBe('x.toBoolean()') expect(codegen.ascTypeForEthereum('bool')).toBe('boolean') }) test('byte -> Bytes', () => { expect(codegen.ethereumToAsc('x', 'byte')).toBe('x.toBytes()') expect(codegen.ascTypeForEthereum('byte')).toBe('Bytes') }) test('bytes -> Bytes', () => { expect(codegen.ethereumToAsc('x', 'bytes')).toBe('x.toBytes()') expect(codegen.ascTypeForEthereum('bytes')).toBe('Bytes') }) test('bytes0 (invalid)', () => { expect(() => codegen.ethereumToAsc('x', 'bytes0')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes0')).toThrow() }) test('bytes1..32 -> Bytes', () => { for (let i = 1; i <= 32; i++) { expect(codegen.ethereumToAsc('x', `bytes${i}`)).toBe('x.toBytes()') expect(codegen.ascTypeForEthereum(`bytes${i}`)).toBe('Bytes') } }) test('bytes33 (invalid)', () => { expect(() => codegen.ethereumToAsc('x', 'bytes33')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes33')).toThrow() }) test('int8..32, uint8..uint24 -> i32', () => { for (let i = 8; i <= 32; i += 8) { expect(codegen.ethereumToAsc('x', `int${i}`)).toBe('x.toI32()') expect(codegen.ascTypeForEthereum(`int${i}`)).toBe('i32') } for (let i = 8; i <= 24; i += 8) { expect(codegen.ethereumToAsc('x', `uint${i}`)).toBe('x.toI32()') expect(codegen.ascTypeForEthereum(`uint${i}`)).toBe('i32') } }) test('uint32 -> BigInt', () => { expect(codegen.ethereumToAsc('x', `uint32`)).toBe('x.toBigInt()') expect(codegen.ascTypeForEthereum('uint32')).toBe('BigInt') }) test('(u)int40..256 -> BigInt', () => { for (let i = 40; i <= 256; i += 8) { expect(codegen.ethereumToAsc('x', `int${i}`)).toBe('x.toBigInt()') expect(codegen.ethereumToAsc('x', `uint${i}`)).toBe('x.toBigInt()') expect(codegen.ascTypeForEthereum(`int${i}`)).toBe('BigInt') expect(codegen.ascTypeForEthereum(`uint${i}`)).toBe('BigInt') } }) test('string -> String', () => { expect(codegen.ethereumToAsc('x', 'string')).toBe('x.toString()') expect(codegen.ascTypeForEthereum('string')).toBe('string') }) // Array values test('address[*] -> Array<Address>', () => { expect(codegen.ethereumToAsc('x', 'address[]')).toBe('x.toAddressArray()') expect(codegen.ethereumToAsc('x', 'address[1]')).toBe('x.toAddressArray()') expect(codegen.ethereumToAsc('x', 'address[123]')).toBe('x.toAddressArray()') expect(codegen.ascTypeForEthereum('address[]')).toBe('Array<Address>') expect(codegen.ascTypeForEthereum('address[1]')).toBe('Array<Address>') expect(codegen.ascTypeForEthereum('address[123]')).toBe('Array<Address>') }) test('bool[*] -> Array<boolean>', () => { expect(codegen.ethereumToAsc('x', 'bool[]')).toBe('x.toBooleanArray()') expect(codegen.ethereumToAsc('x', 'bool[5]')).toBe('x.toBooleanArray()') expect(codegen.ethereumToAsc('x', 'bool[275]')).toBe('x.toBooleanArray()') expect(codegen.ascTypeForEthereum('bool[]')).toBe('Array<boolean>') expect(codegen.ascTypeForEthereum('bool[5]')).toBe('Array<boolean>') expect(codegen.ascTypeForEthereum('bool[275]')).toBe('Array<boolean>') }) test('byte[*] -> Array<Bytes>', () => { expect(codegen.ethereumToAsc('x', 'byte[]')).toBe('x.toBytesArray()') expect(codegen.ethereumToAsc('x', 'byte[7]')).toBe('x.toBytesArray()') expect(codegen.ethereumToAsc('x', 'byte[553]')).toBe('x.toBytesArray()') expect(codegen.ascTypeForEthereum('byte[]')).toBe('Array<Bytes>') expect(codegen.ascTypeForEthereum('byte[7]')).toBe('Array<Bytes>') expect(codegen.ascTypeForEthereum('byte[553]')).toBe('Array<Bytes>') }) test('bytes[*] -> Array<Bytes>', () => { expect(codegen.ethereumToAsc('x', 'bytes[]')).toBe('x.toBytesArray()') expect(codegen.ethereumToAsc('x', 'bytes[14]')).toBe('x.toBytesArray()') expect(codegen.ethereumToAsc('x', 'bytes[444]')).toBe('x.toBytesArray()') expect(codegen.ascTypeForEthereum('bytes[]')).toBe('Array<Bytes>') expect(codegen.ascTypeForEthereum('bytes[14]')).toBe('Array<Bytes>') expect(codegen.ascTypeForEthereum('bytes[444]')).toBe('Array<Bytes>') }) test('bytes0[*] (invalid)', () => { expect(() => codegen.ethereumToAsc('x', 'bytes0[]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes0[83]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes0[123]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes0[]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes0[83]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes0[123]')).toThrow() }) test('bytes1..32[*] -> Array<Bytes>', () => { for (let i = 1; i <= 32; i++) { expect(codegen.ethereumToAsc('x', `bytes${i}[]`)).toBe('x.toBytesArray()') expect(codegen.ethereumToAsc('x', `bytes${i}[7]`)).toBe('x.toBytesArray()') expect(codegen.ethereumToAsc('x', `bytes${i}[432]`)).toBe('x.toBytesArray()') expect(codegen.ascTypeForEthereum(`bytes${i}[]`)).toBe('Array<Bytes>') expect(codegen.ascTypeForEthereum(`bytes${i}[7]`)).toBe('Array<Bytes>') expect(codegen.ascTypeForEthereum(`bytes${i}[432]`)).toBe('Array<Bytes>') } }) test('bytes33[*] (invalid)', () => { expect(() => codegen.ethereumToAsc('x', 'bytes33[]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes33[58]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes33[394]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes33[]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes33[58]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes33[394]')).toThrow() }) test('int8..32[*], uint8..24[*] -> Array<i32>', () => { for (let i = 8; i <= 32; i += 8) { expect(codegen.ethereumToAsc('x', `int${i}[]`)).toBe('x.toI32Array()') expect(codegen.ethereumToAsc('x', `int${i}[6]`)).toBe('x.toI32Array()') expect(codegen.ethereumToAsc('x', `int${i}[4638]`)).toBe('x.toI32Array()') expect(codegen.ascTypeForEthereum(`int${i}[]`)).toBe('Array<i32>') expect(codegen.ascTypeForEthereum(`int${i}[6]`)).toBe('Array<i32>') expect(codegen.ascTypeForEthereum(`int${i}[4638]`)).toBe('Array<i32>') } for (let i = 8; i <= 24; i += 8) { expect(codegen.ethereumToAsc('x', `uint${i}[]`)).toBe('x.toI32Array()') expect(codegen.ethereumToAsc('x', `uint${i}[6]`)).toBe('x.toI32Array()') expect(codegen.ethereumToAsc('x', `uint${i}[593]`)).toBe('x.toI32Array()') expect(codegen.ascTypeForEthereum(`uint${i}[]`)).toBe('Array<i32>') expect(codegen.ascTypeForEthereum(`uint${i}[6]`)).toBe('Array<i32>') expect(codegen.ascTypeForEthereum(`uint${i}[593]`)).toBe('Array<i32>') } }) test('uint32[*] -> Array<BigInt>', () => { expect(codegen.ethereumToAsc('x', `uint32[]`)).toBe('x.toBigIntArray()') expect(codegen.ethereumToAsc('x', `uint32[6]`)).toBe('x.toBigIntArray()') expect(codegen.ethereumToAsc('x', `uint32[593]`)).toBe('x.toBigIntArray()') expect(codegen.ascTypeForEthereum(`uint32[]`)).toBe('Array<BigInt>') expect(codegen.ascTypeForEthereum(`uint32[6]`)).toBe('Array<BigInt>') expect(codegen.ascTypeForEthereum(`uint32[593]`)).toBe('Array<BigInt>') }) test('(u)int40..256[*] -> Array<BigInt>', () => { for (let i = 40; i <= 256; i += 8) { expect(codegen.ethereumToAsc('x', `int${i}[]`)).toBe('x.toBigIntArray()') expect(codegen.ethereumToAsc('x', `int${i}[7]`)).toBe('x.toBigIntArray()') expect(codegen.ethereumToAsc('x', `int${i}[6833]`)).toBe('x.toBigIntArray()') expect(codegen.ascTypeForEthereum(`int${i}[]`)).toBe('Array<BigInt>') expect(codegen.ascTypeForEthereum(`int${i}[7]`)).toBe('Array<BigInt>') expect(codegen.ascTypeForEthereum(`int${i}[6833]`)).toBe('Array<BigInt>') expect(codegen.ethereumToAsc('x', `uint${i}[]`)).toBe('x.toBigIntArray()') expect(codegen.ethereumToAsc('x', `uint${i}[23]`)).toBe('x.toBigIntArray()') expect(codegen.ethereumToAsc('x', `uint${i}[467]`)).toBe('x.toBigIntArray()') expect(codegen.ascTypeForEthereum(`uint${i}[]`)).toBe('Array<BigInt>') expect(codegen.ascTypeForEthereum(`uint${i}[23]`)).toBe('Array<BigInt>') expect(codegen.ascTypeForEthereum(`uint${i}[467]`)).toBe('Array<BigInt>') } }) test('string[*] -> Array<string>', () => { expect(codegen.ethereumToAsc('x', 'string[]')).toBe('x.toStringArray()') expect(codegen.ethereumToAsc('x', 'string[4]')).toBe('x.toStringArray()') expect(codegen.ethereumToAsc('x', 'string[754]')).toBe('x.toStringArray()') expect(codegen.ascTypeForEthereum('string[]')).toBe('Array<string>') expect(codegen.ascTypeForEthereum('string[4]')).toBe('Array<string>') expect(codegen.ascTypeForEthereum('string[754]')).toBe('Array<string>') }) // Multi dimensional arrays test('address[*][*] -> Array<Array<Address>>', () => { expect(codegen.ethereumToAsc('x', 'address[][]')).toBe('x.toAddressMatrix()') expect(codegen.ethereumToAsc('x', 'address[5][]')).toBe('x.toAddressMatrix()') expect(codegen.ethereumToAsc('x', 'address[][4]')).toBe('x.toAddressMatrix()') expect(codegen.ethereumToAsc('x', 'address[1][2]')).toBe('x.toAddressMatrix()') expect(codegen.ethereumToAsc('x', 'address[123][321]')).toBe('x.toAddressMatrix()') expect(codegen.ascTypeForEthereum('address[][]')).toBe('Array<Array<Address>>') expect(codegen.ascTypeForEthereum('address[5][]')).toBe('Array<Array<Address>>') expect(codegen.ascTypeForEthereum('address[][4]')).toBe('Array<Array<Address>>') expect(codegen.ascTypeForEthereum('address[1][2]')).toBe('Array<Array<Address>>') expect(codegen.ascTypeForEthereum('address[123][321]')).toBe('Array<Array<Address>>') }) test('bool[*][*] -> Array<Array<boolean>>', () => { expect(codegen.ethereumToAsc('x', 'bool[][]')).toBe('x.toBooleanMatrix()') expect(codegen.ethereumToAsc('x', 'bool[1][]')).toBe('x.toBooleanMatrix()') expect(codegen.ethereumToAsc('x', 'bool[][3]')).toBe('x.toBooleanMatrix()') expect(codegen.ethereumToAsc('x', 'bool[5][2]')).toBe('x.toBooleanMatrix()') expect(codegen.ethereumToAsc('x', 'bool[275][572]')).toBe('x.toBooleanMatrix()') expect(codegen.ascTypeForEthereum('bool[][]')).toBe('Array<Array<boolean>>') expect(codegen.ascTypeForEthereum('bool[1][]')).toBe('Array<Array<boolean>>') expect(codegen.ascTypeForEthereum('bool[][3]')).toBe('Array<Array<boolean>>') expect(codegen.ascTypeForEthereum('bool[5][2]')).toBe('Array<Array<boolean>>') expect(codegen.ascTypeForEthereum('bool[275][572]')).toBe('Array<Array<boolean>>') }) test('byte[*][*] -> Array<Array<Bytes>>', () => { expect(codegen.ethereumToAsc('x', 'byte[][]')).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', 'byte[7][]')).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', 'byte[][8]')).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', 'byte[553][355]')).toBe('x.toBytesMatrix()') expect(codegen.ascTypeForEthereum('byte[][]')).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum('byte[7][]')).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum('byte[][8]')).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum('byte[553][355]')).toBe('Array<Array<Bytes>>') }) test('bytes[*][*] -> Array<Array<Bytes>>', () => { expect(codegen.ethereumToAsc('x', 'bytes[][]')).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', 'bytes[14][]')).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', 'bytes[][41]')).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', 'bytes[444][555]')).toBe('x.toBytesMatrix()') expect(codegen.ascTypeForEthereum('bytes[][]')).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum('bytes[14][]')).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum('bytes[][41]')).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum('bytes[444][555]')).toBe('Array<Array<Bytes>>') }) test('bytes0[*][*] (invalid)', () => { expect(() => codegen.ethereumToAsc('x', 'bytes0[][]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes0[83][]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes0[][83]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes0[123][321]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes0[][]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes0[83][]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes0[][83]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes0[123][321]')).toThrow() }) test('bytes1..32[*][*] -> Array<Array<Bytes>>', () => { for (let i = 1; i <= 32; i++) { expect(codegen.ethereumToAsc('x', `bytes${i}[][]`)).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', `bytes${i}[7][]`)).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', `bytes${i}[][7]`)).toBe('x.toBytesMatrix()') expect(codegen.ethereumToAsc('x', `bytes${i}[432][234]`)).toBe('x.toBytesMatrix()') expect(codegen.ascTypeForEthereum(`bytes${i}[][]`)).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum(`bytes${i}[6][]`)).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum(`bytes${i}[][7]`)).toBe('Array<Array<Bytes>>') expect(codegen.ascTypeForEthereum(`bytes${i}[432][234]`)).toBe('Array<Array<Bytes>>') } }) test('bytes33[*][*] (invalid)', () => { expect(() => codegen.ethereumToAsc('x', 'bytes33[][]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes33[58][]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes33[][85]')).toThrow() expect(() => codegen.ethereumToAsc('x', 'bytes33[394][493]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes33[][]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes33[58][]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes33[][85]')).toThrow() expect(() => codegen.ascTypeForEthereum('bytes33[394][493]')).toThrow() }) test('int8..32[*][*], uint8..24[*][*] -> Array<Array<i32>>', () => { for (let i = 8; i <= 32; i += 8) { expect(codegen.ethereumToAsc('x', `int${i}[][]`)).toBe('x.toI32Matrix()') expect(codegen.ethereumToAsc('x', `int${i}[6][]`)).toBe('x.toI32Matrix()') expect(codegen.ethereumToAsc('x', `int${i}[][6]`)).toBe('x.toI32Matrix()') expect(codegen.ethereumToAsc('x', `int${i}[4638][8364]`)).toBe('x.toI32Matrix()') expect(codegen.ascTypeForEthereum(`int${i}[][]`)).toBe('Array<Array<i32>>') expect(codegen.ascTypeForEthereum(`int${i}[6][]`)).toBe('Array<Array<i32>>') expect(codegen.ascTypeForEthereum(`int${i}[][6]`)).toBe('Array<Array<i32>>') expect(codegen.ascTypeForEthereum(`int${i}[4638][8364]`)).toBe('Array<Array<i32>>') } for (let i = 8; i <= 24; i += 8) { expect(codegen.ethereumToAsc('x', `uint${i}[][]`)).toBe('x.toI32Matrix()') expect(codegen.ethereumToAsc('x', `uint${i}[6][]`)).toBe('x.toI32Matrix()') expect(codegen.ethereumToAsc('x', `uint${i}[][6]`)).toBe('x.toI32Matrix()') expect(codegen.ethereumToAsc('x', `uint${i}[593][395]`)).toBe('x.toI32Matrix()') expect(codegen.ascTypeForEthereum(`uint${i}[][]`)).toBe('Array<Array<i32>>') expect(codegen.ascTypeForEthereum(`uint${i}[6][]`)).toBe('Array<Array<i32>>') expect(codegen.ascTypeForEthereum(`uint${i}[][6]`)).toBe('Array<Array<i32>>') expect(codegen.ascTypeForEthereum(`uint${i}[593][395]`)).toBe('Array<Array<i32>>') } }) test('uint32[*][*] -> Array<Array<BigInt>>', () => { expect(codegen.ethereumToAsc('x', `uint32[][]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `uint32[6][]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `uint32[][6]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `uint32[593][395]`)).toBe('x.toBigIntMatrix()') expect(codegen.ascTypeForEthereum(`uint32[][]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`uint32[6][]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`uint32[][5]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`uint32[593][395]`)).toBe('Array<Array<BigInt>>') }) test('(u)int40..256[*][*] -> Array<Array<BigInt>>', () => { for (let i = 40; i <= 256; i += 8) { expect(codegen.ethereumToAsc('x', `int${i}[][]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `int${i}[7][]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `int${i}[][7]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `int${i}[6833][3386]`)).toBe('x.toBigIntMatrix()') expect(codegen.ascTypeForEthereum(`int${i}[][]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`int${i}[7][]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`int${i}[][7]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`int${i}[6833][3386]`)).toBe('Array<Array<BigInt>>') expect(codegen.ethereumToAsc('x', `uint${i}[][]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `uint${i}[23][]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `uint${i}[][32]`)).toBe('x.toBigIntMatrix()') expect(codegen.ethereumToAsc('x', `uint${i}[467][764]`)).toBe('x.toBigIntMatrix()') expect(codegen.ascTypeForEthereum(`uint${i}[][]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`uint${i}[23][]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`uint${i}[][32]`)).toBe('Array<Array<BigInt>>') expect(codegen.ascTypeForEthereum(`uint${i}[467][764]`)).toBe('Array<Array<BigInt>>') } }) test('string[*][*] -> Array<Array<string>>', () => { expect(codegen.ethereumToAsc('x', 'string[][]')).toBe('x.toStringMatrix()') expect(codegen.ethereumToAsc('x', 'string[4][]')).toBe('x.toStringMatrix()') expect(codegen.ethereumToAsc('x', 'string[][3]')).toBe('x.toStringMatrix()') expect(codegen.ethereumToAsc('x', 'string[754][457]')).toBe('x.toStringMatrix()') expect(codegen.ascTypeForEthereum('string[][]')).toBe('Array<Array<string>>') expect(codegen.ascTypeForEthereum('string[4][]')).toBe('Array<Array<string>>') expect(codegen.ascTypeForEthereum('string[][3]')).toBe('Array<Array<string>>') expect(codegen.ascTypeForEthereum('string[754][457]')).toBe('Array<Array<string>>') }) }) describe('AssemblyScript -> ethereum.Value', () => { // Scalar values test('Address -> address', () => { expect(codegen.ethereumFromAsc('x', 'address')).toBe('ethereum.Value.fromAddress(x)') }) test('boolean -> bool', () => { expect(codegen.ethereumFromAsc('x', 'bool')).toBe('ethereum.Value.fromBoolean(x)') }) test('Bytes -> byte', () => { expect(codegen.ethereumFromAsc('x', 'byte')).toBe('ethereum.Value.fromFixedBytes(x)') }) test('Bytes -> bytes', () => { expect(codegen.ethereumFromAsc('x', 'bytes')).toBe('ethereum.Value.fromBytes(x)') }) test('Bytes -> bytes0 (invalid)', () => { expect(() => codegen.ethereumFromAsc('x', 'bytes0')).toThrow() }) test('Bytes -> bytes1..32', () => { for (let i = 1; i <= 32; i++) { expect(codegen.ethereumFromAsc('x', `bytes${i}`)).toBe( 'ethereum.Value.fromFixedBytes(x)', ) } }) test('Bytes -> bytes33 (invalid)', () => { expect(() => codegen.ethereumFromAsc('x', 'bytes33')).toThrow() }) test('i32 -> int8..32, uint8..24', () => { for (let i = 8; i <= 32; i += 8) { expect(codegen.ethereumFromAsc('x', `int${i}`)).toBe(`ethereum.Value.fromI32(x)`) } for (let i = 8; i <= 24; i += 8) { expect(codegen.ethereumFromAsc('x', `uint${i}`)).toBe( `ethereum.Value.fromUnsignedBigInt(BigInt.fromI32(x))`, ) } }) test('BigInt -> uint32', () => { expect(codegen.ethereumFromAsc('x', `uint32`)).toBe( `ethereum.Value.fromUnsignedBigInt(x)`, ) }) test('BigInt -> (u)int40..256', () => { for (let i = 40; i <= 256; i += 8) { expect(codegen.ethereumFromAsc('x', `int${i}`)).toBe( `ethereum.Value.fromSignedBigInt(x)`, ) expect(codegen.ethereumFromAsc('x', `uint${i}`)).toBe( `ethereum.Value.fromUnsignedBigInt(x)`, ) } }) test('String -> string', () => { expect(codegen.ethereumFromAsc('x', 'string')).toBe('ethereum.Value.fromString(x)') }) // Array values test('Array<Address> -> address[*]', () => { expect(codegen.ethereumFromAsc('x', 'address[]')).toBe( 'ethereum.Value.fromAddressArray(x)', ) expect(codegen.ethereumFromAsc('x', 'address[1]')).toBe( 'ethereum.Value.fromAddressArray(x)', ) expect(codegen.ethereumFromAsc('x', 'address[123]')).toBe( 'ethereum.Value.fromAddressArray(x)', ) }) test('Array<boolean> -> bool[*]', () => { expect(codegen.ethereumFromAsc('x', 'bool[]')).toBe( 'ethereum.Value.fromBooleanArray(x)', ) expect(codegen.ethereumFromAsc('x', 'bool[5]')).toBe( 'ethereum.Value.fromBooleanArray(x)', ) expect(codegen.ethereumFromAsc('x', 'bool[275]')).toBe( 'ethereum.Value.fromBooleanArray(x)', ) }) test('Array<Bytes> -> byte[*]', () => { expect(codegen.ethereumFromAsc('x', 'byte[]')).toBe( 'ethereum.Value.fromFixedBytesArray(x)', ) expect(codegen.ethereumFromAsc('x', 'byte[7]')).toBe( 'ethereum.Value.fromFixedBytesArray(x)', ) expect(codegen.ethereumFromAsc('x', 'byte[553]')).toBe( 'ethereum.Value.fromFixedBytesArray(x)', ) }) test('Array<Bytes> -> bytes[*]', () => { expect(codegen.ethereumFromAsc('x', 'bytes[]')).toBe( 'ethereum.Value.fromBytesArray(x)', ) expect(codegen.ethereumFromAsc('x', 'bytes[14]')).toBe( 'ethereum.Value.fromBytesArray(x)', ) expect(codegen.ethereumFromAsc('x', 'bytes[444]')).toBe( 'ethereum.Value.fromBytesArray(x)', ) }) test('bytes0[*] (invalid)', () => { expect(() => codegen.ethereumFromAsc('x', 'bytes0[]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes0[83]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes0[123]')).toThrow() }) test('Array<Bytes> -> bytes1..32[*]', () => { for (let i = 1; i <= 32; i++) { expect(codegen.ethereumFromAsc('x', `bytes${i}[]`)).toBe( 'ethereum.Value.fromFixedBytesArray(x)', ) expect(codegen.ethereumFromAsc('x', `bytes${i}[7]`)).toBe( 'ethereum.Value.fromFixedBytesArray(x)', ) expect(codegen.ethereumFromAsc('x', `bytes${i}[432]`)).toBe( 'ethereum.Value.fromFixedBytesArray(x)', ) } }) test('bytes33[*] (invalid)', () => { expect(() => codegen.ethereumFromAsc('x', 'bytes33[]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes33[58]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes33[394]')).toThrow() }) test('Array<i32> -> int8..32[*], uint8..24[*]', () => { for (let i = 8; i <= 32; i += 8) { expect(codegen.ethereumFromAsc('x', `int${i}[]`)).toBe( 'ethereum.Value.fromI32Array(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[6]`)).toBe( 'ethereum.Value.fromI32Array(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[4638]`)).toBe( 'ethereum.Value.fromI32Array(x)', ) } for (let i = 8; i <= 24; i += 8) { expect(codegen.ethereumFromAsc('x', `uint${i}[]`)).toBe( 'ethereum.Value.fromI32Array(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[6]`)).toBe( 'ethereum.Value.fromI32Array(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[593]`)).toBe( 'ethereum.Value.fromI32Array(x)', ) } }) test('Array<BigInt> -> uint32[*]', () => { expect(codegen.ethereumFromAsc('x', `uint32[]`)).toBe( 'ethereum.Value.fromUnsignedBigIntArray(x)', ) expect(codegen.ethereumFromAsc('x', `uint32[6]`)).toBe( 'ethereum.Value.fromUnsignedBigIntArray(x)', ) expect(codegen.ethereumFromAsc('x', `uint32[593]`)).toBe( 'ethereum.Value.fromUnsignedBigIntArray(x)', ) }) test('Array<BigInt> -> (u)int40..256[*]', () => { for (let i = 40; i <= 256; i += 8) { expect(codegen.ethereumFromAsc('x', `int${i}[]`)).toBe( 'ethereum.Value.fromSignedBigIntArray(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[7]`)).toBe( 'ethereum.Value.fromSignedBigIntArray(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[6833]`)).toBe( 'ethereum.Value.fromSignedBigIntArray(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[]`)).toBe( 'ethereum.Value.fromUnsignedBigIntArray(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[23]`)).toBe( 'ethereum.Value.fromUnsignedBigIntArray(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[467]`)).toBe( 'ethereum.Value.fromUnsignedBigIntArray(x)', ) } }) test('Array<String> -> string[*]', () => { expect(codegen.ethereumFromAsc('x', 'string[]')).toBe( 'ethereum.Value.fromStringArray(x)', ) expect(codegen.ethereumFromAsc('x', 'string[4]')).toBe( 'ethereum.Value.fromStringArray(x)', ) expect(codegen.ethereumFromAsc('x', 'string[754]')).toBe( 'ethereum.Value.fromStringArray(x)', ) }) // Multidimensional arrays test('Array<Array<Address>> -> address[*][*]', () => { expect(codegen.ethereumFromAsc('x', 'address[][]')).toBe( 'ethereum.Value.fromAddressMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'address[1][]')).toBe( 'ethereum.Value.fromAddressMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'address[][2]')).toBe( 'ethereum.Value.fromAddressMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'address[123][321]')).toBe( 'ethereum.Value.fromAddressMatrix(x)', ) }) test('Array<Array<boolean>> -> bool[*][*]', () => { expect(codegen.ethereumFromAsc('x', 'bool[][]')).toBe( 'ethereum.Value.fromBooleanMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'bool[5][]')).toBe( 'ethereum.Value.fromBooleanMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'bool[][5]')).toBe( 'ethereum.Value.fromBooleanMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'bool[275][572]')).toBe( 'ethereum.Value.fromBooleanMatrix(x)', ) }) test('Array<Array<Bytes>> -> byte[*][*]', () => { expect(codegen.ethereumFromAsc('x', 'byte[][]')).toBe( 'ethereum.Value.fromFixedBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'byte[7][]')).toBe( 'ethereum.Value.fromFixedBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'byte[][6]')).toBe( 'ethereum.Value.fromFixedBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'byte[553][355]')).toBe( 'ethereum.Value.fromFixedBytesMatrix(x)', ) }) test('Array<Array<Bytes>> -> bytes[*][*]', () => { expect(codegen.ethereumFromAsc('x', 'bytes[][]')).toBe( 'ethereum.Value.fromBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'bytes[14][]')).toBe( 'ethereum.Value.fromBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'bytes[][41]')).toBe( 'ethereum.Value.fromBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', 'bytes[444][333]')).toBe( 'ethereum.Value.fromBytesMatrix(x)', ) }) test('bytes0[*][*] (invalid)', () => { expect(() => codegen.ethereumFromAsc('x', 'bytes0[][]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes0[83][]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes0[][38]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes0[123][321]')).toThrow() }) test('Array<Array<Bytes>> -> bytes1..32[*][*]', () => { for (let i = 1; i <= 32; i++) { expect(codegen.ethereumFromAsc('x', `bytes${i}[][]`)).toBe( 'ethereum.Value.fromFixedBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `bytes${i}[7][]`)).toBe( 'ethereum.Value.fromFixedBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `bytes${i}[][7]`)).toBe( 'ethereum.Value.fromFixedBytesMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `bytes${i}[432][234]`)).toBe( 'ethereum.Value.fromFixedBytesMatrix(x)', ) } }) test('bytes33[*][*] (invalid)', () => { expect(() => codegen.ethereumFromAsc('x', 'bytes33[][]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes33[58][]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes33[][85]')).toThrow() expect(() => codegen.ethereumFromAsc('x', 'bytes33[394][493]')).toThrow() }) test('Array<Array<i32>> -> int8..32[*][*], uint8..24[*][*]', () => { for (let i = 8; i <= 32; i += 8) { expect(codegen.ethereumFromAsc('x', `int${i}[][]`)).toBe( 'ethereum.Value.fromI32Matrix(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[6][]`)).toBe( 'ethereum.Value.fromI32Matrix(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[][5]`)).toBe( 'ethereum.Value.fromI32Matrix(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[4638][8364]`)).toBe( 'ethereum.Value.fromI32Matrix(x)', ) } for (let i = 8; i <= 24; i += 8) { expect(codegen.ethereumFromAsc('x', `uint${i}[][]`)).toBe( 'ethereum.Value.fromI32Matrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[6][]`)).toBe( 'ethereum.Value.fromI32Matrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[][5]`)).toBe( 'ethereum.Value.fromI32Matrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[593][395]`)).toBe( 'ethereum.Value.fromI32Matrix(x)', ) } }) test('Array<Array<BigInt>> -> uint32[*][*]', () => { expect(codegen.ethereumFromAsc('x', `uint32[][]`)).toBe( 'ethereum.Value.fromUnsignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint32[6][]`)).toBe( 'ethereum.Value.fromUnsignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint32[][5]`)).toBe( 'ethereum.Value.fromUnsignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint32[593][395]`)).toBe( 'ethereum.Value.fromUnsignedBigIntMatrix(x)', ) }) test('Array<Array<BigInt>> -> (u)int40..256[*][*]', () => { for (let i = 40; i <= 256; i += 8) { expect(codegen.ethereumFromAsc('x', `int${i}[][]`)).toBe( 'ethereum.Value.fromSignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[8][]`)).toBe( 'ethereum.Value.fromSignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[][7]`)).toBe( 'ethereum.Value.fromSignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `int${i}[6833][3386]`)).toBe( 'ethereum.Value.fromSignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[][]`)).toBe( 'ethereum.Value.fromUnsignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[23][]`)).toBe( 'ethereum.Value.fromUnsignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[][32]`)).toBe( 'ethereum.Value.fromUnsignedBigIntMatrix(x)', ) expect(codegen.ethereumFromAsc('x', `uint${i}[467][764]`)).toBe( 'ethereum.Value.fromUnsignedBigIntMatrix(x)', ) } }) test('Array<Array<String>> -> string[*][*]', () => { expect(codegen.ethereumFromAsc('x', 'string[]')).toBe( 'ethereum.Value.fromStringArray(x)', ) expect(codegen.ethereumFromAsc('x', 'string[4]')).toBe( 'ethereum.Value.fromStringArray(x)', ) expect(codegen.ethereumFromAsc('x', 'string[754]')).toBe( 'ethereum.Value.fromStringArray(x)', ) }) }) describe('Value -> AssemblyScript', () => { test('BigDecimal -> BigDecimal', () => { expect(codegen.valueToAsc('x', 'BigDecimal')).toBe('x.toBigDecimal()') }) test('[BigDecimal] -> Array<BigDecimal>', () => { expect(codegen.valueToAsc('x', '[BigDecimal]')).toBe('x.toBigDecimalArray()') }) test('String -> string', () => { expect(codegen.valueToAsc('x', 'string')).toBe('x.toString()') }) test('[String] -> Array<string>', () => { expect(codegen.valueToAsc('x', '[String]')).toBe('x.toStringArray()') }) }) describe('AssemblyScript -> Value', () => { test('BigDecimal -> BigDecimal', () => { expect(codegen.valueFromAsc('x', 'BigDecimal')).toBe('Value.fromBigDecimal(x)') expect(codegen.valueTypeForAsc('BigDecimal')).toBe('BigDecimal') }) test('Array<BigDecimal> -> [BigDecimal]', () => { expect(codegen.valueFromAsc('x', '[BigDecimal]')).toBe('Value.fromBigDecimalArray(x)') expect(codegen.valueTypeForAsc('Array<BigDecimal>')).toBe('[BigDecimal]') }) test('string -> String', () => { expect(codegen.valueFromAsc('x', 'String')).toBe('Value.fromString(x)') expect(codegen.valueTypeForAsc('string')).toBe('String') }) test('Array<string> -> [String]', () => { expect(codegen.valueFromAsc('x', '[String]')).toBe('Value.fromStringArray(x)') expect(codegen.valueTypeForAsc('Array<string>')).toBe('[String]') }) })