Skip to content

Cloud-Code-AI/kaizen

Repository files navigation

Github Stars Commits-per-week License: AGPL-3.0

Kaizen

Kaizen is an open-source project that helps teams ensure quality in their software delivery by providing a suite of tools for code review, test generation, and end-to-end testing. It integrates with your existing code repositories and workflows, allowing you to streamline your software development process.

Features

End-to-End Testing

Kaizen generates comprehensive end-to-end tests based on your application's code and documentation. These tests ensure that your application functions correctly from start to finish, catching regressions and edge cases that may have been overlooked during development.

UI Testing and Review

Kaizen can provide teams with helpful reviews for their UI and generate necessary tests to ensure that their website works as expected.

Code Review

Kaizen automatically reviews pull requests, summarizes code changes and provides insightful feedback on potential issues or areas of improvement. It leverages advanced natural language processing techniques to understand the context and implications of the code changes.

File Structure

  • github_app: Contains the API server used by the GitHub app to process and respond to incoming requests.
  • kaizen: Contains the main logic for interaction with LLMs and data processing.
    • actors: Contains classes used to process various different actions like Code Review and Test execution.
    • generators: Contains the main logic for generative use cases like test case generation, description generation, etc.
    • llms: Contains LLM integrations.
  • docs: Contains Nextra-powered documentation for the project.
  • examples: Contains sample code for various use cases.

Getting Started

To get started with Kaizen, follow these steps:

  1. Install Kaizen package:

      pip install kaizen-cloudcode
  2. Copy the example code from examples/basic

  3. Generate tests for your website:

    First, you need to update the URL in the examples/basic/generate.py

      PYTHONPATH=. poetry run python examples/basic/generate.py

    Kaizen will generate all the tests and store them inside .kaizen/tests/

  4. Execute tests:

    Once you have generated all the necessary tests, you can run all the tests in two ways:

      PYTHONPATH=. poetry run python examples/basic/execute.py

    Or using the default pytest module:

      pytest -v .kaizen/tests/
    

    Kaizen will generate all the tests and store them inside .kaizen/tests/

Running API Server for GitHub App

Kaizen utilizes a GitHub app to perform actions like PR review and description updates. Here is a quick link to set up your own GitHub App: docs/pages/github_app.md

Deploy the API using Docker Compose:

docker-compose up

You can also configure features by tweaking the config.json file.

NOTE: You need to create a .env file by copying .env.example and also store the PEM file for the GitHub app as GITHUB_APP_KEY.pem.

Contributing

We welcome contributions from the community! If you'd like to contribute to Kaizen, please follow these steps:

  1. Fork the repository
  2. Create a new branch (git checkout -b feature/my-feature)
  3. Commit your changes (git commit -m 'Add some feature')
  4. Push to the branch (git push origin feature/my-feature)
  5. Open a Pull Request

License

Kaizen is released under the AGPL License.

Contact

If you have any questions or need further assistance, please feel free to contact us at support@cloudcode.ai.