Compare commits
No commits in common. "a11127a64ea6d41326913cd4a7aac5066bcfe03f" and "5b278d68d4e8f6142a1803b132a8eafcae9d4cc6" have entirely different histories.
a11127a64e
...
5b278d68d4
|
@ -236,9 +236,9 @@ def execute (command: Protocol.Command): MainM Lean.Json := do
|
||||||
else
|
else
|
||||||
[]
|
[]
|
||||||
let messages ← step.messageStrings
|
let messages ← step.messageStrings
|
||||||
return (step.before, boundary, invocations?, sorrys, messages)
|
return (boundary, invocations?, sorrys, messages)
|
||||||
let li ← frontendM.run context |>.run' state
|
let li ← frontendM.run context |>.run' state
|
||||||
let units ← li.mapM λ (env, boundary, invocations?, sorrys, messages) => Lean.withEnv env do
|
let units ← li.mapM λ (boundary, invocations?, sorrys, messages) => do
|
||||||
let (goalStateId?, goals) ← if sorrys.isEmpty then do
|
let (goalStateId?, goals) ← if sorrys.isEmpty then do
|
||||||
pure (.none, #[])
|
pure (.none, #[])
|
||||||
else do
|
else do
|
||||||
|
|
|
@ -10,9 +10,9 @@ def collectSorrysFromSource (source: String) : MetaM (List GoalState) := do
|
||||||
let filename := "<anonymous>"
|
let filename := "<anonymous>"
|
||||||
let (context, state) ← do Frontend.createContextStateFromFile source filename (← getEnv) {}
|
let (context, state) ← do Frontend.createContextStateFromFile source filename (← getEnv) {}
|
||||||
let m := Frontend.mapCompilationSteps λ step => do
|
let m := Frontend.mapCompilationSteps λ step => do
|
||||||
return (step.before, Frontend.collectSorrys step)
|
return Frontend.collectSorrys step
|
||||||
let li ← m.run context |>.run' state
|
let li ← m.run context |>.run' state
|
||||||
let goalStates ← li.filterMapM λ (env, sorrys) => withEnv env do
|
let goalStates ← li.filterMapM λ sorrys => do
|
||||||
if sorrys.isEmpty then
|
if sorrys.isEmpty then
|
||||||
return .none
|
return .none
|
||||||
let goalState ← Frontend.sorrysToGoalState sorrys
|
let goalState ← Frontend.sorrysToGoalState sorrys
|
||||||
|
@ -159,24 +159,6 @@ example : ∀ (y: Nat), ∃ (x: Nat), y + 1 = x := by
|
||||||
}
|
}
|
||||||
])
|
])
|
||||||
|
|
||||||
def test_environment_capture: TestT MetaM Unit := do
|
|
||||||
let sketch := "
|
|
||||||
def mystery (n: Nat) := n + 1
|
|
||||||
|
|
||||||
example (n: Nat) : mystery n + 1 = n + 2 := sorry
|
|
||||||
"
|
|
||||||
let goalStates ← (collectSorrysFromSource sketch).run' {}
|
|
||||||
let [goalState] := goalStates | panic! s!"Incorrect number of states: {goalStates.length}"
|
|
||||||
addTest $ LSpec.check "goals" ((← goalState.serializeGoals (options := {})).map (·.devolatilize) = #[
|
|
||||||
{
|
|
||||||
target := { pp? := "mystery n + 1 = n + 2" },
|
|
||||||
vars := #[{
|
|
||||||
userName := "n",
|
|
||||||
type? := .some { pp? := "Nat" },
|
|
||||||
}],
|
|
||||||
}
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
def suite (env : Environment): List (String × IO LSpec.TestSeq) :=
|
def suite (env : Environment): List (String × IO LSpec.TestSeq) :=
|
||||||
let tests := [
|
let tests := [
|
||||||
|
@ -184,7 +166,6 @@ def suite (env : Environment): List (String × IO LSpec.TestSeq) :=
|
||||||
("sorry_in_middle", test_sorry_in_middle),
|
("sorry_in_middle", test_sorry_in_middle),
|
||||||
("sorry_in_induction", test_sorry_in_induction),
|
("sorry_in_induction", test_sorry_in_induction),
|
||||||
("sorry_in_coupled", test_sorry_in_coupled),
|
("sorry_in_coupled", test_sorry_in_coupled),
|
||||||
("environment_capture", test_environment_capture),
|
|
||||||
]
|
]
|
||||||
tests.map (fun (name, test) => (name, runMetaMSeq env $ runTest test))
|
tests.map (fun (name, test) => (name, runMetaMSeq env $ runTest test))
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue