From c25a68894f3bce8a8e63289b46ecd6e29f5cc227 Mon Sep 17 00:00:00 2001 From: Sam Anthony Date: Thu, 22 Aug 2024 21:26:41 -0400 Subject: val: add TryGet() method --- val_test.go | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'val_test.go') diff --git a/val_test.go b/val_test.go index 188f8a8..c1b7766 100644 --- a/val_test.go +++ b/val_test.go @@ -34,6 +34,30 @@ func TestValSetRemote(t *testing.T) { <-done } +// Val.TryGet() before Set should fail. +func TestValTryGetFail(t *testing.T) { + sv := share.NewVal[int]() // type is arbitrary + defer sv.Close() + if v, ok := sv.TryGet(); ok { + t.Errorf("Val.TryGet() succeeded (returned %v) before value was set; expected to fail", v) + } +} + +// Val.TryGet() after Set should succeed. +func TestValTryGet(t *testing.T) { + sv := share.NewVal[string]() + defer sv.Close() + v := "foo" + sv.Set <- v + ret, ok := sv.TryGet() + if !ok { + t.Error("Val.TryGet() failed") + } + if *ret != v { + t.Errorf("Val.TryGet() returned %v; expected %v", ret, v) + } +} + func verifySameVal[T comparable](sv share.Val[T], v T, t *testing.T) { ret := sv.Get() if ret != v { -- cgit v1.2.3