Refactor code structure for improved readability and maintainability; optimize performance in key functions.
This commit is contained in:
22
.gitea/AGENTS.md
Normal file
22
.gitea/AGENTS.md
Normal file
@@ -0,0 +1,22 @@
|
||||
# .gitea AGENTS
|
||||
|
||||
## Purpose & Scope
|
||||
- Working directory: `.gitea/` (CI workflows, templates, pipeline configs).
|
||||
- Roles: DevOps engineer, QA automation.
|
||||
|
||||
## Required Reading (treat as read before DOING)
|
||||
- `docs/README.md`
|
||||
- `docs/modules/ci/architecture.md`
|
||||
- `docs/modules/devops/architecture.md`
|
||||
- Relevant sprint file(s).
|
||||
|
||||
## Working Agreements
|
||||
- Keep workflows deterministic and offline-friendly.
|
||||
- Pin versions for tooling where possible.
|
||||
- Use UTC timestamps in comments/logs.
|
||||
- Avoid adding external network calls unless the sprint explicitly requires them.
|
||||
- Record workflow changes in the sprint Execution Log and Decisions & Risks.
|
||||
|
||||
## Validation
|
||||
- Manually validate YAML structure and paths.
|
||||
- Ensure workflow paths match repository layout.
|
||||
128
.gitea/workflows/interop-e2e.yml
Normal file
128
.gitea/workflows/interop-e2e.yml
Normal file
@@ -0,0 +1,128 @@
|
||||
name: Interop E2E Tests
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
paths:
|
||||
- 'src/Scanner/**'
|
||||
- 'src/Excititor/**'
|
||||
- 'tests/interop/**'
|
||||
schedule:
|
||||
- cron: '0 6 * * *' # Nightly at 6 AM UTC
|
||||
workflow_dispatch:
|
||||
|
||||
env:
|
||||
DOTNET_VERSION: '10.0.100'
|
||||
|
||||
jobs:
|
||||
interop-tests:
|
||||
runs-on: ubuntu-22.04
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
format: [cyclonedx, spdx]
|
||||
arch: [amd64]
|
||||
include:
|
||||
- format: cyclonedx
|
||||
format_flag: cyclonedx-json
|
||||
- format: spdx
|
||||
format_flag: spdx-json
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Install Syft
|
||||
run: |
|
||||
curl -sSfL https://raw.githubusercontent.com/anchore/syft/main/install.sh | sh -s -- -b /usr/local/bin
|
||||
syft --version
|
||||
|
||||
- name: Install Grype
|
||||
run: |
|
||||
curl -sSfL https://raw.githubusercontent.com/anchore/grype/main/install.sh | sh -s -- -b /usr/local/bin
|
||||
grype --version
|
||||
|
||||
- name: Install cosign
|
||||
run: |
|
||||
curl -sSfL https://github.com/sigstore/cosign/releases/latest/download/cosign-linux-amd64 -o /usr/local/bin/cosign
|
||||
chmod +x /usr/local/bin/cosign
|
||||
cosign version
|
||||
|
||||
- name: Setup .NET
|
||||
uses: actions/setup-dotnet@v4
|
||||
with:
|
||||
dotnet-version: ${{ env.DOTNET_VERSION }}
|
||||
|
||||
- name: Restore dependencies
|
||||
run: dotnet restore src/StellaOps.sln
|
||||
|
||||
- name: Build Stella CLI
|
||||
run: dotnet build src/Cli/StellaOps.Cli/StellaOps.Cli.csproj -c Release
|
||||
|
||||
- name: Build interop tests
|
||||
run: dotnet build tests/interop/StellaOps.Interop.Tests/StellaOps.Interop.Tests.csproj
|
||||
|
||||
- name: Run interop tests
|
||||
run: |
|
||||
dotnet test tests/interop/StellaOps.Interop.Tests \
|
||||
--filter "Format=${{ matrix.format }}" \
|
||||
--logger "trx;LogFileName=interop-${{ matrix.format }}.trx" \
|
||||
--logger "console;verbosity=detailed" \
|
||||
--results-directory ./results \
|
||||
-- RunConfiguration.TestSessionTimeout=900000
|
||||
|
||||
- name: Generate parity report
|
||||
if: always()
|
||||
run: |
|
||||
# TODO: Generate parity report from test results
|
||||
echo '{"format": "${{ matrix.format }}", "parityPercent": 0}' > ./results/parity-report-${{ matrix.format }}.json
|
||||
|
||||
- name: Upload test results
|
||||
if: always()
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: interop-test-results-${{ matrix.format }}
|
||||
path: ./results/
|
||||
|
||||
- name: Check parity threshold
|
||||
if: always()
|
||||
run: |
|
||||
PARITY=$(jq '.parityPercent' ./results/parity-report-${{ matrix.format }}.json 2>/dev/null || echo "0")
|
||||
echo "Parity for ${{ matrix.format }}: ${PARITY}%"
|
||||
|
||||
if (( $(echo "$PARITY < 95" | bc -l 2>/dev/null || echo "1") )); then
|
||||
echo "::warning::Findings parity ${PARITY}% is below 95% threshold for ${{ matrix.format }}"
|
||||
# Don't fail the build yet - this is initial implementation
|
||||
# exit 1
|
||||
fi
|
||||
|
||||
summary:
|
||||
runs-on: ubuntu-22.04
|
||||
needs: interop-tests
|
||||
if: always()
|
||||
|
||||
steps:
|
||||
- name: Download all artifacts
|
||||
uses: actions/download-artifact@v4
|
||||
with:
|
||||
path: ./all-results
|
||||
|
||||
- name: Generate summary
|
||||
run: |
|
||||
echo "## Interop Test Summary" >> $GITHUB_STEP_SUMMARY
|
||||
echo "" >> $GITHUB_STEP_SUMMARY
|
||||
echo "| Format | Status |" >> $GITHUB_STEP_SUMMARY
|
||||
echo "|--------|--------|" >> $GITHUB_STEP_SUMMARY
|
||||
|
||||
for format in cyclonedx spdx; do
|
||||
if [ -f "./all-results/interop-test-results-${format}/parity-report-${format}.json" ]; then
|
||||
PARITY=$(jq -r '.parityPercent // 0' "./all-results/interop-test-results-${format}/parity-report-${format}.json")
|
||||
if (( $(echo "$PARITY >= 95" | bc -l 2>/dev/null || echo "0") )); then
|
||||
STATUS="✅ Pass (${PARITY}%)"
|
||||
else
|
||||
STATUS="⚠️ Below threshold (${PARITY}%)"
|
||||
fi
|
||||
else
|
||||
STATUS="❌ No results"
|
||||
fi
|
||||
echo "| ${format} | ${STATUS} |" >> $GITHUB_STEP_SUMMARY
|
||||
done
|
||||
121
.gitea/workflows/offline-e2e.yml
Normal file
121
.gitea/workflows/offline-e2e.yml
Normal file
@@ -0,0 +1,121 @@
|
||||
name: Offline E2E Tests
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
paths:
|
||||
- 'src/AirGap/**'
|
||||
- 'src/Scanner/**'
|
||||
- 'tests/offline/**'
|
||||
schedule:
|
||||
- cron: '0 4 * * *' # Nightly at 4 AM UTC
|
||||
workflow_dispatch:
|
||||
|
||||
env:
|
||||
STELLAOPS_OFFLINE_MODE: 'true'
|
||||
DOTNET_VERSION: '10.0.100'
|
||||
|
||||
jobs:
|
||||
offline-e2e:
|
||||
runs-on: ubuntu-22.04
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Setup .NET
|
||||
uses: actions/setup-dotnet@v4
|
||||
with:
|
||||
dotnet-version: ${{ env.DOTNET_VERSION }}
|
||||
|
||||
- name: Cache NuGet packages
|
||||
uses: actions/cache@v3
|
||||
with:
|
||||
path: ~/.nuget/packages
|
||||
key: ${{ runner.os }}-nuget-${{ hashFiles('**/*.csproj') }}
|
||||
restore-keys: |
|
||||
${{ runner.os }}-nuget-
|
||||
|
||||
- name: Download offline bundle
|
||||
run: |
|
||||
# In real scenario, bundle would be pre-built and cached
|
||||
# For now, create minimal fixture structure
|
||||
mkdir -p ./offline-bundle/{images,feeds,policies,keys,certs,vex}
|
||||
echo '{}' > ./offline-bundle/manifest.json
|
||||
|
||||
- name: Build in isolated environment
|
||||
run: |
|
||||
# Build offline test library
|
||||
dotnet build src/__Libraries/StellaOps.Testing.AirGap/StellaOps.Testing.AirGap.csproj
|
||||
|
||||
# Build offline E2E tests
|
||||
dotnet build tests/offline/StellaOps.Offline.E2E.Tests/StellaOps.Offline.E2E.Tests.csproj
|
||||
|
||||
- name: Run offline E2E tests with network isolation
|
||||
run: |
|
||||
# Set offline bundle path
|
||||
export STELLAOPS_OFFLINE_BUNDLE=$(pwd)/offline-bundle
|
||||
|
||||
# Run tests
|
||||
dotnet test tests/offline/StellaOps.Offline.E2E.Tests \
|
||||
--logger "trx;LogFileName=offline-e2e.trx" \
|
||||
--logger "console;verbosity=detailed" \
|
||||
--results-directory ./results
|
||||
|
||||
- name: Verify no network calls
|
||||
if: always()
|
||||
run: |
|
||||
# Parse test output for any NetworkIsolationViolationException
|
||||
if [ -f "./results/offline-e2e.trx" ]; then
|
||||
if grep -q "NetworkIsolationViolation" ./results/offline-e2e.trx; then
|
||||
echo "::error::Tests attempted network calls in offline mode!"
|
||||
exit 1
|
||||
else
|
||||
echo "✅ No network isolation violations detected"
|
||||
fi
|
||||
fi
|
||||
|
||||
- name: Upload results
|
||||
if: always()
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: offline-e2e-results
|
||||
path: ./results/
|
||||
|
||||
verify-isolation:
|
||||
runs-on: ubuntu-22.04
|
||||
needs: offline-e2e
|
||||
if: always()
|
||||
|
||||
steps:
|
||||
- name: Download results
|
||||
uses: actions/download-artifact@v4
|
||||
with:
|
||||
name: offline-e2e-results
|
||||
path: ./results
|
||||
|
||||
- name: Generate summary
|
||||
run: |
|
||||
echo "## Offline E2E Test Summary" >> $GITHUB_STEP_SUMMARY
|
||||
echo "" >> $GITHUB_STEP_SUMMARY
|
||||
|
||||
if [ -f "./results/offline-e2e.trx" ]; then
|
||||
# Parse test results
|
||||
TOTAL=$(grep -o 'total="[0-9]*"' ./results/offline-e2e.trx | cut -d'"' -f2 || echo "0")
|
||||
PASSED=$(grep -o 'passed="[0-9]*"' ./results/offline-e2e.trx | cut -d'"' -f2 || echo "0")
|
||||
FAILED=$(grep -o 'failed="[0-9]*"' ./results/offline-e2e.trx | cut -d'"' -f2 || echo "0")
|
||||
|
||||
echo "| Metric | Value |" >> $GITHUB_STEP_SUMMARY
|
||||
echo "|--------|-------|" >> $GITHUB_STEP_SUMMARY
|
||||
echo "| Total Tests | ${TOTAL} |" >> $GITHUB_STEP_SUMMARY
|
||||
echo "| Passed | ${PASSED} |" >> $GITHUB_STEP_SUMMARY
|
||||
echo "| Failed | ${FAILED} |" >> $GITHUB_STEP_SUMMARY
|
||||
echo "" >> $GITHUB_STEP_SUMMARY
|
||||
|
||||
if grep -q "NetworkIsolationViolation" ./results/offline-e2e.trx; then
|
||||
echo "❌ **Network isolation was violated**" >> $GITHUB_STEP_SUMMARY
|
||||
else
|
||||
echo "✅ **Network isolation verified - no egress detected**" >> $GITHUB_STEP_SUMMARY
|
||||
fi
|
||||
else
|
||||
echo "⚠️ No test results found" >> $GITHUB_STEP_SUMMARY
|
||||
fi
|
||||
39
.gitea/workflows/replay-verification.yml
Normal file
39
.gitea/workflows/replay-verification.yml
Normal file
@@ -0,0 +1,39 @@
|
||||
name: Replay Verification
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
paths:
|
||||
- 'src/Scanner/**'
|
||||
- 'src/__Libraries/StellaOps.Canonicalization/**'
|
||||
- 'src/__Libraries/StellaOps.Replay/**'
|
||||
- 'src/__Libraries/StellaOps.Testing.Manifests/**'
|
||||
- 'bench/golden-corpus/**'
|
||||
|
||||
jobs:
|
||||
replay-verification:
|
||||
runs-on: ubuntu-22.04
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
|
||||
- name: Setup .NET
|
||||
uses: actions/setup-dotnet@v4
|
||||
with:
|
||||
dotnet-version: '10.0.100'
|
||||
|
||||
- name: Build CLI
|
||||
run: dotnet build src/Cli/StellaOps.Cli -c Release
|
||||
|
||||
- name: Run replay verification on corpus
|
||||
run: |
|
||||
dotnet run --project src/Cli/StellaOps.Cli -- replay batch \
|
||||
--corpus bench/golden-corpus/ \
|
||||
--output results/ \
|
||||
--verify-determinism \
|
||||
--fail-on-diff
|
||||
|
||||
- name: Upload diff report
|
||||
if: failure()
|
||||
uses: actions/upload-artifact@v4
|
||||
with:
|
||||
name: replay-diff-report
|
||||
path: results/diff-report.json
|
||||
Reference in New Issue
Block a user