Skip to content

Commit

Permalink
pythonGH-91054: Reset static events counts in code watchers tests (py…
Browse files Browse the repository at this point in the history
  • Loading branch information
itamaro authored Dec 4, 2022
1 parent 76f43fc commit 1012dc1
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 3 deletions.
6 changes: 3 additions & 3 deletions Lib/test/test_capi/test_watchers.py
Original file line number Diff line number Diff line change
Expand Up @@ -383,11 +383,11 @@ def test_code_object_events_dispatched(self):
del co3
self.assert_event_counts(2, 2, 1, 1)

# verify counts remain as they were after both watchers are cleared
# verify counts are reset and don't change after both watchers are cleared
co4 = _testcapi.code_newempty("test_watchers", "dummy4", 0)
self.assert_event_counts(2, 2, 1, 1)
self.assert_event_counts(0, 0, 0, 0)
del co4
self.assert_event_counts(2, 2, 1, 1)
self.assert_event_counts(0, 0, 0, 0)

def test_clear_out_of_range_watcher_id(self):
with self.assertRaisesRegex(ValueError, r"Invalid code watcher ID -1"):
Expand Down
9 changes: 9 additions & 0 deletions Modules/_testcapi/watchers.c
Original file line number Diff line number Diff line change
Expand Up @@ -325,9 +325,13 @@ add_code_watcher(PyObject *self, PyObject *which_watcher)
long which_l = PyLong_AsLong(which_watcher);
if (which_l == 0) {
watcher_id = PyCode_AddWatcher(first_code_object_callback);
num_code_object_created_events[0] = 0;
num_code_object_destroyed_events[0] = 0;
}
else if (which_l == 1) {
watcher_id = PyCode_AddWatcher(second_code_object_callback);
num_code_object_created_events[1] = 0;
num_code_object_destroyed_events[1] = 0;
}
else {
return NULL;
Expand All @@ -346,6 +350,11 @@ clear_code_watcher(PyObject *self, PyObject *watcher_id)
if (PyCode_ClearWatcher(watcher_id_l) < 0) {
return NULL;
}
// reset static events counters
if (watcher_id_l >= 0 && watcher_id_l < NUM_CODE_WATCHERS) {
num_code_object_created_events[watcher_id_l] = 0;
num_code_object_destroyed_events[watcher_id_l] = 0;
}
Py_RETURN_NONE;
}

Expand Down

0 comments on commit 1012dc1

Please sign in to comment.