Amazon Q Developer Tips: No.21 Amazon Q Developer Agents - /test
Published Dec 21, 2024
Reading time 5 minutes
In this series I will be sharing daily hints and tips to help you get ahead and start to accelerate you on your own journey with Amazon Q Developer. Each day I will share a new tip, categorised against a few themes and topics. If you have your own tips or your own experiences with tips I share, please use the comment feature or feel free to contact me directly. Check out the previous tips here.
Ok, time for today’s tip….
Tip 21 - Amazon Q Developer Agents : /test
Amazon Q Developer provides a number of tools for developers to use. /test is a new addition that was announced at re:Invent 2024, that will help you when adding tests to your project.
/test
You can ask Amazon Q Developer Agents to generate tests for you. You first have to open the code you want to add tests to, and then can test specific code/functions (highlighting the code and then using the IDE menu integration (see below), or add tests for the whole file using /test.
When invoking /test from the chat interface, you can (optionally) provide the names of the functions/classes you want to add tests for - the default behaviour is to add tests for all of these in the current open file in your editor. This is the equivalent of highlighting a code block and then using the integrated menu option (see below).
You cannot provide additional context to steer the direction of the tests.
The UI will show you a progress bar, and then show you the generated test code which you can review and then accept.
Running tests
One thing I have found is that running tests will typically fail, and I am able to fix these by:
- installing additional dependencies - whilst the test cases are generated, you will need to install additional libraries to run the tests. You can use Amazon Q Developer to help you here.
- adding init.py files - if you are running Python tests, I have found that you need to add init.py to your current project (at each relevant directory) to avoid the tests not failing (when using PyTest)
IDE menu integration
You can invoke /test from within the actual file you are editing to, as a new option has been added to the menu integration. After right clicking, you will see the new option “Generate Tests”.
The actual workflow then reverts to the standard /test workflow.
Influencing test libraries
Pytest and unittest (Python) and JUnit and Mockito (Java) are the only currently supported testing frameworks that /test supports. In my testing, it seems that PyTest tends to be the default option (a good choice in my view).
If you want to influence the use of one over the other, then I have found the way to do this is to:
- Create a tests folder in your current project (if you do not have one)
- Create a test file for the project file you want to add tests to - for example, tests_xxx if xxx is the name of the file you are adding tests for.
- Add a single import statement (for example, “import unittest”) and then save the file.
When you then run /test, the tests generated will be for this library. I put together a quick video to show you this in action.
{% youtube 1OcMXuX5KQ4 %}
Things to know about
I have spent only a little time getting to know how /test works, probably the least of the new features. Here are some initial thoughts on things to think about that I discovered when testing this out (sorry, pun intended!):
-
need to have your code open in the editor - you cannot run /test unless you have the code you want to provide tests for open in the editor. This means that you can only generate tests per file of your projects, and will need to repeat this process for each function within your project
-
click on the “View Diff” button to review the code - in previous versions of the Amazon Q Developer plugin, clicking on the files that are generated when the agent has completed would automatically bring up the code diff. This behaviour has changed now, and you need to click on the “View Diff” button to see the actual code.
-
Java and Python only - currently you can only use this feature if your codebase is Java or Python
-
adding extra information in the /test prompt will generate failures - if you add some additional information in the prompt after /test, you might see the following error occur
- counts towards your service quota - as per the other agents, using this consumes one of your allocated quota for the month
Further reading When it comes to testing in the generative AI era, I cannot recommend enough my colleague Danilo’s blog post, Beyond Traditional Testing: Addressing the Challenges of Non-Deterministic Software
Try Amazon Q Developer today, and claim your free Builder ID
That’s it for today’s tip. Let me know how you get on with this tip, and if you have your own drop me a message or reply. I would love to feature them here.
You can try Amazon Q Developer for free today, by signing up for a Builder ID. You can also check out my other posts on community.aws, as I have been sharing a lot of tips and use cases of how I am using Amazon Q Developer. You can also keep up to date with all the new features and improvements of Amazon Q Developer by checking out the changelog.
Made with ♥ from DevRel