pmat 3.15.0

PMAT - Zero-config AI context generation and code quality toolkit (CLI, MCP, HTTP)
#![allow(unused)]
#![cfg_attr(coverage_nightly, coverage(off))]
//! Quality gate enforcement for roadmap tasks

use super::{DateTime, QualityGateConfig, Utc};
use anyhow::Result;
use serde::{Deserialize, Serialize};

/// Quality check types
#[derive(Debug, Clone, Serialize, Deserialize)]
pub enum QualityCheck {
    Complexity(u32),
    TestCoverage(u8),
    Documentation,
    NoSatd,
    LintCompliance,
    RoadmapUpdated,
}

/// Result of a quality check
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct CheckResult {
    pub check: QualityCheck,
    pub passed: bool,
    pub message: String,
    pub details: Option<String>,
}

/// Quality report for a task
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct QualityReport {
    pub task_id: String,
    pub timestamp: DateTime<Utc>,
    pub checks: Vec<CheckResult>,
    pub overall_passed: bool,
}

impl QualityReport {
    #[must_use]
    #[provable_contracts_macros::contract("pmat-core.yaml", equation = "check_compliance")]
    /// Create a new instance.
    pub fn new(task_id: &str) -> Self {
        Self {
            task_id: task_id.to_string(),
            timestamp: Utc::now(),
            checks: Vec::new(),
            overall_passed: true,
        }
    }

    #[provable_contracts_macros::contract("pmat-core.yaml", equation = "check_compliance")]
    /// Add check result.
    pub fn add_check_result(&mut self, _check: QualityCheck, result: CheckResult) {
        if !result.passed {
            self.overall_passed = false;
        }
        self.checks.push(result);
    }

    #[must_use]
    #[provable_contracts_macros::contract("pmat-core.yaml", equation = "check_compliance")]
    /// Passed.
    pub fn passed(&self) -> bool {
        self.overall_passed
    }
}

/// Task-level quality gate
pub struct TaskQualityGate {
    task_id: String,
    checks: Vec<QualityCheck>,
    config: QualityGateConfig,
}

/// Quality gate enforcer for strict quality control
pub struct QualityGateEnforcer {
    pub config: QualityGateConfig,
}

// TaskQualityGate async validation methods and coverage parsing
include!("quality_validation.rs");

// QualityGateEnforcer implementation, QualityCheck::matches, and coverage extraction helpers
include!("quality_enforcer.rs");

// Unit tests and property tests
include!("quality_tests.rs");