How do developers want to use AI tools?

How do developers want to use AI tools?

This is the latest issue of my newsletter. Each week I cover the latest research and perspectives on developer productivity. Subscribe to get future issues.


This week I read Towards Effective AI Support for Developers: A Survey of Desires and Concerns from Microsoft. In this paper, researchers sought to understand how developers view AI, how they want to use it, and what their top concerns are in adopting it. 

Google recently released a similar paper where they looked into how developers want to work with AI. While Google's findings were more general (“developers want AI tools to support simpler tasks and reduce toil”), Microsoft's paper is more specific. Also, Google's paper talks about how they decide where to use AI tools within the company—Microsoft's paper doesn't cover their approach to this.

My summary of the paper 

This paper shares the results from a study with nearly 800 developers at Microsoft. The survey excluded any developers directly working on AI-based tools.  

What developers are most interested in using AI for

The survey included the question, “Which of the following aspects of your job would you most like to see AI tools help with?” Developers could select up to 3 items from the provided list of 17 response options. 

Most developers (96%) want AI to help with routine tasks such as generating tests or writing documentation. 37% of developers want AI to simplify administrative overhead tasks, such as email parsing and task management.  

The top use case that Microsoft developers want AI tools for is to generate unit, integration, and functional tests. This makes sense: testing is valuable, but it’s not always the most exciting part of the job. Using AI for this task would, in theory, not just alleviate some of the monotony but could also result in higher-quality tests. 

The other most common task developers want AI for is to analyze code for defects, vulnerabilities, and optimizations. This kind of work can be repetitive, and having AI check code might give developers more confidence in their results.

Writing documentation was also a common use case developers want help with. While developers emphasized that AI-generated documentation shouldn’t be blindly trusted—it's important to review and edit for accuracy—these tools can take care of some of the more tedious aspects of the task. 

Each of the top four tasks that developers are interested in using AI for are focused on helping them with work that is necessary but repetitive or undifferentiated. This fits with what Google’s study found—that developers want AI to reduce toil but not take away from the most rewarding parts of their job. That might explain why “writing new code or refactoring existing code” was slightly lower on the list, with 25% of respondents choosing it as a desired use case. Those who did choose "writing new code and/or refactoring existing code" as a desired use case wanted AI tools to help reduce the time spent on boilerplate code.

The researchers note that tenure didn’t make that much of a difference in which items were selected. The only exceptions were “evaluating performance to help identify areas of growth” and "clarifying requirements,” which were both more commonly chosen by developers with fewer years of experience versus more senior developers. 

Apprehensions developers have with using AI tools

To understand why developers might not adopt AI tools, the researchers included this question in their survey: “What worries you the most about integrating AI into your daily workflows?” They provided a list of options that developers could choose from. 

The biggest concern developers have with AI tools is that they can be more gimmicky than helpful. This matches what we found in our State of DevEx report: leaders might be overly optimistic about AI tools, while developers aren’t as impressed. It's important for AI tools to be technologically advanced, but it's equally crucial for those introducing them to be transparent about what these tools can really do.

Many developers also worry that AI could deteriorate the quality of their work. As one study participant said, “I am worried that AI will create answers that give the appearance of correctness, but are not actually correct.” This underscores the need for transparency from AI tools and also highlights the importance of human oversight. 

Another study exploring the barriers to AI adoption similarly found that “limited capabilities relative to expectations” was a top reason why these tools don’t get the expected levels of adoption. That study also found that a fear of decreased skills, potential judgement from peers, and not having a culture of sharing inhibited AI adoption. 

Author recommendations

This survey surfaced a few themes related to the need for transparency, education, and humans being in the loop. The authors leave with a few specific recommendations to improve AI tool adoption:

  • Help teams understand how AI models work and how AI tools can be applied to existing technologies. Equip leaders with the skills needed to guide their teams through these changes. Bootcamps, online courses, and workshops are great formats for this.
  • Be clear about which AI tools are being used and what they’re meant to do.
  • Instead of relying entirely on AI, find a balance where humans stay involved, especially for critical tasks. 

Final thoughts

This paper advances the conversation about how organizations can get the most out of their investments in tools like Copilot. One common challenge is figuring out the best ways to use these tools—this paper provides helpful insights on what those use cases might be. It also explores other reasons why an organization might not see the adoption they were expecting.


Who’s hiring right now

Here is a roundup of Developer Productivity job openings. Find more open roles here.


That’s it for this week. Thanks for reading.

-Abi

Randy Brown

Full Stack Leader | Husband and Dad | a bard in bitspace

4mo

Abi Noda do you have any insight into why generating tests for written code took off but generating code to pass written tests didn’t? I was using copilot for the inverse scenario of seemingly everyone else for a while and i am curious how one is preferred to the other.

Like
Reply
Ian Jennings

Helping engineering teams remove testing bottlenecks with Agentic User Testing. Inventor of Developer Experience Testing & Agentic User Testing

4mo

Great findings! Happy to be in the world of AI testing for devs 😁

Matt Johnston

GitKraken CEO. 30M+ developers from 100K orgs use our DevEx platform. Nike, Netflix, NASA… Apple, AmEx, Amazon… they use our great stuff to build their great stuff.

4mo

Great read, Abi, thanks for sharing. It’ll be veryinteresting to see what type of indicator or predictor this is for the adoption of AI-powered tools by less technical professions. Do developers just have a better view of risk versus reward of adopting AI in 2024? Or is there another reason?

Like
Reply
Kunal Kandekar

Geek god (or at least a minor deity)

5mo

Maybe "limited capabilities relative to expectations" would not have been an issue if people hadn't created such a hype about "replacing software engineers!" and "destroying jobs!" GenAI is insanely good, but it is still a tool with serious limitations. People need to learn how to work with it, just like any sophisticated tool.

They *are* more gimmicky than practical. Stop talking to me about adopting AI — instead, give me the best tools and infrastructure regardless of whether it’s buzzword-compliant, and support my efforts with clear priorities, transparency about the ways my software adds value, and relentless removal of friction in the process.

To view or add a comment, sign in

Insights from the community

Others also viewed

Explore topics