Currently stale, as I am temporarily working on related C++ library, that hopefully will become a part of this project, or at least will give me knowledge to do work on it further.
Impactifier is a tool designed to analyze the impact of code changes, across the whole - possibly separated - codebase, and allow to take various actions based on that. It aims to help developers identify potential downstream effects of changes, allowing for more reliable and frequent releases. Can be used as either local tool or as part of CI/CD.
Show your support by giving a ⭐
Please note, that a lot of this README was created with help of ChatGPT, so it is far from perfect
Impactifier provides an automated approach to change impact analysis, designed to serve as both CI/CD and local tool. Aims to improve frequency and reliability of releases, by generating impact reports for engineers to be able to push the changes with confidence. (Eventually) Highly configurable, with possibility to add custom rules and actions.
Your contracts generator does weird stuff under the hood, yet you want to see what impact on front-end modifying its query handler have? Don't worry, Impactifier got your back.
- Automated Impact Analysis: Detect changes and their potential effects across the codebase.
- Configurable rules specification: Analyses the impact based on configurable set of rules, to support various tech-stacks.
- Integration with CI/CD Pipelines: Seamlessly integrate with GitHub Actions to provide impact reports in pull requests.
- Performance: Built in Rust for high performance and low latency. After all, it is all about faster releases.
Please note, that it doesn't yet work at all. Stuff below is meant to show how it hopefully will be used.
Impactifier main usage is designed to be CI/CD.
It supports both pull_request
andpush
trigger actions.
Simplified example:
on: [push, pull_request]
jobs:
run:
runs-on: ubuntu-latest
needs: extract-info
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: run cli
run: |
if [ "${{ github.event_name }}" = "push" ]; then
impactifier --from-branch ${{ $BRANCH_NAME }} --commit ${{ $COMMIT_SHA }}
elif [ "${{ github.event_name }}" = "pull_request" ]; then
impactifier --from-branch ${{ $BRANCH_NAME }} --to-branch ${{ $TARGET_BRANCH }}
fi
Flags information can easily be extracted inside the github action itself. Full example can be found here
Impactifier can be used as a CLI tool.
It can either clone a repository or open an existing - in you local file path - one.
To clone a repository you have to specify its url via --url
flag.
If repository is private, you need to pass --access-token
flag.
Example:
$ impactifier --url github.com/wzslr321/foobar --access-token=very_private
The command above will actually allow you to perform your first impact analysis!
Since there is no further configuration, it will try to go with defaults, which are
your local changes & current branch - so basically just output of plain git diff
To specify what exactly you want to analyze, you have a few options:
--from-branch
: branch to compare, defaults to the current branch--to-branch
: branch to compare the one from--from-branch
with--commit-id
: specific commit to analyze To specify the branch where the commit is located, use--from-branch
To analyze local repository, you can specify --path
flag. By default it checks both current directory,
and the one above it, to handle both local & ci/cd usage.
All necessary config can be passed via flags - which take highest priority - but config file is also supported.
Below is an example of a impactifier-config.yaml file:
repository:
url: "https://github.com/wzslr321/impactifier"
options:
clone_into: "./repo"
rules:
- name: "Detect API Changes"
trigger:
path: "api/"
pattern: "func (\\w+)Handler"
transform:
name: "toApiEndpoint"
steps:
- name: "toLowerCase"
- name: "replace"
args:
pattern: "Handler$"
with: "_endpoint"
- name: "prepend"
args:
value: "/api/"
- name: "customFunction"
args:
script: |
fn transform(context) {
if context.class_name == "SpecialClass" {
return "/special" + context.matched_string;
} else {
return context.matched_string;
}
}
matcher:
path: "client/"
pattern: "ApiClient.call('$transform')"
action:
alert_level: "Severe"
message: "API changed"
We welcome contributions to Impactifier! Please refer to our Contributing Guidelines for instructions on how to contribute.
Impactifier is licensed under the MIT License. See the LICENSE file for details.