Skip to content

🚌 Your repo's fitness witness! Track your bus factor before your code misses the bus.

Notifications You must be signed in to change notification settings

erdemkosk/gitness

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

24 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Gitness

Gitness - Your repo's fitness witness! Track your bus factor before your code misses the bus.

Gitness

Features

  • Calculate repository bus factor and knowledge distribution
  • Analyze contributor statistics and activity patterns
  • Track recent contributor engagement
  • Support for multiple VCS providers (GitHub, Bitbucket)
  • Multiple output formats (Console, JSON, Markdown)
  • Configurable analysis period (e.g., 6m, 1y, 30d)
  • Branch-specific analysis support
  • CI/CD pipeline integration
  • Docker support

Usage

# Analyze all time
gitness https://github.com/user/repo

# Analyze last 6 months
gitness --duration 6m https://github.com/user/repo

# Analyze last 1 year with JSON output
gitness --duration 1y --output json https://github.com/user/repo

# Analyze specific branch with Markdown output
gitness --branch feature-branch --output markdown https://github.com/user/repo

# Analyze specific branch for last 30 days
gitness --duration 30d --branch experimental --output console https://github.com/user/repo

# Analyze last week with console output (default)
gitness --duration 7d --output console https://github.com/user/repo

# Analyze last quarter with JSON output and specific branch
gitness --duration 3m --branch develop --output json https://github.com/user/repo

# Analyze last month with Markdown output and save to file
gitness --duration 1m --output markdown https://github.com/user/repo > report.md

Metrics Explained

Bus Factor 🚌

The "Bus Factor" represents the minimum number of developers that would need to be hit by a bus before the project is in serious trouble. It's calculated based on contributors who collectively account for 80% of contributions.

  • πŸ”΄ Critical (< 2): Project knowledge is dangerously concentrated
  • 🟑 Warning (2-3): Limited knowledge distribution
  • 🟒 Good (β‰₯ 4): Healthy knowledge distribution

Knowledge Distribution Score πŸ“Š

Measures how evenly the knowledge is distributed across all contributors (0-100).

  • πŸ”΄ Critical (< 25): Knowledge is heavily concentrated
  • 🟑 Warning (25-50): Moderate knowledge concentration
  • 🟒 Good (> 50): Well-distributed knowledge

Active Contributor Ratio πŸ‘₯

Percentage of contributors who have made significant contributions (>1% of total commits).

  • πŸ”΄ Critical (< 30%): Most contributors are occasional
  • 🟑 Warning (30-50%): Moderate active participation
  • 🟒 Good (> 50%): Healthy active participation

Recent Contributors πŸ•’

Number of contributors active in last 3 months.

  • πŸ”΄ Critical (< 2): Low recent activity
  • 🟑 Warning (2-4): Moderate recent activity
  • 🟒 Good (β‰₯ 5): High recent activity

Commit Frequency Analysis ⏰

Detailed analysis of commit patterns and activity trends.

  • πŸ“… Daily Average: Average number of commits per day
  • πŸ“… Weekly Average: Average number of commits per week
  • πŸ“… Monthly Average: Average number of commits per month
  • πŸ“… Most Active Day: Day of the week with highest commit activity
  • πŸ•’ Peak Activity Time: Hour of the day with most commits

Example Output

    β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•— β–ˆβ–ˆβ•—β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•—β–ˆβ–ˆβ–ˆβ•—   β–ˆβ–ˆβ•—β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•—β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•—β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•—
   β–ˆβ–ˆβ•”β•β•β•β•β• β–ˆβ–ˆβ•‘β•šβ•β•β–ˆβ–ˆβ•”β•β•β•β–ˆβ–ˆβ–ˆβ–ˆβ•—  β–ˆβ–ˆβ•‘β–ˆβ–ˆβ•”β•β•β•β•β•β–ˆβ–ˆβ•”β•β•β•β•β•β–ˆβ–ˆβ•”β•β•β•β•β•
   β–ˆβ–ˆβ•‘  β–ˆβ–ˆβ–ˆβ•—β–ˆβ–ˆβ•‘   β–ˆβ–ˆβ•‘   β–ˆβ–ˆβ•”β–ˆβ–ˆβ•— β–ˆβ–ˆβ•‘β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•—  β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•—β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•—
   β–ˆβ–ˆβ•‘   β–ˆβ–ˆβ•‘β–ˆβ–ˆβ•‘   β–ˆβ–ˆβ•‘   β–ˆβ–ˆβ•‘β•šβ–ˆβ–ˆβ•—β–ˆβ–ˆβ•‘β–ˆβ–ˆβ•”β•β•β•  β•šβ•β•β•β•β–ˆβ–ˆβ•‘β•šβ•β•β•β•β–ˆβ–ˆβ•‘
   β•šβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•”β•β–ˆβ–ˆβ•‘   β–ˆβ–ˆβ•‘   β–ˆβ–ˆβ•‘ β•šβ–ˆβ–ˆβ–ˆβ–ˆβ•‘β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•—β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•‘β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ•‘
    β•šβ•β•β•β•β•β• β•šβ•β•   β•šβ•β•   β•šβ•β•  β•šβ•β•β•β•β•šβ•β•β•β•β•β•β•β•šβ•β•β•β•β•β•β•β•šβ•β•β•β•β•β•β•

Your repo's fitness witness! Track your bus factor before your code misses the bus.
═══════════════════════════════════════════════════════════════════════════════════

πŸ“Š Repository: user/repo
──────────────────────────────────────────────────

🌿 Branch: default
πŸ•’ Analysis Period: Last 6 months

🎯 Core Metrics
────────────────
🚌 Bus Factor: 4
πŸ“š Knowledge Distribution: 75.5%
πŸ“ Total Commits: 330
πŸ‘₯ Active Contributors: 45.5%
πŸ”„ Recent Contributors: 6

⏰ Commit Frequency
────────────────
πŸ“… Daily Average: 3.77 commits
πŸ“… Weekly Average: 26.38 commits
πŸ“… Monthly Average: 113.07 commits
πŸ“… Most Active Day: Monday
πŸ•’ Peak Activity Time: 18:00

πŸ‘₯ Top Contributors
────────────────
πŸ‘€ John Doe: 100 commits (30.3%)
πŸ‘€ Jane Smith: 90 commits (27.3%)
πŸ‘€ Bob Wilson: 80 commits (24.2%)
πŸ‘€ Alice Brown: 60 commits (18.2%)
πŸ‘€ Charlie Brown: 30 commits (9.1%)

... and 5 more contributors

═══════════════════════════════════════════════════════════════
                     Generated by Gitness                      

Environment Variables

GITHUB_TOKEN=your_token
BITBUCKET_CLIENT_ID=your_client_id
BITBUCKET_CLIENT_SECRET=your_client_secret
COMMIT_HISTORY_DURATION=6m  # Optional: 6m, 1y, 30d etc.
REPOSITORY_BRANCH=main      # Optional: Specify branch to analyze

Installation

Using Go

go install github.com/erdemkosk/gitness@latest

Using Docker

docker build -t gitness .
docker run \                                                                                                                           ok 
  -e GITHUB_TOKEN="TOKEN" \
  -e REPOSITORY_URL="https://github.com/user/repo" \
  gitness --output json;

Environment Variables

  • REPOSITORY_URL: Target repository URL
  • GITHUB_TOKEN: GitHub personal access token
  • BITBUCKET_CLIENT_ID: Bitbucket OAuth client ID
  • BITBUCKET_CLIENT_SECRET: Bitbucket OAuth client secret
  • OUTPUT_FORMAT: Output format (console, json, markdown)
  • COMMIT_HISTORY_DURATION: Analysis period (e.g., 6m, 1y, 30d)
  • REPOSITORY_BRANCH: Branch to analyze (optional, defaults to repository's default branch)

Repository URL Formats

GitHub

https://github.com/username/repository

Bitbucket

https://bitbucket.org/workspace/repository

Authentication

GitHub

Generate a personal access token from GitHub Settings > Developer Settings > Personal Access Tokens.

Bitbucket

  1. Go to Bitbucket Settings > OAuth Consumers
  2. Create a new OAuth consumer
  3. Use the Client ID and Client Secret in your environment variables

CI/CD Integration

GitHub Actions

name: Gitness Bus Factor Analysis

on:
  push:
    branches: [ main, master ]
  pull_request:
    branches: [ main, master ]

jobs:
  check-bus-factor:
    runs-on: ubuntu-latest
    steps:
      - name: Set up QEMU
        uses: docker/setup-qemu-action@v3
      
      - name: Run Bus Factor Analysis
        uses: docker://erdemkosk/gitness:latest
        env:
          GITHUB_TOKEN: ${{ secrets.GITNESS_GITHUB_TOKEN }}
          REPOSITORY_URL: "https://github.com/${{ github.repository }}"
          OUTPUT_FORMAT: json
        id: analysis

GitHub Actions With Result

name: Gitness Analysis

on:
  push:
    branches: [ main, master ]
  pull_request:
    branches: [ main, master ]

jobs:
  analyze:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v3
      
      - name: Run Gitness Analysis
        id: gitness
        run: |
          OUTPUT=$(docker run \
            -e GITHUB_TOKEN="${{ secrets.GITNESS_GITHUB_TOKEN }}" \
            -e REPOSITORY_URL="https://github.com/${{ github.repository }}" \
            -e OUTPUT_FORMAT=markdown \
            erdemkosk/gitness:latest)
          echo "# πŸ“Š Gitness Analysis Report" >> $GITHUB_STEP_SUMMARY
          echo "$OUTPUT" >> $GITHUB_STEP_SUMMARY
          echo "> This report is automatically generated by [Gitness](https://github.com/erdemkosk/gitness)" >> $GITHUB_STEP_SUMMARY
Example GitHub Action Result

Example GitHub Action Run

Architecture

  • Clean architecture principles
  • Strategy pattern for output formatting
  • Factory pattern for VCS providers
  • Dependency injection
  • Environment-based configuration

Contributing

  1. Fork the repository
  2. Create your feature branch
  3. Commit your changes
  4. Push to the branch
  5. Create a new Pull Request

Command Line Arguments

  • --output: Output format (console, json, markdown)
  • --duration: Analysis period (e.g., 6m, 1y, 30d)
  • --branch: Branch to analyze (optional, defaults to repository's default branch)

License

This project is licensed under the GNU General Public License v3.0 (GPL-3.0) - see below for details:

Permissions

  • βœ… Commercial use
  • βœ… Distribution
  • βœ… Modification
  • βœ… Private use

Conditions

  • ❗ Disclose source: Any modified version must be open source
  • ❗ License and copyright notice: Include the original license and copyright
  • ❗ Same license: Any modified version must use the same license (GPL-3.0)
  • ❗ State changes: Document all changes made to the code

Limitations

  • ❌ Liability: No warranty is provided
  • ❌ Trademark use: Does not grant trademark rights

For the full license text, see LICENSE file or visit https://www.gnu.org/licenses/gpl-3.0.en.html

Copyright (c) 2025 Erdem Kâşk

About

🚌 Your repo's fitness witness! Track your bus factor before your code misses the bus.

Resources

Stars

Watchers

Forks

Packages

No packages published