autogit
is a command line tool for updating multiple GitLab or GitHub repositories with a single command.
Generate an access token at GitLab or GitHub and set it as environment variable:
export GITLAB_ACCESS_TOKEN=<token>
export GITHUB_OAUTH_TOKEN=<token>
export GIT_TOKEN=<token> # This one is used if previous ones are not found
Provide a list of repositories and a script or a command to run inside each of them:
autogit --repos repos.txt update_repo.py
Where repos.txt
could be:
https://gitlab.com/<handle>/<repo-title>
https://gitlab.com/<handle>/<repo-title2>
https://github.com/<handle>/<repo-title>
Try it yourself:
autogit \
--repo https://github.com/<handle>/<repo-title> \
--branch-name add-hello-world-file \
--commit-message "Add hello-world.txt file" \
touch hello-world.txt
These steps will be executed for each specified repository:
- The repository will be cloned into
/tmp/
directory. - A new branch will be created or fetched if it already exists.
- The command or a script will be executed inside the repository.
- A commit containing all the changes will be created.
- Newly created commit will be pushed to remote repository.
- A pull request will be created.
- [optional] A comment will be left next to the PR.
- [optional] The pull request will be merged.
These options could be used to specify more details:
Option | Description | Type | Required |
---|---|---|---|
--branch-name |
A name of a branch which will be created or used to add a commit and to create pull request from. | String | Yes |
--commit-message |
A commit message which will be used for all of the changes made. | String | No |
--repo |
Link to repository | String | No |
--repos |
Filename which contains a list of repository links | String | No |
More examples:
autogit --repos repos.txt ./examples/update_mypy_version.py
autogit
is implemented in Python and uses coroutines to make multiple parallel API calls. Delays are being made after each API call in order not to get throttled.
-
Add unit tests for all the paths (mock gitpython, httpx requests)
- Implement state change dependencies on the tests.
- Implement RecorderMock for packages.
-
Package and release to PyPi
-
Run command as command line tool
- Stand-alone executable file download in Github releases.
-
Make API calls to GitLab
-
Support different API calls
-
Advanced features:
- Merge PRs which have all requirements like approvals met.
make venv
- will create virtual env with dev dependencies.
make check
- will run Flake8, MyPy and PyTest checks.
This tool was inspired by: