Automate the creation of git commits over a specified date range with customizable options for commit frequency, commit times, and more. This script helps you simulate activity in a repository by generating commits according to your specified parameters, which can be useful for testing, demonstrations, increase privacy (it is possible to set github activity to show your private repositories as well, so in this case use this repository as your private repository) or populating a repository's history.
- Date Range Specification: Define the start and end dates for commit generation.
- Percentage of Active Days: Specify the percentage of days within the date range on which commits should be created.
- Customizable Commit Frequency: Set an exact number of commits per day or define a random range with minimum and maximum commits.
- Time Interval Control: Define specific time intervals during the day when commits should be made.
- Branch Management: Automatically creates and switches to a specified branch for commit generation.
- Safety Checks: Ensures that the script is run in a git repository with a clean working directory.
- Interactive Configuration: User-friendly prompts guide you through the setup process.
- Git: Ensure that Git is installed and properly configured on your system.
- Python 3: The script is written in Python 3 and requires Python 3.6 or higher.
- Git Repository: The script must be run in the root directory of an existing git repository.
-
Clone the Repository (or copy the script into your existing repository):
git clone https://github.com/annyedge/github-activity-python-script.git
-
Navigate to the Repository Directory:
cd github-activity-python-script
-
Make the Script Executable (optional):
chmod +x main.py
Run the script from the root directory of your git repository:
python3 main.py
or
./main.py
Follow the interactive prompts to configure the commit generation according to your preferences.
- Branch Name:
feature-commit-generator
- Start Date:
2023-02-01
- End Date:
2023-02-28
- Percentage of Days:
50
- Time Intervals:
- Enter
09:00 17:00
- Enter
22:00 23:50
- Enter
done
- Enter
- Exact Number of Commits per Day: Leave blank.
- Minimum Commits per Day:
1
- Maximum Commits per Day:
3
- Push to Remote: Enter
y
to push to the remote repository.
-
Branch Name: The script will create and switch to this branch for commit generation. Default is
activity-branch
. -
Date Range:
- Start Date: The date from which to start generating commits (
YYYY-MM-DD
). - End Date: The date on which to stop generating commits (
YYYY-MM-DD
).
- Start Date: The date from which to start generating commits (
-
Percentage of Days: The percentage of days within the date range on which commits will be created. Accepts a value between
0
and100
. Default is100%
. -
Time Intervals: Define one or more time intervals during the day when commits can be made. Intervals are entered in the format
HH:MM HH:MM
(24-hour format). For example:09:00 12:00
(from 9 AM to 12 PM)14:00 17:30
(from 2 PM to 5:30 PM)
-
Commits per Day:
- Exact Number: Specify an exact number of commits to be made each day.
- Random Range: Define a minimum and maximum number of commits per day to randomize commit frequency.
- Minimum Commits per Day: Default is
1
. - Maximum Commits per Day: Default is
6
.
- Minimum Commits per Day: Default is
-
Push to Remote: Optionally push the generated commits to the remote repository. The script uses
--force
and sets the upstream branch.
I don't care about licenses—do whatever you want!
Disclaimer: Use this script responsibly. Automating commits can alter your repository's history and may have implications when collaborating with others. Always ensure that force-pushing to a remote repository will not disrupt other collaborators.