From e67f1a6c633fb6a3aabed3debda346c83a8fe0ca Mon Sep 17 00:00:00 2001 From: Bob Aman Date: Mon, 14 Jan 2019 16:35:52 -0800 Subject: [PATCH] Add clarification around error handling --- internal/auth/providers/ms_graph_api.go | 3 +++ 1 file changed, 3 insertions(+) diff --git a/internal/auth/providers/ms_graph_api.go b/internal/auth/providers/ms_graph_api.go index 52ba5cf4..225c3776 100644 --- a/internal/auth/providers/ms_graph_api.go +++ b/internal/auth/providers/ms_graph_api.go @@ -115,6 +115,8 @@ func (gs *MSGraphService) GetGroups(email string) ([]string, error) { if cachedName, ok := gs.groupNameCache.Get(id); !ok { // didn't have the group name, make concurrent API call to fetch it name, err = gs.getGroupName(id) + // the err value is not shadowed in the goroutine, so if this isn't + // nil, it will return the err value after wg.Wait() is called if err == nil { // got the name ok, populate the cache gs.groupNameCache.Add(id, name) @@ -136,6 +138,7 @@ func (gs *MSGraphService) GetGroups(email string) ([]string, error) { } } wg.Wait() + // any err value set above will cause this to fail if err != nil { return nil, err }