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:
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
Full Stack Leader | Husband and Dad | a bard in bitspace
4moAbi 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.
Helping engineering teams remove testing bottlenecks with Agentic User Testing. Inventor of Developer Experience Testing & Agentic User Testing
4moGreat findings! Happy to be in the world of AI testing for devs 😁
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.
4moGreat 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?
Geek god (or at least a minor deity)
5moMaybe "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.
Software Engineer
5moThey *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.