From 3eaddc8b3528c41a7f51dd8f7738344a56ae451e Mon Sep 17 00:00:00 2001 From: MaurĂ­cio Antunes Date: Wed, 14 Feb 2024 13:47:56 -0300 Subject: feat: New exercises (concurrency) --- exercises/concurrent/concurrent2/main_test.go | 32 +++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 exercises/concurrent/concurrent2/main_test.go (limited to 'exercises/concurrent/concurrent2') diff --git a/exercises/concurrent/concurrent2/main_test.go b/exercises/concurrent/concurrent2/main_test.go new file mode 100644 index 0000000..2233259 --- /dev/null +++ b/exercises/concurrent/concurrent2/main_test.go @@ -0,0 +1,32 @@ +// concurrent2 +// Make the tests pass! + +// I AM NOT DONE +package main_test + +import ( + "sync" + "testing" +) + +func TestCounter(t *testing.T) { + counter := updateCounter() + if counter != 100 { + t.Errorf("Counter should be 100, but got %d", counter) + } +} + +func updateCounter() int { + var counter int + var wg sync.WaitGroup + + for i := 0; i < 100; i++ { + wg.Add(1) + go func() { + defer wg.Done() + counter++ // Many goroutines trying to update the counter? We need some protection here! + }() + } + wg.Wait() + return counter +} -- cgit v1.2.3-70-g09d2