-
Notifications
You must be signed in to change notification settings - Fork 81
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
CashScript debugger (@mainnet-pat's flipstarter) #172
Comments
pat, mathieu and I had a call today to discuss some of these things. pat has been working on integrating source mapping into the CashScript compiler. He's doing that by keeping track of the AST's Location data in the GenerateBytecodeTraversal. This sourcemap information is represented in the same format that Solidity uses for its source mapping and is included in the artifact output. To make it work for now, we're also adding a "unoptimised bytecode" output that will be used for debugging purposes, because it is much simpler to apply the source-mapping to that compared to the optimised bytecode. As an extension it may be interesting to make it work properly with optimised bytecode as well. To use this sourcemap, we also require a Libauth template to be exported from CashScript so that it can be evaluated through libauth (and combined with the sourcemap). This is related to #72 and #76. For now this will be implemented in the pat is also working on adding |
Mathieu and I did some refactoring and adding of tests today, both in the utils and the cashc packages. Next time, we want to refactor |
Today we refactored the Next time we want to continue looking at the compiler stuff (most of the other GenerateTargetTraversal code). After that we want to refactor |
Today we finished refactoring the Looking at the CashScript SDK code, some private properties of classes have been made public. I remember when pat walked us through the code, that this was because that data is required when building the libauth template. We should see if we can change the interface of that function so that it requires fewer public properties. But this is not incredibly important if we can't change it. We also noticed that there is a special case for the We also looked at the error messages generated when a transaction failed (see https://twitter.com/CashScriptBCH/status/1745102982255939640), and we should try to make the structure of this message easier to parse quickly (such as changing Maybe we should also add a function to export the built libauth template (similar to At some point we should probably try to make the |
Today we added an additional test that checks the compiled source map with our fixture source map. We noticed that the source map generation fixtures were not the same as what was being generated by the latest compiler. We spent a bunch of time debugging, but we have a good indication that the current version is correct. Next time we just want to go back a few commits in the past again to double check that the source map fixture for TransferWithTimeout was definitely incorrect. We also ran into a few other things:
|
We double checked that the initial source map fixture was incorrect / outdated, so the one that we replaced it with is correct. Today we also updated the console.log tests to include more edge cases. Here we noticed some weird behaviour on the JestExtensions file that we added a TODO for in the code. We can look into fixing that next time. We also solved the issue of multiline-style comments breaking the BitAuth IDE integration due to prematurely ending the "sourcemap" comments. Next time we want to also update the tests for require statement handling, and look at the JestExtensions stuff mentioned above. After that we want to add tests / fixtures for the full Libauth Template generation process. And the session after that we can finally get to refactoring the libauth template generation process. |
Today we double checked the require statement tests, which were mostly fine. Then we got started on defining fixtures for Libauth Template generation (mostly so we can be more confident when refactoring). During this process we found some small issues with the template generation that we fixed. There are still a few edge cases for which we want to add template generation fixtures, which we'll do next time + the aforementioned JestExtensions issues. After that we can get started on refactoring the libauth template generation. |
Today we added the remaining edge case fixtures for template generation. We probably want to support other hashtypes and signing algorithms in the future, but we decided to skip that for now, since we couldn't think of a very good use case that really needs that. After that, we implemented the fix that Pat sent us in telegram for an issue with if-else blocks. This turned out to affect some of the existing fixtures/tests, so we updated the fixtures, which were technically incorrect before. While debugging, we encountered an issue where failed Libauth template evaluation in Next time we want to start the refactor, and the PS: We're postponing dealing with the JestExtension stuff, since it's less important. |
Would you make a new @next release? |
Today we published the new next release and shared it in the compilers group - after quickly fixing some fixtures that we forgot to update last time. After this we looked into Sayoshi Nakamario's issue that he reported to Mathieu. In the end we asked him to create a reproduction repo so we can build a test case from it. Finally we made a start on adding tests for the JestExtensions functionality where we ran into some weirdness that we'll tackle next time - we wrote down the TODOs in the code. |
Today we looked at Sayoshi Nakamario's issue. It turns out that some of our fixes in 0.10.0-next.3 solved the issue. After this we expanded our debugging tests and added more JestExtensions tests. Most of these are still failing. We think this is because of a bug in the Next time we will try to make the tests succeed by finding and fixing those bugs. |
Today we fixed some bugs in the We also ran into new bugs with the require statement message handling for the final require statement case. For this we've created a list of new test cases we need to create. We've also implemented a likely fix, but we'll need to verify it with the new test cases once those are implemented. There is also still one outstanding issue with the JestExtensions, where the JestExtensions will pass a test that expects a failure, even when no failure occurs. We didn't have time to commit the require statement changes, so we want to do another session in the coming days to finish that and look at the final JestExtensions issue. |
Today we fixed the last remaining issues with require statement handling. We also expanded the test cases so now we're pretty confident that most edge cases are fully covered. We also moved all debugging related functionality into a new We also figured out the issue with the JestExtensions bug, but didn't have the time to fully implement a fix, so I'll do that early next week and then also release a new prerelease version. |
I just did the last fixes to the JestExtensions and published a new |
Noticed 2 issues while testing
edit: 2nd issue was on my end. However during testing I aslo noticed an issue with SigChecks not throwing the correct error |
Today we fixed the first issue mentioned by @mr-zwets above - we now index on lockingBytecode rather than address. Then we wrote tests for an issue that @mr-zwets had run into where signature checks that failed the NULLFAIL rule did not display custom require messages. We then fixed this issue (so now it still displays the require message when a signature check fails the NULLFAIL rule). While we were working on that issue we noticed some issues with the template generation regarding signatures:
We decided to tackle these issues while working on the Libauth template generation refactor, since we didn't want to touch just those parts. We made a start on the overall refactor and plan to continue next time (we documented our progress with TODO comments in the WIP code). |
Today we refactored the generation of
If we want to we can then tackle the other signature template related todos that are mentioned in the comment above. We also still want to tackle some other new functionality, most importantly, we still want to log the specific require statement (which line), even when users don't specify a custom error message. There also might be some other TODOs sprinkled in the code that we should look at. Before releasing the full new version, we also need to make some docs changes:
|
today we almost finished the refactoring, but we still need to push the final changes to In the past weeks we also ran into some more issues that we want to fix before full release:
|
here's a proposed checklist for 0.10.0-next.5
for 0.10.0-next.6
for the full v0.10.0
go over any and all TODOs left in the code before releasing v0.10.0
for future extensions
|
We essentially finished all of the big refactoring. We encountered some issues with Libauth not fully supporting P2SH32 in the We cut a new Note about multiple input handling / advanced transaction builder: Earlier we mentioned that we're not sure how multiple inputs can be tested at once, since there can only be one However, we noticed that our scenarios do support P2PKH inputs, which are evaluated separately. So it does seem like it's possible to evaluate multiple inputs using multiple scripts. We will need to look into this further. |
Today we looked into a bug with require message handling that Mathieu found. This was caused by an incorrect instruction pointer due to removal of the final verify statement in the bytecode generation. We tried to move the "final verify remove" code out of the main bytecode generation process and into the static optimisation process (so that the debugging tooling uses the code without the final VERIFY removed). However, this turned out to be very hard if not impossible, due to the fact that we need to remove the final VERIFY for every function, and we lose the function / AST context once we reach the static optimisation stage of compiling. We've scheduled another session this week to fix the issue in a different way. |
Today we finally solved the require message handling edge case that Mathieu found. We also tried to reproduce the mocknet timelock issue, but couldn't reproduce it. Next time we'll need to fix the console.log internals so that |
Today we fixed the two bugs with One bug we fixed was that The other bug was that We also updated the tests so this functionality is properly tested. We also removed cashproof as a devDependency and updated the developer docs on how to run cashproof. We made a start towards logging specific require statements (line numbers) even when these statements don't use a custom message. We'll finish that work next time. |
Today we finished the work towards logging specific require statements (line numbers) even when those statements don't use custom messages. We've also updated some of the error handling and transaction sending code to work better with this new functionality. And we've made some changes to the artifact naming. While working on this, we found an existing bug that likely has something to do with incorrect handling of CHECKDATASIG. We have a failing test case for this and will look at it later. Finally we released a version 0.10.0-next.6 with the recent changes included. |
Today we fixed the failing HodlVault test (which was just due to incorrect test logic). Then we added a new test for P2SH20 template generation, and decided not to add one for token introspection, since that has no impact on the template generation and is already properly tested in the template evaluation tests. We also ran into a bug with the Finally, we updated the JestExtensions so that they can be imported from Next time we'll continue with the other points on the checklist a few messages up. |
Today we double checked that all thrown errors were instances of Error, and not literal strings etc. While doing so we ran into a few other smaller issues that we solved along the way. Afterwards we cleaned up the Transaction Finally we went over some TODOs and moved some of them into the checklist above. Next time, we'll continue ticking off small issues on the checklist. |
Today we added support for multiple P2PKH inputs (with custom signing parameters). After that we added tests for non-require transaction evaluation errors (e.g. invalid OP_SPLIT range or invalid input index). We then started to enhance the "non-require" transaction errors to also display a line number and failing statement text. This is mostly working, but there are still a few edge cases remaining that we need to tackle. And we need to update all tests to match the new error messages. |
Today we updated all e2e tests for the new error messages (including failing statement). While doing that we also fixed a bug that the failing tests showed us. Next time we'll still need to update all of the debugging tests with more extensive error message tests, and then continue the rest of the checklist. |
Today we extended our debugging tests to also include the expected failing statement. We upgraded libauth to add a multisig debugging test. We also fixed some export syntax that was causing failing examples. We then cleaned up / merged the location mapping code in Errors.ts, and got started on making sure multiline errors also display a proper "failing statement". We'll have to continue this next time. |
Today we added support and tests for multiline failing statements and fixed some PositionHint bugs. Next session we can hopefully go over all TODOs + either fix them or decide to delay them until a 0.10.x release. We'll also go over the docs, and plan to release either later this week or next week if possible. |
Today we went over the remaining Debugging TODOs and moved most of them over to be done in future a 0.10.x release. We also did some final fixes:
Next time we want to double check that the updated VS Code extension works and we want to go over the final documentation updates. And then release v0.10.0. |
Today we released v0.10.0 🥳 We went over all the docs to improve documentation, list the breaking changes. With this milestone we can close this issue 'CashScript debugger (mainnet-pat's flipstarter)' Thanks again @mainnet-pat for the initiative and significant contributions. 🙏 We have created a separate todo list for other refactors we might still want to do later. 👍 |
@mainnet-pat is working on a debugger for CashScript. For this he is making certain changes to the CashScript compiler and SDK. We'll use this issue to document the progress on that.
This issue is related (and solves) the following long-standing issues as well:
#72
#76
The text was updated successfully, but these errors were encountered: