Some checks failed
CLI Tests / test-cli (push) Failing after 4s
Deploy to Testnet / deploy-testnet (push) Successful in 1m40s
Documentation Validation / validate-docs (push) Failing after 12s
Documentation Validation / validate-policies-strict (push) Successful in 4s
Integration Tests / test-service-integration (push) Successful in 2m42s
Package Tests / Python package - aitbc-agent-sdk (push) Failing after 34s
Package Tests / Python package - aitbc-core (push) Successful in 27s
Package Tests / Python package - aitbc-crypto (push) Successful in 13s
Package Tests / Python package - aitbc-sdk (push) Successful in 16s
Package Tests / JavaScript package - aitbc-sdk-js (push) Successful in 8s
Package Tests / JavaScript package - aitbc-token (push) Successful in 18s
Python Tests / test-python (push) Failing after 50s
Security Scanning / security-scan (push) Failing after 43s
Multi-Node Stress Testing / stress-test (push) Successful in 12s
Cross-Node Transaction Testing / transaction-test (push) Successful in 9s
- Created aitbc/_version.py with centralized version definition - Updated aitbc/__init__.py to import __version__ from _version module - Updated constants.py to use __version__ for PACKAGE_VERSION - Replaced print() calls with logger in decorators.py, events.py, queue_manager.py, and state.py - Added logger initialization using get_logger(__name__) in config.py, decorators.py, events.py, queue_manager.py, and state.py - Added cli/commands
206 lines
5.7 KiB
Python
206 lines
5.7 KiB
Python
"""Unit tests for plugin security service"""
|
|
|
|
import pytest
|
|
import sys
|
|
import sys
|
|
from pathlib import Path
|
|
from datetime import datetime, timezone
|
|
|
|
|
|
from main import app, SecurityScan, Vulnerability, SecurityReport, calculate_overall_score, generate_recommendations, get_severity_distribution, estimate_scan_time
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_app_initialization():
|
|
"""Test that the FastAPI app initializes correctly"""
|
|
assert app is not None
|
|
assert app.title == "AITBC Plugin Security Service"
|
|
assert app.version == "1.0.0"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_security_scan_model():
|
|
"""Test SecurityScan model"""
|
|
scan = SecurityScan(
|
|
plugin_id="plugin_123",
|
|
version="1.0.0",
|
|
plugin_type="cli",
|
|
scan_type="comprehensive",
|
|
priority="high"
|
|
)
|
|
assert scan.plugin_id == "plugin_123"
|
|
assert scan.version == "1.0.0"
|
|
assert scan.plugin_type == "cli"
|
|
assert scan.scan_type == "comprehensive"
|
|
assert scan.priority == "high"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_vulnerability_model():
|
|
"""Test Vulnerability model"""
|
|
vuln = Vulnerability(
|
|
cve_id="CVE-2023-1234",
|
|
severity="high",
|
|
title="Buffer Overflow",
|
|
description="Buffer overflow vulnerability",
|
|
affected_file="file.py",
|
|
line_number=42,
|
|
recommendation="Update to latest version"
|
|
)
|
|
assert vuln.cve_id == "CVE-2023-1234"
|
|
assert vuln.severity == "high"
|
|
assert vuln.title == "Buffer Overflow"
|
|
assert vuln.line_number == 42
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_vulnerability_model_optional_fields():
|
|
"""Test Vulnerability model with optional fields"""
|
|
vuln = Vulnerability(
|
|
cve_id=None,
|
|
severity="low",
|
|
title="Minor issue",
|
|
description="Description",
|
|
affected_file="file.py",
|
|
line_number=None,
|
|
recommendation="Fix it"
|
|
)
|
|
assert vuln.cve_id is None
|
|
assert vuln.line_number is None
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_security_report_model():
|
|
"""Test SecurityReport model"""
|
|
report = SecurityReport(
|
|
scan_id="scan_123",
|
|
plugin_id="plugin_123",
|
|
version="1.0.0",
|
|
scan_date=datetime.now(timezone.utc),
|
|
scan_duration=120.5,
|
|
overall_score="passed",
|
|
vulnerabilities=[],
|
|
security_metrics={},
|
|
recommendations=[]
|
|
)
|
|
assert report.scan_id == "scan_123"
|
|
assert report.overall_score == "passed"
|
|
assert report.scan_duration == 120.5
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_calculate_overall_score_passed():
|
|
"""Test calculate overall score with no vulnerabilities"""
|
|
scan_result = {"vulnerabilities": []}
|
|
score = calculate_overall_score(scan_result)
|
|
assert score == "passed"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_calculate_overall_score_critical():
|
|
"""Test calculate overall score with critical vulnerability"""
|
|
scan_result = {
|
|
"vulnerabilities": [
|
|
{"severity": "critical"},
|
|
{"severity": "low"}
|
|
]
|
|
}
|
|
score = calculate_overall_score(scan_result)
|
|
assert score == "critical"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_calculate_overall_score_failed():
|
|
"""Test calculate overall score with multiple high vulnerabilities"""
|
|
scan_result = {
|
|
"vulnerabilities": [
|
|
{"severity": "high"},
|
|
{"severity": "high"},
|
|
{"severity": "high"}
|
|
]
|
|
}
|
|
score = calculate_overall_score(scan_result)
|
|
assert score == "failed"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_calculate_overall_score_warning():
|
|
"""Test calculate overall score with high and medium vulnerabilities"""
|
|
scan_result = {
|
|
"vulnerabilities": [
|
|
{"severity": "high"},
|
|
{"severity": "medium"},
|
|
{"severity": "medium"},
|
|
{"severity": "medium"},
|
|
{"severity": "medium"},
|
|
{"severity": "medium"}
|
|
]
|
|
}
|
|
score = calculate_overall_score(scan_result)
|
|
assert score == "warning"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_generate_recommendations_no_vulnerabilities():
|
|
"""Test generate recommendations with no vulnerabilities"""
|
|
recommendations = generate_recommendations([])
|
|
assert len(recommendations) == 1
|
|
assert "No security issues detected" in recommendations[0]
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_generate_recommendations_critical():
|
|
"""Test generate recommendations with critical vulnerabilities"""
|
|
vulnerabilities = [
|
|
{"severity": "critical"},
|
|
{"severity": "high"}
|
|
]
|
|
recommendations = generate_recommendations(vulnerabilities)
|
|
assert any("CRITICAL" in r for r in recommendations)
|
|
assert any("HIGH" in r for r in recommendations)
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_get_severity_distribution():
|
|
"""Test get severity distribution"""
|
|
vulnerabilities = [
|
|
{"severity": "critical"},
|
|
{"severity": "high"},
|
|
{"severity": "high"},
|
|
{"severity": "medium"},
|
|
{"severity": "low"}
|
|
]
|
|
distribution = get_severity_distribution(vulnerabilities)
|
|
assert distribution["critical"] == 1
|
|
assert distribution["high"] == 2
|
|
assert distribution["medium"] == 1
|
|
assert distribution["low"] == 1
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_estimate_scan_time_basic():
|
|
"""Test estimate scan time for basic scan"""
|
|
time = estimate_scan_time("basic")
|
|
assert time == "1-2 minutes"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_estimate_scan_time_comprehensive():
|
|
"""Test estimate scan time for comprehensive scan"""
|
|
time = estimate_scan_time("comprehensive")
|
|
assert time == "5-10 minutes"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_estimate_scan_time_deep():
|
|
"""Test estimate scan time for deep scan"""
|
|
time = estimate_scan_time("deep")
|
|
assert time == "15-30 minutes"
|
|
|
|
|
|
@pytest.mark.unit
|
|
def test_estimate_scan_time_unknown():
|
|
"""Test estimate scan time for unknown scan type"""
|
|
time = estimate_scan_time("unknown")
|
|
assert time == "5-10 minutes"
|