cover-agent
CodiumAI Cover-Agent: An AI-Powered Tool for Automated Test Generation and Code Coverage Enhancement! ๐ป๐ค๐งช๐
Top Related Projects
The ChatGPT Retrieval Plugin lets you easily find personal or work documents by asking questions in natural language.
๐ฆ๐ Build context-aware reasoning applications
Integrate cutting-edge LLM technology quickly and easily into your apps
JARVIS, a system to connect LLMs with ML community. Paper: https://arxiv.org/pdf/2303.17580.pdf
Quick Overview
Cover-agent is an AI-powered tool designed to generate comprehensive code coverage for Python projects. It utilizes large language models to automatically create test cases, improving code quality and reducing manual testing efforts.
Pros
- Automates test case generation, saving developers time and effort
- Improves code coverage, potentially uncovering hidden bugs and edge cases
- Integrates seamlessly with existing Python testing frameworks
- Customizable to fit specific project needs and coding standards
Cons
- May generate unnecessary or redundant tests in some cases
- Requires careful review of generated tests to ensure accuracy and relevance
- Potential for false positives or missed edge cases in complex scenarios
- Dependency on external AI services may raise privacy concerns for sensitive projects
Code Examples
- Initializing the Cover-agent:
from cover_agent import CoverAgent
agent = CoverAgent(project_path="/path/to/your/project")
- Generating test cases for a specific file:
test_cases = agent.generate_tests(file_path="your_module.py")
print(test_cases)
- Running generated tests and analyzing coverage:
coverage_report = agent.run_and_analyze()
print(f"Overall coverage: {coverage_report.total_coverage}%")
Getting Started
To get started with Cover-agent:
-
Install the package:
pip install cover-agent
-
Initialize the agent with your project path:
from cover_agent import CoverAgent agent = CoverAgent(project_path="/path/to/your/project")
-
Generate and run tests:
agent.generate_and_run_tests()
-
View the coverage report:
report = agent.get_coverage_report() print(report.summary())
Competitor Comparisons
The ChatGPT Retrieval Plugin lets you easily find personal or work documents by asking questions in natural language.
Pros of chatgpt-retrieval-plugin
- More comprehensive documentation and setup instructions
- Supports multiple vector database options (Pinecone, Weaviate, Zilliz, Milvus, Qdrant)
- Includes a FastAPI server for handling requests and responses
Cons of chatgpt-retrieval-plugin
- More complex setup process due to multiple dependencies
- Requires API keys and external services for full functionality
- Limited to retrieval and doesn't include code generation features
Code Comparison
chatgpt-retrieval-plugin:
@app.post("/upsert")
async def upsert(
request: UpsertRequest = Body(...),
background_tasks: BackgroundTasks,
token: str = Depends(get_bearer_token),
):
try:
ids = await datastore.upsert(request.documents)
background_tasks.add_task(batch_upsert, request.documents)
return UpsertResponse(ids=ids)
except Exception as e:
print(f"Error: {e}")
raise HTTPException(status_code=500, detail="Internal Service Error")
cover-agent:
def generate_cover_letter(resume, job_description):
prompt = f"Resume:\n{resume}\n\nJob Description:\n{job_description}\n\nGenerate a cover letter:"
response = openai.Completion.create(
engine="text-davinci-002",
prompt=prompt,
max_tokens=500,
n=1,
stop=None,
temperature=0.7,
)
return response.choices[0].text.strip()
๐ฆ๐ Build context-aware reasoning applications
Pros of langchain
- More comprehensive framework for building LLM applications
- Larger community and ecosystem with extensive documentation
- Supports a wide range of LLMs and integrations
Cons of langchain
- Steeper learning curve due to its extensive features
- May be overkill for simpler projects or specific use cases
- Requires more setup and configuration
Code Comparison
cover-agent:
from cover_agent import CoverAgent
agent = CoverAgent()
response = agent.generate_cover_letter(resume, job_description)
langchain:
from langchain import PromptTemplate, LLMChain
from langchain.llms import OpenAI
template = """Generate a cover letter based on:
Resume: {resume}
Job Description: {job_description}"""
prompt = PromptTemplate(input_variables=["resume", "job_description"], template=template)
llm_chain = LLMChain(prompt=prompt, llm=OpenAI())
response = llm_chain.run(resume=resume, job_description=job_description)
Integrate cutting-edge LLM technology quickly and easily into your apps
Pros of semantic-kernel
- More comprehensive framework for building AI-powered applications
- Extensive documentation and examples for various use cases
- Strong integration with Azure AI services and other Microsoft technologies
Cons of semantic-kernel
- Steeper learning curve due to its broader scope and complexity
- Primarily focused on Microsoft ecosystem, which may limit flexibility
- Requires more setup and configuration for basic tasks
Code Comparison
cover-agent:
from cover_agent import CoverAgent
agent = CoverAgent()
response = agent.generate_cover_letter(resume, job_description)
semantic-kernel:
import semantic_kernel as sk
kernel = sk.Kernel()
kernel.add_text_completion_service("dv", "text-davinci-003")
context = kernel.create_new_context()
result = kernel.run_async(prompt, context)
Summary
cover-agent is a specialized tool for generating cover letters, offering simplicity and ease of use for its specific task. semantic-kernel, on the other hand, provides a more comprehensive framework for building AI-powered applications with broader capabilities but requires more setup and familiarity with its ecosystem. The choice between the two depends on the specific needs of the project and the desired level of customization and integration with other AI services.
JARVIS, a system to connect LLMs with ML community. Paper: https://arxiv.org/pdf/2303.17580.pdf
Pros of JARVIS
- More comprehensive AI agent system with multiple components (vision, speech, etc.)
- Larger community and support from Microsoft
- Broader scope for general AI tasks and research
Cons of JARVIS
- More complex setup and configuration
- Potentially higher resource requirements
- Less focused on specific code-related tasks
Code Comparison
JARVIS (Python):
from jarvis import Jarvis
jarvis = Jarvis()
response = jarvis.process_input("What's the weather like today?")
print(response)
cover-agent (JavaScript):
import { CoverAgent } from 'cover-agent';
const agent = new CoverAgent();
const coverage = await agent.analyzeCoverage('path/to/source');
console.log(coverage);
Summary
JARVIS is a more comprehensive AI agent system with broader applications, while cover-agent focuses specifically on code coverage analysis. JARVIS offers more features and potential for general AI tasks, but may be more complex to set up and use. cover-agent provides a simpler, more targeted solution for code coverage, making it potentially easier to integrate into existing development workflows for that specific purpose.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
CodiumAI Cover Agent aims to help efficiently increasing code coverage, by automatically generating qualified tests to enhance existing test suites
Table of Contents
News and Updates
2024-09-29:
We are excited to announce the latest series of updates to CoverAgent, delivering significant improvements to functionality, documentation, and testing frameworks. These updates reflect our ongoing commitment to enhancing the developer experience, improving error handling, and refining the testing processes.
New Features and Enhancements
- Enhanced Database Usage: Introduced a new database_usage.md document outlining the expanded capabilities of logging test results to a structured database.
- Comprehensive System Diagrams: Added a top_level_sequence_diagram.md, providing a clear visual overview of CoverAgent's processes and workflows.
- Docker and Multi-Language Support: Several new Docker configurations and templated tests were introduced for various programming languages, including C#, TypeScript, C, and React, ensuring streamlined testing environments across multiple platforms.
- UnitTestDB Integration: The UnitTestDB.py file was added to support robust logging of test generation attempts, improving error tracking and debugging.
Refinements and Modifications
- Coverage Processing: Key improvements to CoverageProcessor.py modularized coverage parsing and expanded support for different coverage report formats (LCOV, Cobertura, Jacoco).
- PromptBuilder Enhancements: New CLI arguments were introduced, including options for running tests multiple times (--run-tests-multiple-times) and a report coverage feature flag for more granular control over coverage behavior.
- CI/CD Pipeline Improvements: Several GitHub workflows were modified to improve pipeline efficiency, including nightly regression tests and templated test publishing pipelines.
Improved Documentation
- Detailed Usage Examples: The usage_examples.md file was updated to provide more comprehensive guidance on how to effectively use CoverAgent's features, ensuring that developers can quickly get up to speed with the latest updates.
- Configuration and Template Updates: Configuration files, such as test_generation_prompt.toml, were refined to better support the test framework and eliminate redundant instructions.
These updates signify a major leap forward in improving the ease of use, flexibility, and overall performance of CoverAgent. We are committed to continuing to enhance the tool and providing regular updates based on feedback from our community.
2024-06-05:
The logic and prompts for adding new imports for the generated tests have been improved.
We also added a usage examples file, with more elaborate examples of how to use the Cover Agent.
2024-06-01:
Added support for comprehensive logging to Weights and Biases. Set the WANDB_API_KEY
environment variable to enable this feature.
2024-05-26:
Cover-Agent now supports nearly any LLM model in the world, using LiteLLM package.
Notice that GPT-4 outperforms almost any open-source model in the world when it comes to code tasks and following complicated instructions.
However, we updated the post-processing scripts to be more comprehensive, and were able to successfully run the baseline script with llama3-8B
and llama3-70B models
, for example.
2024-05-09:
This repository includes the first known implementation of TestGen-LLM, described in the paper Automated Unit Test Improvement using Large Language Models at Meta.
Cover-Agent
Welcome to Cover-Agent. This focused project utilizes Generative AI to automate and enhance the generation of tests (currently mostly unit tests), aiming to streamline development workflows. Cover-Agent can run via a terminal, and is planned to be integrated into popular CI platforms.
We invite the community to collaborate and help extend the capabilities of Cover Agent, continuing its development as a cutting-edge solution in the automated unit test generation domain. We also wish to inspire researchers to leverage this open-source tool to explore new test-generation techniques.
Overview
This tool is part of a broader suite of utilities designed to automate the creation of unit tests for software projects. Utilizing advanced Generative AI models, it aims to simplify and expedite the testing process, ensuring high-quality software development. The system comprises several components:
- Test Runner: Executes the command or scripts to run the test suite and generate code coverage reports.
- Coverage Parser: Validates that code coverage increases as tests are added, ensuring that new tests contribute to the overall test effectiveness.
- Prompt Builder: Gathers necessary data from the codebase and constructs the prompt to be passed to the Large Language Model (LLM).
- AI Caller: Interacts with the LLM to generate tests based on the prompt provided.
Installation and Usage
Requirements
Before you begin, make sure you have the following:
OPENAI_API_KEY
set in your environment variables, which is required for calling the OpenAI API.- Code Coverage tool: A Cobertura XML code coverage report is required for the tool to function correctly.
- For example, in Python one could use
pytest-cov
. Add the--cov-report=xml
option when running Pytest. - Note: We are actively working on adding more coverage types but please feel free to open a PR and contribute to
cover_agent/CoverageProcessor.py
- For example, in Python one could use
If running directly from the repository you will also need:
- Python installed on your system.
- Poetry installed for managing Python package dependencies. Installation instructions for Poetry can be found at https://python-poetry.org/docs/.
Standalone Runtime
The Cover Agent can be installed as a Python Pip package or run as a standalone executable.
Python Pip
To install the Python Pip package directly via GitHub run the following command:
pip install git+https://github.com/Codium-ai/cover-agent.git
Binary
The binary can be run without any Python environment installed on your system (e.g. within a Docker container that does not contain Python). You can download the release for your system by navigating to the project's release page.
Repository Setup
Run the following command to install all the dependencies and run the project from source:
poetry install
Running the Code
After downloading the executable or installing the Pip package you can run the Cover Agent to generate and validate unit tests. Execute it from the command line by using the following command:
cover-agent \
--source-file-path "<path_to_source_file>" \
--test-file-path "<path_to_test_file>" \
--code-coverage-report-path "<path_to_coverage_report>" \
--test-command "<test_command_to_run>" \
--test-command-dir "<directory_to_run_test_command>" \
--coverage-type "<type_of_coverage_report>" \
--desired-coverage <desired_coverage_between_0_and_100> \
--max-iterations <max_number_of_llm_iterations> \
--included-files "<optional_list_of_files_to_include>"
You can use the example code below to try out the Cover Agent. (Note that the usage_examples file provides more elaborate examples of how to use the Cover Agent)
Python
Follow the steps in the README.md file located in the templated_tests/python_fastapi/
directory to setup an environment, then return to the root of the repository, and run the following command to add tests to the python fastapi example:
cover-agent \
--source-file-path "templated_tests/python_fastapi/app.py" \
--test-file-path "templated_tests/python_fastapi/test_app.py" \
--code-coverage-report-path "templated_tests/python_fastapi/coverage.xml" \
--test-command "pytest --cov=. --cov-report=xml --cov-report=term" \
--test-command-dir "templated_tests/python_fastapi" \
--coverage-type "cobertura" \
--desired-coverage 70 \
--max-iterations 10
Go
For an example using go cd
into templated_tests/go_webservice
, set up the project following the README.md
.
To work with coverage reporting, you need to install gocov
and gocov-xml
. Run the following commands to install these tools:
go install github.com/axw/gocov/gocov@v1.1.0
go install github.com/AlekSi/gocov-xml@v1.1.0
and then run the following command:
cover-agent \
--source-file-path "app.go" \
--test-file-path "app_test.go" \
--code-coverage-report-path "coverage.xml" \
--test-command "go test -coverprofile=coverage.out && gocov convert coverage.out | gocov-xml > coverage.xml" \
--test-command-dir $(pwd) \
--coverage-type "cobertura" \
--desired-coverage 70 \
--max-iterations 1
Java
For an example using java cd
into templated_tests/java_gradle
, set up the project following the README.md.
To work with jacoco coverage reporting, follow the README.md Requirements section:
and then run the following command:
cover-agent \
--source-file-path="src/main/java/com/davidparry/cover/SimpleMathOperations.java" \
--test-file-path="src/test/groovy/com/davidparry/cover/SimpleMathOperationsSpec.groovy" \
--code-coverage-report-path="build/reports/jacoco/test/jacocoTestReport.csv" \
--test-command="./gradlew clean test jacocoTestReport" \
--test-command-dir=$(pwd) \
--coverage-type="jacoco" \
--desired-coverage=70 \
--max-iterations=1
Outputs
A few debug files will be outputted locally within the repository (that are part of the .gitignore
)
run.log
: A copy of the logger that gets dumped to yourstdout
test_results.html
: A results table that contains the following for each generated test:- Test status
- Failure reason (if applicable)
- Exit code,
stderr
stdout
- Generated test
Additional logging
If you set an environment variable WANDB_API_KEY
, the prompts, responses, and additional information will be logged to Weights and Biases.
Using other LLMs
This project uses LiteLLM to communicate with OpenAI and other hosted LLMs (supporting 100+ LLMs to date). To use a different model other than the OpenAI default you'll need to:
- Export any environment variables needed by the supported LLM following the LiteLLM instructions.
- Call the name of the model using the
--model
option when calling Cover Agent.
For example (as found in the LiteLLM Quick Start guide):
export VERTEX_PROJECT="hardy-project"
export VERTEX_LOCATION="us-west"
cover-agent \
...
--model "vertex_ai/gemini-pro"
OpenAI Compatible Endpoint
export OPENAI_API_KEY="<your api key>" # If <your-api-base> requires an API KEY, set this value.
cover-agent \
...
--model "openai/<your model name>" \
--api-base "<your-api-base>"
Development
This section discusses the development of this project.
Versioning
Before merging to main make sure to manually increment the version number in cover_agent/version.txt
at the root of the repository.
Running Tests
Set up your development environment by running the poetry install
command as you did above.
Note: for older versions of Poetry you may need to include the --dev
option to install Dev dependencies.
After setting up your environment run the following command:
poetry run pytest --junitxml=testLog.xml --cov=templated_tests --cov=cover_agent --cov-report=xml --cov-report=term --log-cli-level=INFO
This will also generate all logs and output reports that are generated in .github/workflows/ci_pipeline.yml
.
Building the binary locally
You can build the binary locally simply by invoking the make installer
command. This will run PyInstaller locally on your machine. Ensure that you have set up the poetry project first (i.e. running poetry install
).
Roadmap
Below is the roadmap of planned features, with the current implementation status:
- Automatically generates unit tests for your software projects, utilizing advanced AI models to ensure comprehensive test coverage and quality assurance. (similar to Meta)
- Being able to generate tests for different programming languages
- Being able to deal with a large variety of testing scenarios
- Generate a behavior analysis for the code under test, and generate tests accordingly
- Check test flakiness, e.g. by running 5 times as suggested by TestGen-LLM
- Cover more test generation pains
- Generate new tests that are focused on the PR changeset
- Run over an entire repo/code-base and attempt to enhance all existing test suites
- Improve usability
- Connectors for GitHub Actions, Jenkins, CircleCI, Travis CI, and more
- Integrate into databases, APIs, OpenTelemetry and other sources of data to extract relevant i/o for the test generation
- Add a setting file
CodiumAI
CodiumAI's mission is to enable busy dev teams to increase and maintain their code integrity. We offer various tools, including "Pro" versions of our open-source tools, which are meant to handle enterprise-level code complexity and are multi-repo codebase aware.
Top Related Projects
The ChatGPT Retrieval Plugin lets you easily find personal or work documents by asking questions in natural language.
๐ฆ๐ Build context-aware reasoning applications
Integrate cutting-edge LLM technology quickly and easily into your apps
JARVIS, a system to connect LLMs with ML community. Paper: https://arxiv.org/pdf/2303.17580.pdf
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot