Cadence Testing framework feedback #1330
-
I'm not sure which repo to put this in, so I figured I'd throw up a discussion! I'm really excited about the cadence testing framework, I've always been annoyed that I need to go through lots of other setup steps to get things like overflow and flow-js-testing to work. They aren't hard to do, but then I'm switching IDEs (I like jetbrains more than vs code for go and node). I also find it distracts and makes things harder to follow when you have to look through tests in one language, but the actual content I care about are the scripts. So all around it makes a lot of sense to me to focus on using and improving cadence's built-in testing I recently started giving the cadence testing framework a try, and have a number of feedback items that I think would make it much more useful. Originally it was a twitter thread but here are the items: Full VS Code support
Code CoverageI noticed that there is a flag for it, but it didn't work for me: Log statementsIt would be great to get all log statements to get printed with some flag when running these tests. As of now, I have to put in a line like this: Debug breakpoints would be great for this kind of iteration as well 🙂 Access to emitted events after running a transactionThis one is super important imo, I was trying to start using these tests in a contract I'm working on, but I found it really hard to make any resource in a transaction, then find what its ID was. Control of the backend system's clock for testing out long-term flows.I can't use this testing framework to verify any of Flowty's loan/rental systems because we time things based on the current block's timestamp. We need a way to fast forward so we can test those kinds of things Ability to reference contract typesIt would be fantastic to be able to reference the contract types I've defined in my contracts so I can return them in scripts. I wasn't able to get that to work but maybe I'm just not doing the right thing. If this is indeed not supported, only being able to use cadence "primitive" types (not sure the right term here) is pretty limiting. For instance, I'd like to be able to resolve MetadataViews to test for compliance with the NFT Catalog. I could do that in a script, I suppose, maybe that's the suggested approach? Run some function after every test, or a way to snapshot and restore stateBased on documentation, Individual test files with a shared setupThis could also just be me not knowing how to properly use this tool yet, but ideally I could define a |
Beta Was this translation helpful? Give feedback.
Replies: 9 comments 5 replies
-
Hey @austinkline 👋 Very nice write up and the feedback is indeed quite legitimate 👏 Regarding Regarding the feedback about the Cadence Testing Framework in general, we are also working on it as part of another grant proposal. Our starting point was the addition of new matchers, and we will continue with the rest of the ideas described here. Some of your ideas are already described in the original issue, and we'll try to cater to them to accommodate any use case 🙏 |
Beta Was this translation helpful? Give feedback.
-
Opened onflow/cadence-tools#102 and onflow/cadence-tools#103 to track the language server and test framework improvements. |
Beta Was this translation helpful? Give feedback.
-
Hey @austinkline , the latest flow-cli should fix the code coverage issue that you faced. |
Beta Was this translation helpful? Give feedback.
-
Adding another suggestion or issue I've run into, I'm sure it's an easy fix. Is there a way to get access to accounts defined in my flow config? I'm writing a test that needs to start by adding flow tokens to an account's balance, but I'm not seeing a way to get access to the right account to do that. Any ideas? |
Beta Was this translation helpful? Give feedback.
-
hey everyone, if you are using code coverage please spare few seconds of your time to fill this survey to help us make it more feature rich! https://forms.gle/Cw9kqh5JAAur4h6PA |
Beta Was this translation helpful? Give feedback.
-
HI @AmarildoGrembi - please feel free to share in discord as well! Thanks |
Beta Was this translation helpful? Give feedback.
-
Update: Regarding Full VS Code support: Regarding Code Coverage: Regarding Log statements: |
Beta Was this translation helpful? Give feedback.
-
Update: Regarding Individual test files with a shared setup: |
Beta Was this translation helpful? Give feedback.
-
Update: Regarding Run some function after every test, or a way to snapshot and restore state: Regarding Access to emitted events after running a transaction: Regarding Ability to reference contract types: |
Beta Was this translation helpful? Give feedback.
Update:
Regarding Run some function after every test, or a way to snapshot and restore state:
We have added the necessary
beforeEach
/afterEach
hooks and theblockchain.reset()
method: onflow/cadence-tools#128Regarding Access to emitted events after running a transaction:
We have added this functionality as well: onflow/cadence-tools#113
Regarding Ability to reference contract types:
We have added the ground work for this, we just need to figure out how to allow the import of these types in the test files. Probably we will need to phase the setup of the blockchain in a standalone step, preceding the tests execution.