Skip to content

Commit

Permalink
Add timeout with grpc context
Browse files Browse the repository at this point in the history
  • Loading branch information
takashabe committed Aug 27, 2018
1 parent 2a23660 commit a724d99
Showing 1 changed file with 13 additions and 3 deletions.
16 changes: 13 additions & 3 deletions api/infrastructure/bigtable/bigtable.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package bigtable
import (
"context"
"sort"
"time"

"cloud.google.com/go/bigtable"
"github.com/takashabe/btcli/api/domain"
Expand Down Expand Up @@ -41,8 +42,10 @@ func getAdminClient(project, instance string) (*bigtable.AdminClient, error) {
}

func (b *bigtableRepository) Get(ctx context.Context, table, key string, opts ...bigtable.ReadOption) (*domain.Bigtable, error) {
tbl := b.client.Open(table)
ctx, cancel := context.WithTimeout(ctx, 3*time.Second)
defer cancel()

tbl := b.client.Open(table)
row, err := tbl.ReadRow(ctx, key, opts...)
if err != nil {
return nil, err
Expand All @@ -56,8 +59,10 @@ func (b *bigtableRepository) Get(ctx context.Context, table, key string, opts ..
}

func (b *bigtableRepository) GetRows(ctx context.Context, table string, rr bigtable.RowRange, opts ...bigtable.ReadOption) (*domain.Bigtable, error) {
tbl := b.client.Open(table)
ctx, cancel := context.WithTimeout(ctx, 3*time.Second)
defer cancel()

tbl := b.client.Open(table)
rows := []*domain.Row{}
err := tbl.ReadRows(ctx, rr, func(row bigtable.Row) bool {
rows = append(rows, readRow(row))
Expand All @@ -73,8 +78,10 @@ func (b *bigtableRepository) GetRows(ctx context.Context, table string, rr bigta
}

func (b *bigtableRepository) Count(ctx context.Context, table string) (int, error) {
tbl := b.client.Open(table)
ctx, cancel := context.WithTimeout(ctx, 3*time.Second)
defer cancel()

tbl := b.client.Open(table)
cnt := 0
err := tbl.ReadRows(ctx, bigtable.InfiniteRange(""), func(_ bigtable.Row) bool {
cnt++
Expand Down Expand Up @@ -108,6 +115,9 @@ func readRow(r bigtable.Row) *domain.Row {
}

func (b *bigtableRepository) Tables(ctx context.Context) ([]string, error) {
ctx, cancel := context.WithTimeout(ctx, 3*time.Second)
defer cancel()

tbls, err := b.adminClient.Tables(ctx)
if err != nil {
return []string{}, err
Expand Down

0 comments on commit a724d99

Please # to comment.