Skip to content

Commit

Permalink
Remove mutexes
Browse files Browse the repository at this point in the history
  • Loading branch information
albertyw committed Feb 25, 2023
1 parent cc2b255 commit 2971205
Show file tree
Hide file tree
Showing 3 changed files with 3 additions and 43 deletions.
8 changes: 0 additions & 8 deletions data_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -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")
Expand All @@ -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; {
Expand Down
11 changes: 1 addition & 10 deletions localtimezone.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,6 @@ type tzData struct {
type localTimeZone struct {
tzids []string
tzData map[string]tzData
mu sync.RWMutex
}

var _ LocalTimeZone = &localTimeZone{}
Expand Down Expand Up @@ -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) {
Expand Down Expand Up @@ -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 {
Expand All @@ -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
}
27 changes: 2 additions & 25 deletions localtimezone_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -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; {
Expand Down Expand Up @@ -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++
}
})
Expand Down Expand Up @@ -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")
Expand All @@ -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)
}
Expand Down

0 comments on commit 2971205

Please sign in to comment.