BlogDocs

feat!: Rename `recursion_mode` to `reemission`. Rename `deferred` to `queued`. Add `latest-only` mode. (technically breaking)(#296)

Merged
Comparing
tlambert03:immediate-drop
(
277f8c6
) with
main
(
f6cebcb
)
-14%
IMPROVEMENTS
0
REGRESSIONS
1
UNTOUCHED
65
NEW
0
DROPPED
0
IGNORED
0

Benchmarks

Passed

test_emit_time[real_func-50]
tests/test_bench.py::test_emit_time[real_func-50]
+1%
168.6 µs
167.3 µs
test_connect_time[function-]
tests/test_bench.py::test_connect_time[function-]
0%
141.2 µs
140.8 µs
test_emit_time[function-2]
tests/test_bench.py::test_emit_time[function-2]
0%
64.8 µs
64.7 µs
test_emit_time[partial_method-18]
tests/test_bench.py::test_emit_time[partial_method-18]
0%
94.5 µs
94.6 µs
test_dataclass_setattr[dataclass]
tests/test_bench.py::test_dataclass_setattr[dataclass]
0%
750.1 µs
750.4 µs
test_connect_time[real_func-check_types]
tests/test_bench.py::test_connect_time[real_func-check_types]
0%
126.9 µs
127 µs
test_connect_time[lambda-]
tests/test_bench.py::test_connect_time[lambda-]
0%
140.3 µs
140.4 µs
test_emit_time[partial-34]
tests/test_bench.py::test_emit_time[partial-34]
0%
108.6 µs
108.7 µs
test_dataclass_setattr[attrs]
tests/test_bench.py::test_dataclass_setattr[attrs]
0%
770.1 µs
771.1 µs
test_connect_time[print-]
tests/test_bench.py::test_connect_time[print-]
0%
145.9 µs
146.1 µs
test_dataclass_setattr[msgspec]
tests/test_bench.py::test_dataclass_setattr[msgspec]
0%
765.7 µs
767 µs
test_connect_time[lambda-check_types]
tests/test_bench.py::test_connect_time[lambda-check_types]
0%
144.3 µs
144.6 µs
test_connect_time[method-]
tests/test_bench.py::test_connect_time[method-]
0%
176.4 µs
176.7 µs
test_connect_time[partial_method-]
tests/test_bench.py::test_connect_time[partial_method-]
0%
276.3 µs
276.8 µs
test_connect_time[real_func-]
tests/test_bench.py::test_connect_time[real_func-]
0%
123.5 µs
123.7 µs
test_emit_time[print-34]
tests/test_bench.py::test_emit_time[print-34]
0%
272.6 µs
273.2 µs
test_emit_time[setitem-50]
tests/test_bench.py::test_emit_time[setitem-50]
0%
93.7 µs
94 µs
test_emit_time[setitem-34]
tests/test_bench.py::test_emit_time[setitem-34]
0%
81.9 µs
82.1 µs
test_connect_time[print-check_types]
tests/test_bench.py::test_connect_time[print-check_types]
0%
206.7 µs
207.4 µs
test_dataclass_setattr[pydantic]
tests/test_bench.py::test_dataclass_setattr[pydantic]
0%
856.9 µs
859.7 µs
test_emit_time[setitem-2]
tests/test_bench.py::test_emit_time[setitem-2]
0%
57.8 µs
58 µs
test_emit_time[print-50]
tests/test_bench.py::test_emit_time[print-50]
0%
370 µs
371.5 µs
test_connect_time[partial-check_types]
tests/test_bench.py::test_connect_time[partial-check_types]
0%
258.3 µs
259.3 µs
test_emit_time[partial_method-50]
tests/test_bench.py::test_emit_time[partial_method-50]
0%
152.1 µs
152.8 µs
test_emit_time[print-2]
tests/test_bench.py::test_emit_time[print-2]
0%
85.4 µs
85.8 µs
test_emit_time[real_func-18]
tests/test_bench.py::test_emit_time[real_func-18]
0%
99.3 µs
99.8 µs
test_emit_time[setitem-18]
tests/test_bench.py::test_emit_time[setitem-18]
0%
69.5 µs
69.8 µs
test_create_signal
tests/test_bench.py::test_create_signal
-1%
75.2 µs
75.6 µs
test_emit_time[print-18]
tests/test_bench.py::test_emit_time[print-18]
-1%
175.9 µs
176.8 µs
test_evented_creation
tests/test_bench.py::test_evented_creation
-1%
1.7 ms
1.7 ms
test_emit_time[setattr-34]
tests/test_bench.py::test_emit_time[setattr-34]
-1%
69.5 µs
69.9 µs
test_connect_time[method-check_types]
tests/test_bench.py::test_connect_time[method-check_types]
-1%
183.3 µs
184.5 µs
test_emit_time[function-34]
tests/test_bench.py::test_emit_time[function-34]
-1%
85.9 µs
86.4 µs
test_connect_time[partial-]
tests/test_bench.py::test_connect_time[partial-]
-1%
244.8 µs
246.3 µs
test_emit_time[setattr-18]
tests/test_bench.py::test_emit_time[setattr-18]
-1%
62.4 µs
62.8 µs
test_connect_time[function-check_types]
tests/test_bench.py::test_connect_time[function-check_types]
-1%
156.1 µs
157.1 µs
test_emit_time[real_func-34]
tests/test_bench.py::test_emit_time[real_func-34]
-1%
133 µs
133.9 µs
test_connect_time[setitem-check_types]
tests/test_bench.py::test_connect_time[setitem-check_types]
-1%
67.4 µs
67.8 µs
test_emit_time[method-50]
tests/test_bench.py::test_emit_time[method-50]
-1%
124 µs
124.9 µs
test_emit_time[setattr-50]
tests/test_bench.py::test_emit_time[setattr-50]
-1%
76 µs
76.7 µs
test_emit_time[lambda-50]
tests/test_bench.py::test_emit_time[lambda-50]
-1%
99.6 µs
100.4 µs
test_emit_time[partial_method-34]
tests/test_bench.py::test_emit_time[partial_method-34]
-1%
121.2 µs
122.3 µs
test_connect_time[setattr-check_types]
tests/test_bench.py::test_connect_time[setattr-check_types]
-1%
67.9 µs
68.5 µs
test_emit_time[function-50]
tests/test_bench.py::test_emit_time[function-50]
-1%
99.6 µs
100.5 µs
test_emit_time[setattr-2]
tests/test_bench.py::test_emit_time[setattr-2]
-1%
55.4 µs
55.9 µs
test_emit_time[real_func-2]
tests/test_bench.py::test_emit_time[real_func-2]
-1%
64.5 µs
65.1 µs
test_connect_time[partial_method-check_types]
tests/test_bench.py::test_connect_time[partial_method-check_types]
-1%
283.3 µs
286.1 µs
test_emit_time[method-34]
tests/test_bench.py::test_emit_time[method-34]
-1%
103 µs
104 µs
test_emit_time[partial-50]
tests/test_bench.py::test_emit_time[partial-50]
-1%
131.8 µs
133.2 µs
test_emit_time[method-2]
tests/test_bench.py::test_emit_time[method-2]
-1%
61.6 µs
62.2 µs
test_dataclass_group_create[pydantic]
tests/test_bench.py::test_dataclass_group_create[pydantic]
-1%
608 µs
614.6 µs
test_emit_time[method-18]
tests/test_bench.py::test_emit_time[method-18]
-1%
81.9 µs
82.8 µs
test_evented_setattr
tests/test_bench.py::test_evented_setattr
-1%
26.8 µs
27.1 µs
test_connect_time[setattr-]
tests/test_bench.py::test_connect_time[setattr-]
-1%
62.1 µs
62.9 µs
test_connect_time[setitem-]
tests/test_bench.py::test_connect_time[setitem-]
-1%
62.5 µs
63.3 µs
test_emit_time[lambda-34]
tests/test_bench.py::test_emit_time[lambda-34]
-1%
85.5 µs
86.6 µs
test_emit_time[function-18]
tests/test_bench.py::test_emit_time[function-18]
-1%
71.4 µs
72.4 µs
test_emit_time[lambda-2]
tests/test_bench.py::test_emit_time[lambda-2]
-2%
57.8 µs
58.7 µs
test_emit_time[lambda-18]
tests/test_bench.py::test_emit_time[lambda-18]
-2%
71.4 µs
72.5 µs
test_dataclass_group_create[dataclass]
tests/test_bench.py::test_dataclass_group_create[dataclass]
-2%
514.7 µs
523.3 µs
test_dataclass_group_create[msgspec]
tests/test_bench.py::test_dataclass_group_create[msgspec]
-2%
601.8 µs
612.2 µs
test_dataclass_group_create[attrs]
tests/test_bench.py::test_dataclass_group_create[attrs]
-2%
597 µs
608.3 µs
test_emit_time[partial_method-2]
tests/test_bench.py::test_emit_time[partial_method-2]
-2%
63.9 µs
65.1 µs
test_emit_time[partial-2]
tests/test_bench.py::test_emit_time[partial-2]
-2%
59.9 µs
61.2 µs
test_emit_time[partial-18]
tests/test_bench.py::test_emit_time[partial-18]
-2%
84 µs
86 µs
test_create_signal_instanceRegression
tests/test_bench.py::test_create_signal_instance
-14%
28.4 µs
33 µs

Commits

Click on a commit to change the comparison range
base
main
f6cebcb
0%
feat: add immediate-drop recursion mode
9982e11
8 months ago
by tlambert03
0%
Update src/psygnal/_signal.py Co-authored-by: Grzegorz Bokota <bokota+github@gmail.com>
35dcc35
8 months ago
by tlambert03
-1%
Merge branch 'main' into immediate-drop
cee62f7
8 months ago
by tlambert03
0%
rename
071875f
7 months ago
by tlambert03
0%
module docstring
df2d2bf
7 months ago
by tlambert03
-15%
Merge branch 'main' into immediate-drop
dc342c5
7 months ago
by tlambert03
+1%
remove replace
277f8c6
7 months ago
by tlambert03
ResourcesHomePricingDocsBlogGitHubChangelog
Copyright © 2024 CodSpeed Technology SAS. All rights reserved.