forked from googleapis/python-bigquery
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsynth.py
123 lines (108 loc) · 3.6 KB
/
synth.py
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
# Copyright 2018 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.
"""This script is used to synthesize generated parts of this library."""
import synthtool as s
from synthtool import gcp
from synthtool.languages import python
gapic = gcp.GAPICBazel()
common = gcp.CommonTemplates()
version = "v2"
library = gapic.py_library(
service="bigquery",
version=version,
bazel_target=f"//google/cloud/bigquery/{version}:bigquery-{version}-py",
include_protos=True,
)
s.move(
library,
excludes=[
"*.tar.gz",
"docs/index.rst",
"docs/bigquery_v2/*_service.rst",
"docs/bigquery_v2/services.rst",
"README.rst",
"noxfile.py",
"setup.py",
"scripts/fixup_bigquery_v2_keywords.py",
library / f"google/cloud/bigquery/__init__.py",
library / f"google/cloud/bigquery/py.typed",
# There are no public API endpoints for the generated ModelServiceClient,
# thus there's no point in generating it and its tests.
library / f"google/cloud/bigquery_{version}/services/**",
library / f"tests/unit/gapic/bigquery_{version}/**",
],
)
# ----------------------------------------------------------------------------
# Add templated files
# ----------------------------------------------------------------------------
templated_files = common.py_library(
cov_level=100,
samples=True,
microgenerator=True,
split_system_tests=True,
)
# BigQuery has a custom multiprocessing note
s.move(
templated_files,
excludes=[
"noxfile.py",
"docs/multiprocessing.rst",
".coveragerc",
# Include custom SNIPPETS_TESTS job for performance.
# https://github.com/googleapis/python-bigquery/issues/191
".kokoro/presubmit/presubmit.cfg",
]
)
# ----------------------------------------------------------------------------
# Samples templates
# ----------------------------------------------------------------------------
python.py_samples()
# Do not expose ModelServiceClient, as there is no public API endpoint for the
# models service.
s.replace(
"google/cloud/bigquery_v2/__init__.py",
r"from \.services\.model_service import ModelServiceClient",
"",
)
s.replace(
"google/cloud/bigquery_v2/__init__.py",
r"""["']ModelServiceClient["'],""",
"",
)
# Adjust Model docstring so that Sphinx does not think that "predicted_" is
# a reference to something, issuing a false warning.
s.replace(
"google/cloud/bigquery_v2/types/model.py",
r'will have a "predicted_"',
"will have a `predicted_`",
)
s.replace(
"docs/conf.py",
r'\{"members": True\}',
'{"members": True, "inherited-members": True}'
)
# Avoid breaking change due to change in field renames.
# https://github.com/googleapis/python-bigquery/issues/319
s.replace(
"google/cloud/bigquery_v2/types/standard_sql.py",
r"type_ ",
"type "
)
# Tell Sphinx to ingore autogenerated docs files.
s.replace(
"docs/conf.py",
r'"samples/snippets/README\.rst",',
'\g<0>\n "bigquery_v2/services.rst", # generated by the code generator',
)
s.shell.run(["nox", "-s", "blacken"], hide_output=False)