{
  "_comment": "Ground-truth expected outcomes for the synthetic adversarial corpus. Each entry's `expected` field is what ProofGate should report. Used for unit-testing the pipeline against known cases before running on real prover artifacts.",
  "items": [
    {
      "file": "faithfulness/good_rfl.lean",
      "theorem": "good_rfl",
      "expected": {"check1_axioms": "pass", "check2_tactics": "pass", "check3_vacuity": "vacuous", "check4_alignment": "n/a"},
      "note": "Tautology-ish: 2+2=4 by rfl. Faithful but flagged as vacuous (decide closes negation). Demonstrates Check 3 firing correctly."
    },
    {
      "file": "faithfulness/good_classical.lean",
      "theorem": "good_classical",
      "expected": {"check1_axioms": "pass", "check2_tactics": "pass", "check3_vacuity": "non-vacuous", "check4_alignment": "n/a"},
      "note": "LEM. Uses Classical.choice (trusted). Faithful, non-vacuous."
    },
    {
      "file": "faithfulness/bad_sorry.lean",
      "theorem": "bad_sorry",
      "expected": {"check1_axioms": "fail", "check2_tactics": "fail", "check3_vacuity": "n/a", "check4_alignment": "n/a"},
      "note": "Explicit sorry. Both Checks 1 and 2 must fire."
    },
    {
      "file": "faithfulness/bad_hidden_sorry.lean",
      "theorem": "bad_hidden_sorry",
      "expected": {"check1_axioms": "fail", "check2_tactics": "fail", "check3_vacuity": "n/a", "check4_alignment": "n/a"},
      "note": "Sorry inside a `have` that isn't used. Kernel still drags sorryAx into the term. THIS IS THE KEY FAILURE MODE the proposal targets."
    },
    {
      "file": "faithfulness/bad_fresh_axiom.lean",
      "theorem": "bad_fresh_axiom",
      "expected": {"check1_axioms": "fail", "check2_tactics": "fail", "check3_vacuity": "n/a", "check4_alignment": "n/a"},
      "note": "Fresh axiom outside the trusted base. Caught by both Check 1 (kernel axiom inspection) and Check 2 (linter sees the `axiom` declaration). Defense in depth: the two checks must agree, since a fresh axiom could equally appear without any banned tactic or vice versa."
    },
    {
      "file": "faithfulness/bad_native_decide.lean",
      "theorem": "bad_native_decide",
      "expected": {"check1_axioms": "pass-with-flag", "check2_tactics": "flag", "check3_vacuity": "vacuous", "check4_alignment": "n/a"},
      "note": "native_decide is sound here but introduces compiler-trust axioms. Check 1 reports them with a flag; Check 2 raises a review flag."
    },
    {
      "file": "vacuity/vacuous_trivial.lean",
      "theorem": "vacuous_trivial",
      "expected": {"check1_axioms": "pass", "check2_tactics": "pass", "check3_vacuity": "vacuous", "check4_alignment": "n/a"},
      "note": "Reflexivity for all n. Check 3 should fire."
    },
    {
      "file": "vacuity/vacuous_ex_falso.lean",
      "theorem": "vacuous_ex_falso",
      "expected": {"check1_axioms": "pass", "check2_tactics": "pass", "check3_vacuity": "vacuous", "check4_alignment": "n/a"},
      "note": "Hypotheses unsatisfiable. Check 3 (or a contradiction probe on hypotheses) should fire."
    },
    {
      "file": "alignment/aligned_simple.lean",
      "theorem": "aligned_simple",
      "expected": {"check1_axioms": "n/a", "check2_tactics": "pass", "check3_vacuity": "non-vacuous", "check4_alignment": "aligned"},
      "informal": "The sum of two even natural numbers is even.",
      "note": "Alignment-corpus file: requires mathlib (Nat, ring_nf), so Check 1 is only meaningful when audited inside a lake project. We deliberately do NOT ship `#print axioms` here; in the audit pipeline, this file is consumed as a fixture for Check 4."
    },
    {
      "file": "alignment/misaligned_missing_hyp.lean",
      "theorem": "misaligned_missing_hyp",
      "expected": {"check1_axioms": "n/a", "check2_tactics": "fail", "check3_vacuity": "n/a", "check4_alignment": "misaligned"},
      "informal": "For every prime p > 2, p is odd.",
      "note": "Formal statement drops `p > 2`; Check 4 should flag misalignment. Proof body is also a `sorry`, so Check 2 fires; Check 1 not run standalone (needs mathlib)."
    }
  ]
}
