-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Expand file tree
/
Copy pathspanner-integration.yaml
More file actions
365 lines (333 loc) · 14.3 KB
/
spanner-integration.yaml
File metadata and controls
365 lines (333 loc) · 14.3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
# Copyright 2026 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
description: Integrate Google Cloud Logging Spanner Handwritten code
url: https://github.com/googleapis/gapic-generator-python/issues/123
replacements:
- paths: [packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/client.py]
before: '(import google\.rpc\.status_pb2 as status_pb2 # type: ignore\n\n)(?!from google\.cloud\.spanner_v1\.metrics)'
after: |
\g<1>from google.cloud.spanner_v1.metrics.metrics_interceptor import MetricsInterceptor
count: 1
- paths: [packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/client.py]
before: '(\s+api_audience=self\._client_options\.api_audience,\n)(?!\s+metrics_interceptor=MetricsInterceptor)'
after: |
\g<1> metrics_interceptor=MetricsInterceptor(),
count: 1
- paths: [packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/base.py]
before: '(from google\.cloud\.spanner_v1 import gapic_version as package_version\n)(?!from google\.cloud\.spanner_v1\.metrics)'
after: |
\g<1>from google.cloud.spanner_v1.metrics.metrics_interceptor import MetricsInterceptor
count: 1
- paths: [packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/rest.py]
before: '(from requests import __version__ as requests_version\n\n)(?!from google\.cloud\.spanner_v1\.metrics)'
after: |
\g<1>from google.cloud.spanner_v1.metrics.metrics_interceptor import MetricsInterceptor
count: 1
- paths: [packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/grpc_asyncio.py]
before: '(from grpc\.experimental import aio # type: ignore\n\n)(?!from google\.cloud\.spanner_v1\.metrics)'
after: |
\g<1>from google.cloud.spanner_v1.metrics.metrics_interceptor import MetricsInterceptor
count: 1
- paths: [packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/grpc.py]
before: '(from google\.protobuf\.json_format import MessageToJson\n\n)(?!from google\.cloud\.spanner_v1\.metrics)'
after: |
\g<1>from google.cloud.spanner_v1.metrics.metrics_interceptor import MetricsInterceptor
count: 1
- paths: [packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/rest_base.py]
before: '(from google\.protobuf import json_format\n\n)(?!from google\.cloud\.spanner_v1\.metrics)'
after: |
\g<1>from google.cloud.spanner_v1.metrics.metrics_interceptor import MetricsInterceptor
count: 1
- paths:
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/base.py
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/grpc.py
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/grpc_asyncio.py
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/rest.py
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/rest_base.py
before: '(\s+api_audience: Optional\[str\] = None,\n)(?!\s+metrics_interceptor: Optional\[MetricsInterceptor\])'
after: |
\g<1> metrics_interceptor: Optional[MetricsInterceptor] = None,
count: 5
- paths:
# Source Transports
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/grpc.py
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/grpc_asyncio.py
- packages/google-cloud-spanner/google/cloud/spanner_admin_database_v1/services/database_admin/transports/grpc.py
- packages/google-cloud-spanner/google/cloud/spanner_admin_database_v1/services/database_admin/transports/grpc_asyncio.py
- packages/google-cloud-spanner/google/cloud/spanner_admin_instance_v1/services/instance_admin/transports/grpc.py
- packages/google-cloud-spanner/google/cloud/spanner_admin_instance_v1/services/instance_admin/transports/grpc_asyncio.py
# Test Files
- packages/google-cloud-spanner/tests/unit/gapic/spanner_admin_database_v1/test_database_admin.py
- packages/google-cloud-spanner/tests/unit/gapic/spanner_admin_instance_v1/test_instance_admin.py
- packages/google-cloud-spanner/tests/unit/gapic/spanner_v1/test_spanner.py
# Group 1 captures exactly the spaces/tabs on that line.
# Group 2 captures the code up to the newline.
before: '([ \t]+)(\("grpc\.max_receive_message_length", -1\),\n)(?![ \t]+\("grpc\.keepalive_time_ms")'
after: |
\g<1>\g<2>\g<1>("grpc.keepalive_time_ms", 120000),
count: 21
- paths:
- packages/google-cloud-spanner/tests/unit/gapic/spanner_v1/test_spanner.py
before: '(\s+api_audience=\"https\:\/\/language\.googleapis\.com\",\n)(?!\s+metrics_interceptor=mock\.ANY,)'
after: |
\g<1> metrics_interceptor=mock.ANY,
count: 1
- paths:
- packages/google-cloud-spanner/tests/unit/gapic/spanner_v1/test_spanner.py
# Group 1: Captures ONLY the spaces/tabs before the text
# Group 2: Captures the text itself and the newline
before: '([ \t]+)(api_audience=None,\n)(?![ \t]+metrics_interceptor=mock\.ANY,)'
after: |
\g<1>\g<2>\g<1>metrics_interceptor=mock.ANY,
count: 12
- paths:
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/grpc.py
before: '(\s+self\._stubs: Dict\[str, Callable\] = \{\}\n)(?!\s+self\._metrics_interceptor = None)'
after: |
\g<1> self._metrics_interceptor = None
count: 1
- paths:
- packages/google-cloud-spanner/google/cloud/spanner_v1/services/spanner/transports/grpc.py
before: '([ \t]+)(\("grpc\.keepalive_time_ms", 120000\),\n[ \t]+\](?:,\n[ \t]*|\n[ \t]*)\)\n+)([ \t]+)(self\._interceptor = _LoggingClientInterceptor\(\)\n)'
after: |
\g<1>\g<2>\g<3># Wrap the gRPC channel with the metric interceptor
\g<3>if metrics_interceptor is not None:
\g<3> self._metrics_interceptor = metrics_interceptor
\g<3> self._grpc_channel = grpc.intercept_channel(
\g<3> self._grpc_channel, metrics_interceptor
\g<3> )
\g<3>\g<4>
count: 1
- paths: [packages/google-cloud-spanner/setup.py]
before: '(?s)dependencies = \[.*?\]\nextras = \{\}'
after: |
dependencies = [
"google-api-core[grpc] >= 1.34.0, <3.0.0,!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.*,!=2.4.*,!=2.5.*,!=2.6.*,!=2.7.*,!=2.8.*,!=2.9.*,!=2.10.*",
"google-cloud-core >= 1.4.4, < 3.0.0",
"grpc-google-iam-v1 >= 0.12.4, <1.0.0",
"proto-plus >= 1.22.0, <2.0.0",
"sqlparse >= 0.4.4",
"proto-plus >= 1.22.2, <2.0.0; python_version>='3.11'",
"protobuf>=3.20.2,<7.0.0,!=4.21.0,!=4.21.1,!=4.21.2,!=4.21.3,!=4.21.4,!=4.21.5",
"grpc-interceptor >= 0.15.4",
# Make OpenTelemetry a core dependency
"opentelemetry-api >= 1.22.0",
"opentelemetry-sdk >= 1.22.0",
"opentelemetry-semantic-conventions >= 0.43b0",
"opentelemetry-resourcedetector-gcp >= 1.8.0a0",
"google-cloud-monitoring >= 2.16.0",
"mmh3 >= 4.1.0 ",
]
extras = {"libcst": "libcst >= 0.2.5"}
count: 1
- paths: [packages/google-cloud-spanner/docs/index.rst]
before: '(?s)API Reference\n-------------.*'
after: |
Usage Documentation
-------------------
.. toctree::
:maxdepth: 2
client-usage
table-usage
batch-usage
snapshot-usage
transaction-usage
database-usage
instance-usage
API Documentation
-----------------
.. toctree::
:maxdepth: 1
:titlesonly:
advanced-session-pool-topics
opentelemetry-tracing
spanner_v1/client
spanner_v1/instance
spanner_v1/database
spanner_v1/table
spanner_v1/session
spanner_v1/keyset
spanner_v1/snapshot
spanner_v1/batch
spanner_v1/transaction
spanner_v1/streamed
spanner_v1/services_
spanner_v1/types_
spanner_admin_database_v1/services_
spanner_admin_database_v1/types_
spanner_admin_database_v1/database_admin
spanner_admin_instance_v1/services_
spanner_admin_instance_v1/types_
spanner_admin_instance_v1/instance_admin
Changelog
---------
For a list of all ``google-cloud-spanner`` releases:
.. toctree::
:maxdepth: 2
CHANGELOG
.. toctree::
:hidden:
summary_overview.md
count: 1
- paths: [packages/google-cloud-spanner/google/cloud/spanner_v1/__init__.py]
before: '(?s)import sys\n\nimport google\.api_core as api_core.*'
after: |
from __future__ import absolute_import
from google.cloud.spanner_v1 import gapic_version as package_version
__version__: str = package_version.__version__
from google.cloud.spanner_v1 import param_types
from google.cloud.spanner_v1._async.client import Client as AsyncClient
from google.cloud.spanner_v1._async.pool import (
AbstractSessionPool as AsyncAbstractSessionPool,
)
from google.cloud.spanner_v1._async.pool import BurstyPool as AsyncBurstyPool
from google.cloud.spanner_v1._async.pool import FixedSizePool as AsyncFixedSizePool
from google.cloud.spanner_v1._async.pool import PingingPool as AsyncPingingPool
from google.cloud.spanner_v1._async.pool import (
TransactionPingingPool as AsyncTransactionPingingPool,
)
from google.cloud.spanner_v1.client import Client
from google.cloud.spanner_v1.keyset import KeyRange, KeySet
from google.cloud.spanner_v1.pool import (
AbstractSessionPool,
BurstyPool,
FixedSizePool,
PingingPool,
TransactionPingingPool,
)
from .data_types import Interval, JsonObject
from .exceptions import wrap_with_request_id
from .services.spanner import SpannerAsyncClient, SpannerClient
from .transaction import BatchTransactionId, DefaultTransactionOptions
from .types import RequestOptions
from .types.commit_response import CommitResponse
from .types.keys import KeyRange as KeyRangePB
from .types.keys import KeySet as KeySetPB
from .types.mutation import Mutation
from .types.query_plan import PlanNode, QueryPlan
from .types.result_set import (
PartialResultSet,
ResultSet,
ResultSetMetadata,
ResultSetStats,
)
from .types.spanner import (
BatchCreateSessionsRequest,
BatchCreateSessionsResponse,
BatchWriteRequest,
BatchWriteResponse,
BeginTransactionRequest,
CommitRequest,
CreateSessionRequest,
DeleteSessionRequest,
DirectedReadOptions,
ExecuteBatchDmlRequest,
ExecuteBatchDmlResponse,
ExecuteSqlRequest,
GetSessionRequest,
ListSessionsRequest,
ListSessionsResponse,
Partition,
PartitionOptions,
PartitionQueryRequest,
PartitionReadRequest,
PartitionResponse,
ReadRequest,
RollbackRequest,
Session,
)
from .types.transaction import Transaction, TransactionOptions, TransactionSelector
from .types.type import StructType, Type, TypeAnnotationCode, TypeCode
COMMIT_TIMESTAMP = "spanner.commit_timestamp()"
"""Placeholder be used to store commit timestamp of a transaction in a column.
This value can only be used for timestamp columns that have set the option
``(allow_commit_timestamp=true)`` in the schema.
"""
__all__ = (
# google.cloud.spanner_v1
"__version__",
"param_types",
# google.cloud.spanner_v1.exceptions
"wrap_with_request_id",
# google.cloud.spanner_v1.client
"Client",
"AsyncClient",
# google.cloud.spanner_v1.keyset
"KeyRange",
"KeySet",
# google.cloud.spanner_v1.pool
"AbstractSessionPool",
"BurstyPool",
"FixedSizePool",
"PingingPool",
"TransactionPingingPool",
"AsyncAbstractSessionPool",
"AsyncBurstyPool",
"AsyncFixedSizePool",
"AsyncPingingPool",
"AsyncTransactionPingingPool",
# local
"COMMIT_TIMESTAMP",
# google.cloud.spanner_v1.types
"BatchCreateSessionsRequest",
"BatchCreateSessionsResponse",
"BatchWriteRequest",
"BatchWriteResponse",
"BeginTransactionRequest",
"CommitRequest",
"CommitResponse",
"CreateSessionRequest",
"DeleteSessionRequest",
"DirectedReadOptions",
"ExecuteBatchDmlRequest",
"ExecuteBatchDmlResponse",
"ExecuteSqlRequest",
"GetSessionRequest",
"KeyRangePB",
"KeySetPB",
"ListSessionsRequest",
"ListSessionsResponse",
"Mutation",
"PartialResultSet",
"Partition",
"PartitionOptions",
"PartitionQueryRequest",
"PartitionReadRequest",
"PartitionResponse",
"PlanNode",
"QueryPlan",
"ReadRequest",
"RequestOptions",
"ResultSet",
"ResultSetMetadata",
"ResultSetStats",
"RollbackRequest",
"Session",
"StructType",
"Transaction",
"TransactionOptions",
"TransactionSelector",
"Type",
"TypeAnnotationCode",
"TypeCode",
# Custom spanner related data types
"JsonObject",
"Interval",
# google.cloud.spanner_v1.services
"SpannerClient",
"SpannerAsyncClient",
"BatchTransactionId",
"DefaultTransactionOptions",
)
count: 1