|
24 | 24 | import com.google.api.gax.rpc.ResponseObserver; |
25 | 25 | import com.google.api.gax.rpc.ServerStreamingCallable; |
26 | 26 | import com.google.api.gax.rpc.UnaryCallable; |
| 27 | +import com.google.bigtable.v2.ReadRowsRequest; |
| 28 | +import com.google.bigtable.v2.RowSet; |
| 29 | +import com.google.cloud.bigtable.data.v2.internal.RequestContext; |
27 | 30 | import com.google.cloud.bigtable.data.v2.models.BulkMutationBatcher; |
28 | 31 | import com.google.cloud.bigtable.data.v2.models.BulkMutationBatcher.BulkMutationFailure; |
29 | 32 | import com.google.cloud.bigtable.data.v2.models.ConditionalRowMutation; |
| 33 | +import com.google.cloud.bigtable.data.v2.models.InstanceName; |
30 | 34 | import com.google.cloud.bigtable.data.v2.models.KeyOffset; |
31 | 35 | import com.google.cloud.bigtable.data.v2.models.Mutation; |
32 | 36 | import com.google.cloud.bigtable.data.v2.models.Query; |
33 | 37 | import com.google.cloud.bigtable.data.v2.models.ReadModifyWriteRow; |
34 | 38 | import com.google.cloud.bigtable.data.v2.models.Row; |
35 | 39 | import com.google.cloud.bigtable.data.v2.models.RowMutation; |
36 | 40 | import com.google.cloud.bigtable.data.v2.stub.EnhancedBigtableStub; |
| 41 | +import com.google.protobuf.ByteString; |
37 | 42 | import io.grpc.Status.Code; |
38 | 43 | import java.util.List; |
39 | 44 | import java.util.concurrent.TimeoutException; |
40 | 45 | import org.junit.Before; |
41 | 46 | import org.junit.Test; |
42 | 47 | import org.junit.runner.RunWith; |
| 48 | +import org.mockito.Answers; |
| 49 | +import org.mockito.ArgumentCaptor; |
43 | 50 | import org.mockito.Mock; |
44 | 51 | import org.mockito.Mockito; |
45 | 52 | import org.mockito.runners.MockitoJUnitRunner; |
|
48 | 55 | @RunWith(MockitoJUnitRunner.class) |
49 | 56 | public class BigtableDataClientTest { |
50 | 57 | @Mock private EnhancedBigtableStub mockStub; |
51 | | - @Mock private ServerStreamingCallable<Query, Row> mockReadRowsCallable; |
| 58 | + |
| 59 | + @Mock(answer = Answers.RETURNS_DEEP_STUBS) |
| 60 | + private ServerStreamingCallable<Query, Row> mockReadRowsCallable; |
| 61 | + |
52 | 62 | @Mock private UnaryCallable<String, List<KeyOffset>> mockSampleRowKeysCallable; |
53 | 63 | @Mock private UnaryCallable<RowMutation, Void> mockMutateRowCallable; |
54 | 64 | @Mock private UnaryCallable<ConditionalRowMutation, Boolean> mockCheckAndMutateRowCallable; |
@@ -79,6 +89,44 @@ public void proxyReadRowsCallableTest() { |
79 | 89 | assertThat(bigtableDataClient.readRowsCallable()).isSameAs(mockReadRowsCallable); |
80 | 90 | } |
81 | 91 |
|
| 92 | + @Test |
| 93 | + public void proxyReadRowAsyncTest() { |
| 94 | + bigtableDataClient.readRowAsync("fake-table", ByteString.copyFromUtf8("fake-row-key")); |
| 95 | + |
| 96 | + ArgumentCaptor<Query> requestCaptor = ArgumentCaptor.forClass(Query.class); |
| 97 | + Mockito.verify(mockReadRowsCallable.first()).futureCall(requestCaptor.capture()); |
| 98 | + |
| 99 | + RequestContext ctx = |
| 100 | + RequestContext.create(InstanceName.of("fake-project", "fake-instance"), "fake-profile"); |
| 101 | + // NOTE: limit(1) is added by the mocked first() call, so it's not tested here |
| 102 | + assertThat(requestCaptor.getValue().toProto(ctx)) |
| 103 | + .isEqualTo( |
| 104 | + ReadRowsRequest.newBuilder() |
| 105 | + .setTableName("projects/fake-project/instances/fake-instance/tables/fake-table") |
| 106 | + .setAppProfileId("fake-profile") |
| 107 | + .setRows(RowSet.newBuilder().addRowKeys(ByteString.copyFromUtf8("fake-row-key"))) |
| 108 | + .build()); |
| 109 | + } |
| 110 | + |
| 111 | + @Test |
| 112 | + public void proxyReadRowStrAsyncTest() { |
| 113 | + bigtableDataClient.readRowAsync("fake-table", "fake-row-key"); |
| 114 | + |
| 115 | + ArgumentCaptor<Query> requestCaptor = ArgumentCaptor.forClass(Query.class); |
| 116 | + Mockito.verify(mockReadRowsCallable.first()).futureCall(requestCaptor.capture()); |
| 117 | + |
| 118 | + RequestContext ctx = |
| 119 | + RequestContext.create(InstanceName.of("fake-project", "fake-instance"), "fake-profile"); |
| 120 | + // NOTE: limit(1) is added by the mocked first() call, so it's not tested here |
| 121 | + assertThat(requestCaptor.getValue().toProto(ctx)) |
| 122 | + .isEqualTo( |
| 123 | + ReadRowsRequest.newBuilder() |
| 124 | + .setTableName("projects/fake-project/instances/fake-instance/tables/fake-table") |
| 125 | + .setAppProfileId("fake-profile") |
| 126 | + .setRows(RowSet.newBuilder().addRowKeys(ByteString.copyFromUtf8("fake-row-key"))) |
| 127 | + .build()); |
| 128 | + } |
| 129 | + |
82 | 130 | @Test |
83 | 131 | public void proxyReadRowsSyncTest() { |
84 | 132 | Query query = Query.create("fake-table"); |
|
0 commit comments