Skip to main content

GitLab issue anomaly detection and page generation

Project description

GitLab Issue Anomaly Detector

A Python package for detecting anomalies in GitLab issues and generating HTML reports.

Overview

This package analyzes GitLab issues to detect various anomalies such as:

  • Missing milestones or iterations
  • Insufficient descriptions
  • Stale issues
  • Blocked issues without details
  • And many more

It generates a comprehensive HTML report with interactive visualizations to help teams identify and address these anomalies.

Installation

pip install gitlab-detector

Usage

Command Line

# Run the anomaly detector and generate a report
gitlab-anomaly-detector

Environment Variables

Create a .env file with the following variables:

GITLAB_URL=https://gitlab.com
GITLAB_TOKEN=your_personal_access_token
GITLAB_PROJECT_ID=your_project_id

Viewing the Report

After running the tool, you can view the generated report by starting a local HTTP server:

python -m http.server 8008 -d public/

Then open your browser to http://localhost:8008

Features

Anomaly Detection

  • Issue Hygiene: Detect issues with poor descriptions, missing milestones, or missing iterations
  • Workflow Impediments: Identify blocked issues, stale issues, and scope creep
  • Priority Management: Flag high-priority issues that lack proper attention
  • Timeline Analysis: Track issues that are at risk of missing deadlines

Reporting

  • Interactive Dashboard: Filter and sort anomalies by type, severity, and owner
  • Milestone View: Group anomalies by milestone to identify at-risk deliverables
  • Iteration View: Track anomalies within your agile iterations
  • Export Functionality: Export data to Excel for further analysis

Testing

This package follows strict test-driven development practices. To run the tests:

# Activate the virtual environment
source .venv/bin/activate

# Run tests with pytest
python -m pytest tests/

Logging

The package implements robust logging throughout the codebase. Logs are output to stdout by default but can be configured via Python's standard logging module.

Example log output:

2025-05-15 22:57:01,584 - scripts.issue_anomaly_detector - DEBUG - Categorized anomaly 'poor_description' as 'hygiene'
2025-05-15 22:57:01,584 - scripts.issue_anomaly_detector - DEBUG - Categorized anomaly 'missing_milestone' as 'hygiene'

GitLab Pages with Dynamic Content

This project includes a custom GitLab CI/CD pipeline for GitLab Pages that generates dynamic content:

  1. A prepare-pages stage runs before the pages stage
  2. A Python script (scripts/prepare_pages.py) generates dynamic content:
    • Creates a data.json file with timestamp and sample data
    • Updates index.html to load and display the dynamic content
  3. The pages stage deploys the generated content

When you push to the main branch, the pipeline automatically runs and deploys your site to GitLab Pages.


Contributing

Contributions are welcome! Please follow these steps to contribute:

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/your-feature-name
  3. Commit your changes: git commit -am 'Add some feature'
  4. Push to the branch: git push origin feature/your-feature-name
  5. Submit a pull request

Development Setup

# Clone the repository
git clone https://gitlab.com/my-group-name2452611/my-project-name.git
cd my-project-name

# Create and activate virtual environment
python -m venv .venv
source .venv/bin/activate

# Install development dependencies
pip install -e .[dev]

Coding Standards

This project follows strict test-driven development practices:

  • Write tests before implementing features
  • Maintain high test coverage
  • Implement robust logging throughout the codebase
  • Follow PEP 8 style guidelines

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gitlab_detector-0.1.3.tar.gz (55.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gitlab_detector-0.1.3-py3-none-any.whl (61.0 kB view details)

Uploaded Python 3

File details

Details for the file gitlab_detector-0.1.3.tar.gz.

File metadata

  • Download URL: gitlab_detector-0.1.3.tar.gz
  • Upload date:
  • Size: 55.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for gitlab_detector-0.1.3.tar.gz
Algorithm Hash digest
SHA256 e81dd13d7dab349054887804839c0dcd88074eb1e067290d7abd0dc2acfd9df3
MD5 81ec0d6865782fb40bad9bdb1c138f01
BLAKE2b-256 718660f1355bf2415e3dba05b35e0a4a1720a07f51650ec3f1f214a397d5e3be

See more details on using hashes here.

File details

Details for the file gitlab_detector-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for gitlab_detector-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e9af68ec6e6ac5b7303b02e4470447f2677f4c923390ca95179b735c689be338
MD5 5e987eee08f3b597849b7bcf357bd46f
BLAKE2b-256 4863c293d7f572ec6353894ce2fd420ba00c687d52067cf86669f53884c01123

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page