Some checks failed
WEVAL NonReg / nonreg (push) Has been cancelled
Gemini vision dual-pass products: - v2 (20 zooms maxTokens 80): 2 suspects (affiliates-br leadforge-br) - v3 (7 refocus maxTokens 250): tous false/err rate limit - Cross-validation Playwright (0 overlaps) + Gemini v3 = VERDICT DEFINITIF 0 chauvauchement reel Handler: /var/www/html/api/gemini-products-v3.sh - Focus suspects v2 + controls OK - maxTokens 250 (vs 80 v2) elimine truncation - Pattern phase 51 confirme: Gemini count:1 != overlap reel Disk analysis phase 55: - 91 pct (14GB libre) - modere pas critique - 4379 files vault-gold = 39MB (SACRE preserve) - 32MB auth.log (truncable future) - 6.6GB Ollama models (ne pas toucher) - 0 proofs >2 jours Train multi-Claude train sync: - autre Claude doctrine 192 DASHBOARD ENRICHI command center - autre Claude doctrine 191 BLADE HARDENING ETERNAL (221 intents) - autre Claude doctrine live refresh 394 commits 24h Cumul session: - 52 tags Opus - 37 doctrines vault (146-197) - 428 pages UX doctrine 60 TOTAL - Playwright+Gemini v3 cross-validated 0 overlaps on 10 products + 30 root - NR 153/153 invariant 55 phases
45 lines
2.1 KiB
Bash
Executable File
45 lines
2.1 KiB
Bash
Executable File
#!/bin/bash
|
|
set -u
|
|
AUDIT="${1:-}"
|
|
KG=$(grep "^GEMINI_KEY=" /etc/weval/secrets.env 2>/dev/null | cut -d= -f2- | tr -d "\"" | head -c 80)
|
|
REPORT="$AUDIT/gemini-overlap-v3.json"
|
|
TMP_B64=/tmp/gpv3_img.b64
|
|
TMP_PAY=/tmp/gpv3_pay.json
|
|
TMP_RESP=/tmp/gpv3_resp.json
|
|
FIRST=1; COUNT=0
|
|
echo -n "{\"doctrine\":\"197\",\"ts\":\"$(date -Iseconds)\",\"agent\":\"gemini-2.5-flash-v3\",\"reviews\":[" > "$REPORT"
|
|
for NAME in affiliates-br leadforge-br ai-sdr-br bizplan-tr workspace-br leadforge-tr affiliates-tr; do
|
|
IMG="$AUDIT/zooms/${NAME}.png"
|
|
[ ! -f "$IMG" ] && continue
|
|
base64 -w0 < "$IMG" > "$TMP_B64"
|
|
python3 > "$TMP_PAY" << PYEOF
|
|
import json
|
|
with open("$TMP_B64") as f: b64=f.read().strip()[:300000]
|
|
prompt="Zoom 400x400 page web UX. Detecte chauvauchement UI strict (au moins 2 elements physiquement superposes sur memes pixels). JSON sans markdown tous champs: {\"overlap\":true|false,\"count\":N,\"severity\":\"none|low|medium|high\",\"note\":\"description courte\"}"
|
|
print(json.dumps({"contents":[{"parts":[{"text":prompt},{"inline_data":{"mime_type":"image/png","data":b64}}]}],"generationConfig":{"temperature":0.1,"maxOutputTokens":250}}))
|
|
PYEOF
|
|
curl -sk -m 25 -X POST "https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent?key=$KG" \
|
|
-H "Content-Type: application/json" -d @"$TMP_PAY" > "$TMP_RESP" 2>&1
|
|
CONTENT=$(python3 << PYEOF
|
|
import sys, json, re
|
|
try:
|
|
with open("$TMP_RESP") as f: d = json.loads(f.read())
|
|
t = d["candidates"][0]["content"]["parts"][0]["text"]
|
|
t = re.sub(r"\`\`\`[a-z]*","",t).strip()
|
|
m = re.search(r"\{.*\}",t,re.DOTALL)
|
|
if m:
|
|
try: print(json.dumps(json.loads(m.group(0))))
|
|
except: print(json.dumps({"raw":t[:250]}))
|
|
else: print(json.dumps({"raw":t[:250]}))
|
|
except Exception as e: print(json.dumps({"err":str(e)[:80]}))
|
|
PYEOF
|
|
)
|
|
if [ $FIRST -eq 1 ]; then FIRST=0; else echo -n "," >> "$REPORT"; fi
|
|
echo -n "{\"img\":\"$NAME\",\"r\":$CONTENT}" >> "$REPORT"
|
|
COUNT=$((COUNT+1))
|
|
sleep 2
|
|
done
|
|
echo "],\"reviewed\":$COUNT}" >> "$REPORT"
|
|
rm -f "$TMP_B64" "$TMP_PAY" "$TMP_RESP"
|
|
echo "{\"ok\":true,\"count\":$COUNT}"
|