GitLab Duo Chat best practices
When prompting GitLab Duo Chat with questions, keep the following best practices in mind.
Have a conversation
Treat chats like conversations, not search forms. Start with a search-like question, then follow up with related questions to refine the scope. Build context through back-and-forth.
For example, you might ask:
c# start project best practices
Then follow up with:
Please show the project structure for the C# project.
Refine the prompt
For better responses, provide more context up front. Think through the full scope of what you need help with and include it in one prompt.
How can I get started creating an empty C# console application in VS Code?
Please show a .gitignore and .gitlab-ci.yml configuration with steps for C#,
and add security scanning for GitLab.
Follow prompt patterns
Structure prompts as problem statement, request for help, then add specificity. Don't feel you must ask everything up front.
I need to fulfill compliance requirements. How can I get started with Codeowners and approval rules?
Then ask:
Please show an example for Codeowners with different teams: backend, frontend, release managers.
Use low-context communication
Even if code is selected, provide context as if none is visible. Be specific on factors like language, framework, and requirements.
When implementing a pure virtual function in an inherited C++ class,
should I use virtual function override, or just function override?
Repeat yourself
Try rephrasing a question if you get an unexpected or strange response. Add more context.
How can I get started creating an C# application in VS Code?
Follow up with:
How can I get started creating an empty C# console application in VS Code?
Be patient
Avoid yes/no questions. Start general, then provide specifics as needed.
Explain labels in GitLab. Provide an example for efficient usage with issue boards.
Reset when needed
Use /reset
if Chat gets stuck on a wrong track. Start fresh.
Refine slash command prompts
Go beyond the basic slash command. Use them with more specific suggestions.
/refactor into a multi-line written string. Show different approaches for all C++ standards.
Or:
Please show the project structure for the C# project.
```0
## Related topics
- GitLab Duo Chat best practices [blog post](https://about.gitlab.com/blog/2024/04/02/10-best-practices-for-using-ai-powered-gitlab-duo-chat/)
- [Videos on how to use Chat](https://www.youtube.com/playlist?list=PL05JrBw4t0Kp5uj_JgQiSvHw1jQu0mSVZ)
- [Request a GitLab Duo Chat learning session](https://gitlab.com/groups/gitlab-com/marketing/developer-relations/-/epics/476)