Clean up pdb state after each pdb doctest #132577
                
     Merged
            
            
          
  Add this suggestion to a batch that can be applied as a single commit.
  This suggestion is invalid because no changes were made to the code.
  Suggestions cannot be applied while the pull request is closed.
  Suggestions cannot be applied while viewing a subset of changes.
  Only one suggestion per line can be applied in a batch.
  Add this suggestion to a batch that can be applied as a single commit.
  Applying suggestions on deleted lines is not supported.
  You must change the existing code in this line in order to create a valid suggestion.
  Outdated suggestions cannot be applied.
  This suggestion has been applied or marked resolved.
  Suggestions cannot be applied from pending reviews.
  Suggestions cannot be applied on multi-line comments.
  Suggestions cannot be applied while the pull request is queued to merge.
  Suggestion cannot be applied right now. Please check back later.
  
    
  
    
I can't remember how many times I was bitten by this, so I'll just step up and fix it. The pdb doctests could have residue states. For example, if the breakpoint is not cleared, pdb won't stop tracing after
continue. This makes the behavior of next pdb instance hard to predict, especially if it switches the backend.We don't have to suffer from this. Nothing bad could happen if we simply clean up after the test. The tests should be independent and isolated anyway. I will just clear all the breakpoints, stop the tracing and clear the pdb instance cache after each doctest.
Now that it's done for every test, we don't need
reset_Breakpointanymore. Every test is a brand new one :)No user observable behavior change, it's a pure test refactoring + improvement.