One of the key challenges in the Agile development lifecycle is defining User Stories with the right level of detail. During refinement phases, stories can range from being overly generic and high-level to fully detailed and actionable. This variability often leads to inefficiencies and inconsistencies in backlog management.

By leveraging a workflow of Generative AI agents capable of interacting with Jira's APIs (tools), we can automate backlog creation and refinement. These agents process requirements, enrich them with best practices, and interact directly with Jira to generate and organize backlog items. The workflow is designed to:

  • Break down requirements into structured Epics and User Stories.
  • Suggests stories in a structured and formalized format.
  • Seamlessly interface with Jira to update or query backlog items dynamically.

In this article we see how CrewAI framework can be used to reach this goal, it is a cutting-edge platform designed to orchestrate autonomous AI agents, enabling them to collaborate effectively on complex tasks.

Key components of CrewAI include:

  • Agents: Autonomous units with specific roles, expertise, and responsibilities. Each agent can perform tasks, utilize tools, and collaborate with other agents to achieve shared objectives.
  • Tasks Defined objectives assigned to agents, which can be executed sequentially or in parallel. Tasks are the building blocks of the workflow, guiding agents on what needs to be accomplished.
  • Tools Integrated functionalities that agents can employ to interact with external systems, such as APIs. For instance, agents can use tools to interface with Jira's API, enabling operations like creating issues or retrieving data.
  • Crews A crew in crewAI represents a collaborative group of agents working together to achieve a set of tasks. Each crew defines the strategy for task execution, agent collaboration, and the overall workflow.

By defining these components, CrewAI facilitates the creation of AI teams where each agent has specific roles, tools, and goals, working together to accomplish complex tasks. This structured approach ensures efficient collaboration and effective task execution within the framework. The basic idea is to define the 4 main capabilities using a friendly and basic UI.

1. Detailed Backlog Creation from Requirements

CrewAI agents process requirement descriptions and generate tasks enriched with security considerations, architectural patterns, and testing protocols. Whether a requirement is sparse or well-documented, the system produces actionable Epics and User Stories, aligning with best practices and reducing manual effort.

2. Collaboration with Product Owners

Tasks are automatically grouped into Epics and linked to User Stories with pre-defined acceptance criteria. Product Owners can easily review, adjust, and reprioritize tasks, ensuring alignment with project goals while reducing time spent on refinement.

3. Automated Jira Integration

The system integrates seamlessly with Jira, creating and organizing Epics and User Stories directly within the tool. This eliminates manual data entry, ensuring consistent and efficient backlog management.

4. Advanced Search and Filtering

With natural language queries and advanced filters (e.g., by priority, status, or assignee), the system can quickly navigate large backlogs, locate tasks, and identify gaps or dependencies to optimize task management.

Implementation overview

In this git hub project there is a basic implementation of these capabilities. This is the project structure

├── agents
│   ├── agile.py
│   └── reporter.py
├── tasks
│   ├── agile.py
│   └── reporter.py
├── tools
│   ├── easy_jira_wrapper.py
│   ├── jira_cleaner_util.py
│   ├── jira_epic_creator_tool.py
│   ├── jira_reader_tool.py
│   └── jira_story_creator_tool.py
├── crews.py
├── LICENSE
├── main.py
├── main_web_gradio.py
├── Pipfile
├── Pipfile.lock
├── README.md
├── setup.txt
├── statememnts_repo.py
└──web_app_gradio.py
  • main.py: Entry point for command line CrewAI execution.
  • main_web_gradio.py: Entry point for the Gradio-based web interface.
  • web_app_gradio.py: Logic for the web app, handling user inputs and outputs.
  • crews.py: Defines Crews, collections of agents and tasks.
  • Pipfile & Pipfile.lock: Dependency management with pipenv.
  • setup.txt: Instructions for initializing the project.

agents

Defines AI agents specialized in specific tasks:

  • agile.py: Agents for Agile processes like backlog refinement.
  • reporter.py: Agents for generating markdown reports.

tasks

Specifies objectives for agents:

  • agile.py: Tasks for creating Epics and User Stories.
  • reporter.py: Tasks for generating reports.

tools

Utilities for Jira integration:

  • easy_jira_wrapper.py: Simplified wrapper for Jira API operations.
  • jira_cleaner_util.py: Tool for cleaning outdated issues.
  • jira_epic_creator_tool.py: Automates Epic creation.
  • jira_reader_tool.py: Reads and filters Jira issues.

jira_story_creator_tool.py: Creates and links User Stories. ## User Interface

The user interface is designed for simplicity and functionality:

  • Input Area: Located in the top-left corner, this text area allows users to input their requirements or queries for the system.
  • Output Area: Positioned at the bottom, this section displays the system's response, including generated backlogs or Jira issue details.
  • Dropdown Menu: Found in the top-right corner, the dropdown provides the following options:
  1. Create a Backlog and Jira User Stories on Jira

    The user can enter a requirement (even just a few words) into the input area, then the system processes the input, generates a backlog, and saves it in Jira as an Epic with linked User Stories.

    The output includes the Type, Key, Summary, and Description of all Jira Stories in Markdown format.
  2. Create a Backlog

    This option allows the user to generate a backlog based on the input requirement. The user can review and modify the backlog before submitting it to Jira with the next choice.
  3. Create Jira User Stories on Jira

    Use this option to submit a pre-defined or previously created backlog to Jira, where it will be saved as Epics and Stories.
  4. Retrieve Jira Issues

    This feature allows users to query Jira and retrieve existing issues based on specific criteria.

The interface provides a streamlined experience, ensuring users can efficiently manage backlogs and interact with Jira.

Conclusions

This project serves as a concrete example of how Agentic Generative AI can support a specific phase of the software development lifecycle. By automating the backlog creation and refinement process, it showcases the potential of AI agents to reduce manual effort, enhance consistency, and streamline Agile workflows.

CrewAI proves to be a strong competitor in the growing landscape of agentic frameworks, standing alongside platforms like LangGraph, LlamaIndex, AutoGen, and many others. Its flexibility in defining agents, tasks, and tools makes it a valuable choice for building advanced AI-driven workflows.
That said, the project is currently in a prototypal state and has room for improvement in several key areas:

  • Integration of a Retrieval-Augmented Generation (RAG) approach: To enhance contextual accuracy by combining AI outputs with real-time data retrieval.
  • Improved Input and Output Typing with Pydantic: Strengthening data validation and consistency across the workflow.
  • Agent and Task Abstraction: Introducing support for YAML-based configuration files to simplify the definition and customization of agents and tasks.
  • Expanded Jira Interactions: Adding more diverse operations to interact with Jira, such as advanced queries, bulk updates, and custom workflows.

This prototype highlights the immense potential of CrewAI and similar frameworks, demonstrating how they can revolutionize software development processes with intelligent, automated workflows.
(originally published on my blog)

Author Of article : rosidotidev Read full article