Skip to content

Commit

Permalink
Update EOF validation test for top-level containers
Browse files Browse the repository at this point in the history
- Update tests because of the validation rule change: top-level
  containers must not have truncated data.
- Fix some expected error messages.
- Change ">=Prague" to "Prague" because not supported in retesteth.
  • Loading branch information
chfast authored and winsvega committed Aug 20, 2024
1 parent ecccd61 commit fd26aad
Show file tree
Hide file tree
Showing 6 changed files with 147 additions and 140 deletions.
15 changes: 8 additions & 7 deletions EOFTests/efExample/validInvalid.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,13 @@
"validInvalid" : {
"_info" : {
"comment" : "Test various examples to see if they are valid or invalid.\nImplements\n EOF1I0001 check that EOF1 with a bad magic number fails\n EOF1I0002 check that EOF1 with a bad version number fails\n EOF1I0003 check that EOF1 with a bad section order fails\n EOF1I0004 check that EOF1 missing a section fails\n EOF1I0005 check that EOF1 with a bad end of sections number fails\n EOF1I0006 check that EOF1 with too many or too few bytes fails\n EOF1I0007 check that EOF1 with a malformed code section fails\n EOF1I0008 check that EOF1 with an illegal opcode fails\n EOF1I0009 check that EOF1 with the wrong maxStackDepth fails\n EOF1I0010 check that return values are not allowed on section 0\n EOF1I0011 check that function calls to code sections that don't exist fail\n EOF1I0012 check that code sections that cause stack underflow fail\n EOF1I0013 check that we can't return more values than we declare\n EOF1I0014 check that code that looks deeper in the stack than the parameters fails\n EOF1I0015 check that code that uses removed opcodes fails\n EOF1I0016 check that code that uses new relative jumps to outside the section fails\n EOF1I0017 check that parameters are not allowed on section 0\n EOF1I0018 inconsistent number of code sections (between types and code)\n EOF1I0019 check that jumps into the middle on an opcode are not allowed\n EOF1I0020 check that you can't get to the same opcode with two different stack heights\n EOF1I0022 stack underflow caused by a function call\n EOF1I0023 sections with unreachable code fail\n EOF1I0024 sections that end with a non-terminator opcode fail\n EOF1I0025 data stack height of 1024 is invalid\n EOF1V0001 check that simple valid EOF1 deploys\n EOF1V0002 check that valid EOF1 with two code sections deploys\n EOF1V0003 check that valid EOF1 with four code sections deploys\n EOF1V0004 check that valid EOF1 can include 0xFE, the designated invalid opcode\n EOF1V0005 check that EOF1 with the right maxStackDepth deploys\n EOF1V0006 check that return values are allowed on code sections that aren't zero\n EOF1V0007 check that function calls to code sections that exist are allowed\n EOF1V0008 check that code that uses a new style relative jump (5C) succeeds\n EOF1V0009 check that parameters are allowed on code sections that aren't zero\n EOF1V0010 parameters are part of the max stack height\n EOF1V0011 check that code that uses a new style conditional jump (5D) succeeds\n EOF1V0012 return values on code sections affect maxStackHeight of the caller\n EOF1V0013 jump tables work\n EOF1V0014 sections that end with a legit terminating opcode are OK\n EOF1V0015 data stack height of 1023 is valid\n EOF1V0016 check that data section size can be less than the declared size\n",
"filling-rpc-server" : "evmone-t8n 0.12.0-dev+commit.8202c81e",
"filling-tool-version" : "retesteth-0.3.2-cancun+commit.a7cdb586.Linux.g++",
"generatedTestHash" : "c62a0385dff27dfa283e037ddc2299ce1ecaa2932061306af3a7191c4dfa5f86",
"lllcversion" : "Error getting LLLC Version",
"solidity" : "Version: 0.8.25+commit.b61c2a91.Linux.g++",
"filling-rpc-server" : "evmone-t8n 0.12.0-dev+commit.a373fd24.dirty",
"filling-tool-version" : "retesteth-0.3.2-cancun+commit.2ab0208e.Linux.g++",
"generatedTestHash" : "052fb1a9a3cac0ac296d356a662fff92975ac57e179cac6dfc19b7974a12f91f",
"lllcversion" : "Version: 0.5.14-develop.2022.6.30+commit.401d5358.mod.Linux.g++",
"solidity" : "Version: 0.8.21-develop.2023.7.19+commit.d9974bed.Linux.g++",
"source" : "src/EOFTestsFiller/efExample/validInvalidFiller.yml",
"sourceHash" : "0eb24a7a7ffb551c5816d2986e04ef73171870f7facaafb8bb91da89bb3a20a3"
"sourceHash" : "786b2f755b615dde19027f85d44160e8644964e13b64ea936fe1cbb3caf0b4ed"
},
"vectors" : {
"validInvalid_0" : {
Expand All @@ -23,7 +23,8 @@
"code" : "0xef0001010004020001000304000400008000013050000bad",
"results" : {
"Prague" : {
"result" : true
"exception" : "EOFException.TOPLEVEL_CONTAINER_TRUNCATED",
"result" : false
}
}
},
Expand Down
15 changes: 8 additions & 7 deletions EOFTests/efValidation/EOF1_embedded_container_.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,13 @@
"EOF1_embedded_container" : {
"_info" : {
"comment" : "",
"filling-rpc-server" : "evmone-t8n 0.12.0-dev+commit.d935077c",
"filling-tool-version" : "retesteth-0.3.2-cancun+commit.cf90baf3.Linux.g++",
"generatedTestHash" : "5743ae583913c61eb7fdfa60eba3682c7867a2575212fa32ec16a0f0a9dac1fc",
"lllcversion" : "Version: 0.5.14-develop.2023.7.11+commit.c58ab2c6.mod.Linux.g++",
"solidity" : "Version: 0.8.21+commit.d9974bed.Linux.g++",
"filling-rpc-server" : "evmone-t8n 0.12.0-dev+commit.81c7b531",
"filling-tool-version" : "retesteth-0.3.2-cancun+commit.2ab0208e.Linux.g++",
"generatedTestHash" : "bfba10a0c6e91753cd7263483bc2e057eb14789d31a52bb02b6f1ff8022d72bc",
"lllcversion" : "Version: 0.5.14-develop.2022.6.30+commit.401d5358.mod.Linux.g++",
"solidity" : "Version: 0.8.21-develop.2023.7.19+commit.d9974bed.Linux.g++",
"source" : "src/EOFTestsFiller/efValidation/EOF1_embedded_container_Copier.json",
"sourceHash" : "d30f7961069e10c8d3c81afb4216ad9796e8a29fa695200b05da97da5a4eea45"
"sourceHash" : "83df9720ea2e43fe20e391360195abbf152e4f048f35d7ecde5cc1d5d31d28b2"
},
"vectors" : {
"EOF1_embedded_container_0" : {
Expand All @@ -23,7 +23,8 @@
"code" : "0xef00010100040200010006030001001404000200008000016000e0000000ef000101000402000100010400000000800000fe",
"results" : {
"Prague" : {
"result" : true
"exception" : "err: toplevel_container_truncated",
"result" : false
}
}
},
Expand Down
17 changes: 9 additions & 8 deletions EOFTests/ori/validInvalid.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,13 @@
"validInvalid" : {
"_info" : {
"comment" : "Ori Pomerantz [email protected]\nImplements EOF1I0001, EOF1I0002, EOF1I0003, EOF1I0004, EOF1I0005,\nEOF1I0006, EOF1I0007, EOF1I0008, EOF1I0009, EOF1I0010,\nEOF1I0011, EOF1I0012, EOF1I0013, EOF1I0014, EOF1I0015,\nEOF1I0016, EOF1I0017, EOF1I0018, EOF1I0019, EOF1I0020,\nEOF1I0021, EOF1I0022, EOF1I0023, EOF1I0024, EOF1I0025,\nEOF1V0001, EOF1V0002, EOF1V0003, EOF1V0004, EOF1V0005,\nEOF1V0006, EOF1V0007, EOF1V0008, EOF1V0009, EOF1V0010,\nEOF1V0011, EOF1V0012, EOF1V0013, EOF1V0014, EOF1V0015\n",
"filling-rpc-server" : "evmone-t8n 0.12.0-dev+commit.14ba7529",
"filling-tool-version" : "retesteth-0.3.2-cancun+commit.9d793abd.Linux.g++",
"generatedTestHash" : "42a674b5b1d41a51050ca56d5e2924a22edcd0e4f8b251913bfc7bb34c5d1457",
"lllcversion" : "Version: 0.5.14-develop.2022.4.6+commit.401d5358.Linux.g++",
"solidity" : "Version: 0.8.18-develop.2023.1.16+commit.469d6d4d.Linux.g++",
"filling-rpc-server" : "evmone-t8n 0.12.0-dev+commit.81c7b531",
"filling-tool-version" : "retesteth-0.3.2-cancun+commit.2ab0208e.Linux.g++",
"generatedTestHash" : "3bdf7b4e07835b5d5414caf875e8c0b9afa3f520a81cad6897ad744568a65615",
"lllcversion" : "Version: 0.5.14-develop.2022.6.30+commit.401d5358.mod.Linux.g++",
"solidity" : "Version: 0.8.21-develop.2023.7.19+commit.d9974bed.Linux.g++",
"source" : "src/EOFTestsFiller/ori/validInvalidFiller.yml",
"sourceHash" : "f4594e906050a1a0e30a17822dbb83cd4382fc613a1a7dac7f6b97360ba2e903"
"sourceHash" : "76f0170e2ea08e6c977203e5d9ea2175b3518811dbc8e188da410edfcd70f3c6"
},
"vectors" : {
"validInvalid_0" : {
Expand Down Expand Up @@ -399,7 +399,8 @@
"code" : "0xef000101000402000100030400060000800001305000ef",
"results" : {
"Prague" : {
"result" : true
"exception" : "err: toplevel_container_truncated",
"result" : false
}
}
},
Expand Down Expand Up @@ -667,7 +668,7 @@
"code" : "0xef000101000302000100030400010000800001305000ef",
"results" : {
"Prague" : {
"exception" : "EOF_InvalidSectionBodiesSize",
"exception" : "EOF_InvalidTypeSectionSize",
"result" : false
}
}
Expand Down
Loading

0 comments on commit fd26aad

Please sign in to comment.