From e4c500e73bf9699a988f780fdb1c30e77a8ba9dd Mon Sep 17 00:00:00 2001 From: Hongbo Zhang Date: Tue, 24 Dec 2024 10:21:14 +0800 Subject: [PATCH] feat(builtin): add `labeld_break` function with tests for various scenarios --- builtin/feature_test.mbt | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/builtin/feature_test.mbt b/builtin/feature_test.mbt index d6c64cda1..c961a353b 100644 --- a/builtin/feature_test.mbt +++ b/builtin/feature_test.mbt @@ -44,3 +44,33 @@ test { @json.inspect!(my_range(1, 10), content={ "lo": 1, "hi": 10 }) @json.inspect!(my_range("a", "z"), content={ "lo": "a", "hi": "z" }) } + +///| +fn labeld_break(xss : Array[Array[Double]]) -> Double? { + let mut threshold = 0.0 + mylabel~: for xs in xss { + for x in xs { + threshold += x + if threshold > 10.0 { + break mylabel~ Some(threshold) + } + } + } else { + None + } +} + +test "labeld_break/empty" { + let xss : Array[Array[Double]] = [] + inspect!(labeld_break(xss), content="None") +} + +test "labeld_break/sum_under_threshold" { + let xss = [[1.0, 2.0], [3.0, 4.0]] + inspect!(labeld_break(xss), content="None") +} + +test "labeld_break/cross_threshold" { + let xss = [[3.0, 4.0], [5.0, 6.0]] + inspect!(labeld_break(xss), content="Some(12)") +}