aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEddy Pedroni <epedroni@pm.me>2025-03-01 11:08:20 +0100
committerEddy Pedroni <epedroni@pm.me>2025-03-01 11:08:20 +0100
commitc593f9635c941ba4a876fa2f3a5ecc734ce02e4d (patch)
tree1a9f2b7bf98b59d71995924bd6ccd283d585d854
parent818859c4562a5f9fef4e74964ca31e4381ce6995 (diff)
Fix bugs in relative keypoint handler
-rw-r--r--solo-tool-project/src/solo_tool/handlers.py9
-rw-r--r--solo-tool-project/test/handlers_integrationtest.py32
2 files changed, 37 insertions, 4 deletions
diff --git a/solo-tool-project/src/solo_tool/handlers.py b/solo-tool-project/src/solo_tool/handlers.py
index b178b3a..1820e86 100644
--- a/solo-tool-project/src/solo_tool/handlers.py
+++ b/solo-tool-project/src/solo_tool/handlers.py
@@ -56,14 +56,15 @@ def keyPointAbsolute(st: SoloTool, kp: float) -> Callable[[], None]:
def keyPointRelative(st: SoloTool, delta: int) -> Callable[[], None]:
from bisect import bisect_right, bisect_left
def f():
+ l = sorted(set(st.keyPoints + [st.keyPoint]))
if delta > 0:
- pivot = bisect_right(st.keyPoints, st.keyPoint) - 1
+ pivot = bisect_right(l, st.keyPoint) - 1
elif delta < 0:
- pivot = bisect_left(st.keyPoints, st.keyPoint) - 1
+ pivot = bisect_left(l, st.keyPoint)
else:
return
- new = max(min(pivot + delta, len(st.keyPoints) - 1), 0)
- st.keyPoint = st.keyPoints[new]
+ new = max(min(pivot + delta, len(l) - 1), 0)
+ st.keyPoint = l[new]
return f
def rateAbsolute(st: SoloTool, value: float) -> Callable[[], None]:
diff --git a/solo-tool-project/test/handlers_integrationtest.py b/solo-tool-project/test/handlers_integrationtest.py
new file mode 100644
index 0000000..85050d6
--- /dev/null
+++ b/solo-tool-project/test/handlers_integrationtest.py
@@ -0,0 +1,32 @@
+import pytest
+
+from fixtures import soloTool, testSongs, mockPlayer, songPool
+
+from solo_tool.handlers import keyPointRelative
+
+testCases = [
+ ([0.1, 0.3], 0.0, +1, 0.1, "Start +1"),
+ ([0.1, 0.3], 0.1, +1, 0.3, "First +1"),
+ ([0.1, 0.3], 0.2, +1, 0.3, "Between +1"),
+ ([0.1, 0.3], 0.3, +1, 0.3, "Second +1"),
+ ([0.1, 0.3], 0.4, +1, 0.4, "End +1"),
+
+ ([0.1, 0.3], 0.0, -1, 0.0, "Start -1"),
+ ([0.1, 0.3], 0.1, -1, 0.1, "First -1"),
+ ([0.1, 0.3], 0.2, -1, 0.1, "Between -1"),
+ ([0.1, 0.3], 0.3, -1, 0.1, "Second -1"),
+ ([0.1, 0.3], 0.4, -1, 0.3, "End -1"),
+
+ ([0.0, 0.3], 0.0, -1, 0.0, "0.0 -1"),
+]
+
+@pytest.mark.parametrize("keyPoints,current,delta,expected,description", testCases)
+def test_keyPointRelativeEdgeCases(soloTool, testSongs, keyPoints, current, delta, expected, description):
+ soloTool.addSong(testSongs[0])
+ soloTool.keyPoints = keyPoints
+ soloTool.keyPoint = current
+
+ handler = keyPointRelative(soloTool, delta)
+ handler()
+
+ assert soloTool.keyPoint == expected, description