You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

53 lines
1.5 KiB

  1. // Copyright 2018 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package spanner
  15. import (
  16. "context"
  17. "testing"
  18. "time"
  19. "cloud.google.com/go/internal/testutil"
  20. stestutil "cloud.google.com/go/spanner/internal/testutil"
  21. "google.golang.org/api/option"
  22. "google.golang.org/grpc"
  23. )
  24. // Check that stats are being exported.
  25. func TestOCStats(t *testing.T) {
  26. te := testutil.NewTestExporter()
  27. defer te.Unregister()
  28. ms := stestutil.NewMockCloudSpanner(t, trxTs)
  29. ms.Serve()
  30. ctx := context.Background()
  31. c, err := NewClient(ctx, "projects/P/instances/I/databases/D",
  32. option.WithEndpoint(ms.Addr()),
  33. option.WithGRPCDialOption(grpc.WithInsecure()),
  34. option.WithoutAuthentication())
  35. if err != nil {
  36. t.Fatal(err)
  37. }
  38. defer c.Close()
  39. c.Single().ReadRow(ctx, "Users", Key{"alice"}, []string{"email"})
  40. // Wait until we see data from the view.
  41. select {
  42. case <-te.Stats:
  43. case <-time.After(1 * time.Second):
  44. t.Fatal("no stats were exported before timeout")
  45. }
  46. }