diff --git a/data_test.go b/data_test.go index becc2b0..549b53a 100644 --- a/data_test.go +++ b/data_test.go @@ -101,8 +101,6 @@ func TestTzidPresent(t *testing.T) { if !ok { t.Error("error when initializing client") } - z.mu.RLock() - z.mu.RUnlock() //lint:ignore SA2001 Make sure client has loaded _, ok = z.tzData["id"] if ok { t.Error("unexpected feature with empty tzid") @@ -118,12 +116,6 @@ func BenchmarkGetZone(b *testing.B) { if err != nil { b.Errorf("cannot initialize test cases: %v", err) } - c, ok := client.(*localTimeZone) - if !ok { - b.Errorf("cannot initialize test client") - } - c.mu.RLock() - c.mu.RUnlock() //lint:ignore SA2001 Make sure client has loaded b.Run("GetZone on large cities", func(b *testing.B) { Loop: for n := 0; n < b.N; { diff --git a/localtimezone.go b/localtimezone.go index e64bbb6..033afa3 100644 --- a/localtimezone.go +++ b/localtimezone.go @@ -94,7 +94,6 @@ type tzData struct { type localTimeZone struct { tzids []string tzData map[string]tzData - mu sync.RWMutex } var _ LocalTimeZone = &localTimeZone{} @@ -164,8 +163,6 @@ func (z *localTimeZone) getZone(point Point, single bool) (tzids []string, err e if p[0] > 180 || p[0] < -180 || p[1] > 90 || p[1] < -90 { return nil, ErrOutOfRange } - z.mu.RLock() - defer z.mu.RUnlock() for _, id := range z.tzids { d := z.tzData[id] if !d.bound.Contains(p) { @@ -276,8 +273,6 @@ func (z *localTimeZone) buildCache(features []*geojson.Feature) { // loadGeoJSON loads a custom GeoJSON shapefile from a Reader func (z *localTimeZone) loadGeoJSON(r io.Reader) error { - z.mu.Lock() - var buf bytes.Buffer _, err := buf.ReadFrom(r) if err != nil { @@ -287,14 +282,10 @@ func (z *localTimeZone) loadGeoJSON(r io.Reader) error { if err != nil { z.tzData = make(map[string]tzData) z.tzids = []string{} - z.mu.Unlock() return err } z.tzData = make(map[string]tzData, TZCount) // Possibly the incorrect length in case of Mock or custom data z.tzids = []string{} // Cannot set a length or else array will be full of empty strings - go func(features []*geojson.Feature) { - defer z.mu.Unlock() - z.buildCache(features) - }(orbData.Features) + z.buildCache(orbData.Features) return nil } diff --git a/localtimezone_test.go b/localtimezone_test.go index ae7b67d..941034c 100644 --- a/localtimezone_test.go +++ b/localtimezone_test.go @@ -273,8 +273,6 @@ func BenchmarkZones(b *testing.B) { if !ok { b.Errorf("cannot initialize timezone client") } - z.mu.RLock() - z.mu.RUnlock() //lint:ignore SA2001 Make sure client has loaded b.Run("polygon centers", func(b *testing.B) { Loop: for n := 0; n < b.N; { @@ -316,28 +314,16 @@ func BenchmarkZones(b *testing.B) { func BenchmarkClientInit(b *testing.B) { b.Run("main client", func(b *testing.B) { for n := 0; n < b.N; { - c, err := NewLocalTimeZone() + _, err := NewLocalTimeZone() if err != nil { b.Errorf("client could not initialize because of %v", err) } - cStruct, ok := c.(*localTimeZone) - if !ok { - b.Errorf("cannot initialize timezone client") - } - cStruct.mu.RLock() - cStruct.mu.RUnlock() //lint:ignore SA2001 Wait for the client to load n++ } }) b.Run("mock client", func(b *testing.B) { for n := 0; n < b.N; { - c := NewMockLocalTimeZone() - cStruct, ok := c.(*localTimeZone) - if !ok { - b.Errorf("cannot initialize timezone client") - } - cStruct.mu.RLock() - cStruct.mu.RUnlock() //lint:ignore SA2001 Wait for the client to load + NewMockLocalTimeZone() n++ } }) @@ -418,11 +404,6 @@ func TestLoadGeoJSONMalformed(t *testing.T) { if err == nil { t.Errorf("expected error, got %v", err) } - unlocked := c.mu.TryLock() - if !unlocked { - t.Errorf("expected lock to be released") - } - defer c.mu.Unlock() if len(c.tzData) != 0 { t.Errorf("tzData not reset") @@ -438,13 +419,9 @@ func TestLoadOverwrite(t *testing.T) { if !ok { t.Errorf("cannot initialize client") } - c.mu.RLock() lenTzData := len(c.tzData) - c.mu.RUnlock() err = c.load(MockTZShapeFile) - c.mu.RLock() - defer c.mu.RUnlock() if err != nil { t.Errorf("cannot switch client to mock data, got %v", err) }