A mini-review of Amazon Q
A mini-review of Amazon Q

A mini-review of Amazon Q

I tried Amazon Q Developer, Amazon's answer to Copilot and, so far, the results are "meh."

If you're using AWS, it's a great tool for asking specific questions, such as "What were the top three highest-cost services in Q1?" or a variety of other useful things, such as listing your lambda functions. Rather than just tell you how to do things, it gives answers immediately. For those not familiar with AWS, it's a great tool.

It also has a command line tool, named q, appropriately enough, allowing me to use the AI from the command line, figuring out those tricky command line problems that I'm always forgetting the exact syntax to. It worked decently, but the interface confused me at first and I accidentally ran a destructive git command. Fortunately, it was in a throwaway codebase.

But it's the code generation I wanted to know about. It integrates well with VS Code and supports many common languages. I ran it through a few Python examples, using standard "fibonacci" variations I often use and it was very fast. The fibonacci functions always returned the correct answers, but at one point, it built a "cached" version that threw away the cache between function calls. Still, I'm used to this, so it wasn't worse than most other AI code support tools.

Then I turned to the big test. I have a personal project Python/Typescript/React project that I've been building. Next up in my TODO list was the ability to upload PDF documents. I asked Amazon Q to add "tabs" to one component so I could switch from typing in a note to uploading a PDF. The code that it wrote worked fine, but it told me to run this command:

npm install @radix-ui/react-tabs 

That seems fine, but I used the @workspace command and it should have told me to add this to my frontend/package.json file instead and use docker compose build frontend to install that component.

After I got past that, I wanted it to write the backend code for me. That should be in my backend/routes/documents.py file, where I handle CRUD, but it first suggested a separate upload.py file. However, what really annoyed me is that even though it can "see" the libraries I'm using and how my code interacts with the database, it insisted upon hard-coding SQL in the function rather than using sqlalchemy, as the rest of my code does.

After working with Amazon Q for a while, I noticed that pattern holding: it would quickly generate functioning code, using the current file as context, but ignoring the standards established in the rest of the codebase. You have to be vigilant for that and issue follow-up prompts accordingly, or manually fix things.

Now that ChatGPT offers projects, I've seen the same pattern (though I have to upload files). For Anthropic's Claude, it mostly just does what I mean.

Claude still wins.

As with ChatGPT projects, I still have to upload files for Claude, but I've written some scripts which autogenerate smaller files to upload, focusing just on the parts of the codebase I want to change. It's still an annoying workflow, not as easy to use as Amazon Q or Copilot, but the quality is good enough that I've been sticking with it.

submitted by /u/OvidPerl
[link] [comments]