diff --git a/.github/.OwlBot.lock.yaml b/.github/.OwlBot.lock.yaml
index fccaa8e..889f77d 100644
--- a/.github/.OwlBot.lock.yaml
+++ b/.github/.OwlBot.lock.yaml
@@ -1,4 +1,4 @@
-# Copyright 2022 Google LLC
+# Copyright 2023 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
@@ -13,4 +13,4 @@
# limitations under the License.
docker:
image: gcr.io/cloud-devrel-public-resources/owlbot-python:latest
- digest: sha256:3bf87e47c2173d7eed42714589dc4da2c07c3268610f1e47f8e1a30decbfc7f1
+ digest: sha256:c43f1d918bcf817d337aa29ff833439494a158a0831508fda4ec75dc4c0d0320
diff --git a/.github/workflows/unittest.yml b/.github/workflows/unittest.yml
index 23000c0..8057a76 100644
--- a/.github/workflows/unittest.yml
+++ b/.github/workflows/unittest.yml
@@ -8,7 +8,7 @@ jobs:
runs-on: ubuntu-latest
strategy:
matrix:
- python: ['3.7', '3.8', '3.9', '3.10']
+ python: ['3.7', '3.8', '3.9', '3.10', '3.11']
steps:
- name: Checkout
uses: actions/checkout@v3
diff --git a/.kokoro/samples/python3.11/common.cfg b/.kokoro/samples/python3.11/common.cfg
new file mode 100644
index 0000000..044f550
--- /dev/null
+++ b/.kokoro/samples/python3.11/common.cfg
@@ -0,0 +1,40 @@
+# Format: //devtools/kokoro/config/proto/build.proto
+
+# Build logs will be here
+action {
+ define_artifacts {
+ regex: "**/*sponge_log.xml"
+ }
+}
+
+# Specify which tests to run
+env_vars: {
+ key: "RUN_TESTS_SESSION"
+ value: "py-3.11"
+}
+
+# Declare build specific Cloud project.
+env_vars: {
+ key: "BUILD_SPECIFIC_GCLOUD_PROJECT"
+ value: "python-docs-samples-tests-311"
+}
+
+env_vars: {
+ key: "TRAMPOLINE_BUILD_FILE"
+ value: "github/python-dataproc-metastore/.kokoro/test-samples.sh"
+}
+
+# Configure the docker image for kokoro-trampoline.
+env_vars: {
+ key: "TRAMPOLINE_IMAGE"
+ value: "gcr.io/cloud-devrel-kokoro-resources/python-samples-testing-docker"
+}
+
+# Download secrets for samples
+gfile_resources: "/bigstore/cloud-devrel-kokoro-resources/python-docs-samples"
+
+# Download trampoline resources.
+gfile_resources: "/bigstore/cloud-devrel-kokoro-resources/trampoline"
+
+# Use the trampoline script to run in docker.
+build_file: "python-dataproc-metastore/.kokoro/trampoline_v2.sh"
\ No newline at end of file
diff --git a/.kokoro/samples/python3.11/continuous.cfg b/.kokoro/samples/python3.11/continuous.cfg
new file mode 100644
index 0000000..a1c8d97
--- /dev/null
+++ b/.kokoro/samples/python3.11/continuous.cfg
@@ -0,0 +1,6 @@
+# Format: //devtools/kokoro/config/proto/build.proto
+
+env_vars: {
+ key: "INSTALL_LIBRARY_FROM_SOURCE"
+ value: "True"
+}
\ No newline at end of file
diff --git a/.kokoro/samples/python3.11/periodic-head.cfg b/.kokoro/samples/python3.11/periodic-head.cfg
new file mode 100644
index 0000000..c0d33ea
--- /dev/null
+++ b/.kokoro/samples/python3.11/periodic-head.cfg
@@ -0,0 +1,11 @@
+# Format: //devtools/kokoro/config/proto/build.proto
+
+env_vars: {
+ key: "INSTALL_LIBRARY_FROM_SOURCE"
+ value: "True"
+}
+
+env_vars: {
+ key: "TRAMPOLINE_BUILD_FILE"
+ value: "github/python-dataproc-metastore/.kokoro/test-samples-against-head.sh"
+}
diff --git a/.kokoro/samples/python3.11/periodic.cfg b/.kokoro/samples/python3.11/periodic.cfg
new file mode 100644
index 0000000..71cd1e5
--- /dev/null
+++ b/.kokoro/samples/python3.11/periodic.cfg
@@ -0,0 +1,6 @@
+# Format: //devtools/kokoro/config/proto/build.proto
+
+env_vars: {
+ key: "INSTALL_LIBRARY_FROM_SOURCE"
+ value: "False"
+}
diff --git a/.kokoro/samples/python3.11/presubmit.cfg b/.kokoro/samples/python3.11/presubmit.cfg
new file mode 100644
index 0000000..a1c8d97
--- /dev/null
+++ b/.kokoro/samples/python3.11/presubmit.cfg
@@ -0,0 +1,6 @@
+# Format: //devtools/kokoro/config/proto/build.proto
+
+env_vars: {
+ key: "INSTALL_LIBRARY_FROM_SOURCE"
+ value: "True"
+}
\ No newline at end of file
diff --git a/.release-please-manifest.json b/.release-please-manifest.json
index 099626f..4fcfdf7 100644
--- a/.release-please-manifest.json
+++ b/.release-please-manifest.json
@@ -1,3 +1,3 @@
{
- ".": "1.8.0"
+ ".": "1.9.0"
}
diff --git a/CHANGELOG.md b/CHANGELOG.md
index e9655b0..944ec03 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,5 +1,12 @@
# Changelog
+## [1.9.0](https://github.com/googleapis/python-dataproc-metastore/compare/v1.8.0...v1.9.0) (2023-01-10)
+
+
+### Features
+
+* Add support for python 3.11 ([#197](https://github.com/googleapis/python-dataproc-metastore/issues/197)) ([2a06432](https://github.com/googleapis/python-dataproc-metastore/commit/2a064329ab4077b3ca556e253a8691cbe56f3733))
+
## [1.8.0](https://github.com/googleapis/python-dataproc-metastore/compare/v1.7.0...v1.8.0) (2023-01-04)
diff --git a/CONTRIBUTING.rst b/CONTRIBUTING.rst
index 0895793..c4e6426 100644
--- a/CONTRIBUTING.rst
+++ b/CONTRIBUTING.rst
@@ -22,7 +22,7 @@ In order to add a feature:
documentation.
- The feature must work fully on the following CPython versions:
- 3.7, 3.8, 3.9 and 3.10 on both UNIX and Windows.
+ 3.7, 3.8, 3.9, 3.10 and 3.11 on both UNIX and Windows.
- The feature must not add unnecessary dependencies (where
"unnecessary" is of course subjective, but new dependencies should
@@ -72,7 +72,7 @@ We use `nox `__ to instrument our tests.
- To run a single unit test::
- $ nox -s unit-3.10 -- -k
+ $ nox -s unit-3.11 -- -k
.. note::
@@ -225,11 +225,13 @@ We support:
- `Python 3.8`_
- `Python 3.9`_
- `Python 3.10`_
+- `Python 3.11`_
.. _Python 3.7: https://docs.python.org/3.7/
.. _Python 3.8: https://docs.python.org/3.8/
.. _Python 3.9: https://docs.python.org/3.9/
.. _Python 3.10: https://docs.python.org/3.10/
+.. _Python 3.11: https://docs.python.org/3.11/
Supported versions can be found in our ``noxfile.py`` `config`_.
diff --git a/google/cloud/metastore/gapic_version.py b/google/cloud/metastore/gapic_version.py
index b334dcc..163d151 100644
--- a/google/cloud/metastore/gapic_version.py
+++ b/google/cloud/metastore/gapic_version.py
@@ -13,4 +13,4 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
-__version__ = "1.8.0" # {x-release-please-version}
+__version__ = "1.9.0" # {x-release-please-version}
diff --git a/google/cloud/metastore_v1/gapic_version.py b/google/cloud/metastore_v1/gapic_version.py
index b334dcc..163d151 100644
--- a/google/cloud/metastore_v1/gapic_version.py
+++ b/google/cloud/metastore_v1/gapic_version.py
@@ -13,4 +13,4 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
-__version__ = "1.8.0" # {x-release-please-version}
+__version__ = "1.9.0" # {x-release-please-version}
diff --git a/google/cloud/metastore_v1/services/dataproc_metastore/async_client.py b/google/cloud/metastore_v1/services/dataproc_metastore/async_client.py
index 4897899..4143dfb 100644
--- a/google/cloud/metastore_v1/services/dataproc_metastore/async_client.py
+++ b/google/cloud/metastore_v1/services/dataproc_metastore/async_client.py
@@ -172,7 +172,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1/services/dataproc_metastore/client.py b/google/cloud/metastore_v1/services/dataproc_metastore/client.py
index aebc29d..9449653 100644
--- a/google/cloud/metastore_v1/services/dataproc_metastore/client.py
+++ b/google/cloud/metastore_v1/services/dataproc_metastore/client.py
@@ -407,7 +407,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1/services/dataproc_metastore_federation/async_client.py b/google/cloud/metastore_v1/services/dataproc_metastore_federation/async_client.py
index 0f98726..37157a7 100644
--- a/google/cloud/metastore_v1/services/dataproc_metastore_federation/async_client.py
+++ b/google/cloud/metastore_v1/services/dataproc_metastore_federation/async_client.py
@@ -163,7 +163,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1/services/dataproc_metastore_federation/client.py b/google/cloud/metastore_v1/services/dataproc_metastore_federation/client.py
index 61adde0..133cc96 100644
--- a/google/cloud/metastore_v1/services/dataproc_metastore_federation/client.py
+++ b/google/cloud/metastore_v1/services/dataproc_metastore_federation/client.py
@@ -317,7 +317,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1alpha/gapic_version.py b/google/cloud/metastore_v1alpha/gapic_version.py
index b334dcc..163d151 100644
--- a/google/cloud/metastore_v1alpha/gapic_version.py
+++ b/google/cloud/metastore_v1alpha/gapic_version.py
@@ -13,4 +13,4 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
-__version__ = "1.8.0" # {x-release-please-version}
+__version__ = "1.9.0" # {x-release-please-version}
diff --git a/google/cloud/metastore_v1alpha/services/dataproc_metastore/async_client.py b/google/cloud/metastore_v1alpha/services/dataproc_metastore/async_client.py
index f8f1d2b..9203f05 100644
--- a/google/cloud/metastore_v1alpha/services/dataproc_metastore/async_client.py
+++ b/google/cloud/metastore_v1alpha/services/dataproc_metastore/async_client.py
@@ -174,7 +174,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1alpha/services/dataproc_metastore/client.py b/google/cloud/metastore_v1alpha/services/dataproc_metastore/client.py
index 39ace3e..eac1180 100644
--- a/google/cloud/metastore_v1alpha/services/dataproc_metastore/client.py
+++ b/google/cloud/metastore_v1alpha/services/dataproc_metastore/client.py
@@ -429,7 +429,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1alpha/services/dataproc_metastore_federation/async_client.py b/google/cloud/metastore_v1alpha/services/dataproc_metastore_federation/async_client.py
index 6c6ca02..00f5699 100644
--- a/google/cloud/metastore_v1alpha/services/dataproc_metastore_federation/async_client.py
+++ b/google/cloud/metastore_v1alpha/services/dataproc_metastore_federation/async_client.py
@@ -163,7 +163,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1alpha/services/dataproc_metastore_federation/client.py b/google/cloud/metastore_v1alpha/services/dataproc_metastore_federation/client.py
index 939da1c..e1e0583 100644
--- a/google/cloud/metastore_v1alpha/services/dataproc_metastore_federation/client.py
+++ b/google/cloud/metastore_v1alpha/services/dataproc_metastore_federation/client.py
@@ -317,7 +317,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1beta/gapic_version.py b/google/cloud/metastore_v1beta/gapic_version.py
index b334dcc..163d151 100644
--- a/google/cloud/metastore_v1beta/gapic_version.py
+++ b/google/cloud/metastore_v1beta/gapic_version.py
@@ -13,4 +13,4 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
-__version__ = "1.8.0" # {x-release-please-version}
+__version__ = "1.9.0" # {x-release-please-version}
diff --git a/google/cloud/metastore_v1beta/services/dataproc_metastore/async_client.py b/google/cloud/metastore_v1beta/services/dataproc_metastore/async_client.py
index 60a3ff3..45e8f7a 100644
--- a/google/cloud/metastore_v1beta/services/dataproc_metastore/async_client.py
+++ b/google/cloud/metastore_v1beta/services/dataproc_metastore/async_client.py
@@ -174,7 +174,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1beta/services/dataproc_metastore/client.py b/google/cloud/metastore_v1beta/services/dataproc_metastore/client.py
index f7756a6..6e64cd5 100644
--- a/google/cloud/metastore_v1beta/services/dataproc_metastore/client.py
+++ b/google/cloud/metastore_v1beta/services/dataproc_metastore/client.py
@@ -429,7 +429,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1beta/services/dataproc_metastore_federation/async_client.py b/google/cloud/metastore_v1beta/services/dataproc_metastore_federation/async_client.py
index 12fcf40..ab39839 100644
--- a/google/cloud/metastore_v1beta/services/dataproc_metastore_federation/async_client.py
+++ b/google/cloud/metastore_v1beta/services/dataproc_metastore_federation/async_client.py
@@ -163,7 +163,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/google/cloud/metastore_v1beta/services/dataproc_metastore_federation/client.py b/google/cloud/metastore_v1beta/services/dataproc_metastore_federation/client.py
index 21939f3..4bfc996 100644
--- a/google/cloud/metastore_v1beta/services/dataproc_metastore_federation/client.py
+++ b/google/cloud/metastore_v1beta/services/dataproc_metastore_federation/client.py
@@ -317,7 +317,7 @@ def get_mtls_endpoint_and_cert_source(
The API endpoint is determined in the following order:
(1) if `client_options.api_endpoint` if provided, use the provided one.
(2) if `GOOGLE_API_USE_CLIENT_CERTIFICATE` environment variable is "always", use the
- default mTLS endpoint; if the environment variabel is "never", use the default API
+ default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
diff --git a/noxfile.py b/noxfile.py
index d8440c0..e716318 100644
--- a/noxfile.py
+++ b/noxfile.py
@@ -32,7 +32,7 @@
DEFAULT_PYTHON_VERSION = "3.8"
-UNIT_TEST_PYTHON_VERSIONS = ["3.7", "3.8", "3.9", "3.10"]
+UNIT_TEST_PYTHON_VERSIONS = ["3.7", "3.8", "3.9", "3.10", "3.11"]
UNIT_TEST_STANDARD_DEPENDENCIES = [
"mock",
"asyncmock",
diff --git a/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1.json b/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1.json
index 9a72fe4..1fc6843 100644
--- a/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1.json
+++ b/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1.json
@@ -8,7 +8,7 @@
],
"language": "PYTHON",
"name": "google-cloud-dataproc-metastore",
- "version": "1.8.0"
+ "version": "1.9.0"
},
"snippets": [
{
diff --git a/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1alpha.json b/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1alpha.json
index 1bb5d39..ec646aa 100644
--- a/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1alpha.json
+++ b/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1alpha.json
@@ -8,7 +8,7 @@
],
"language": "PYTHON",
"name": "google-cloud-dataproc-metastore",
- "version": "1.8.0"
+ "version": "1.9.0"
},
"snippets": [
{
diff --git a/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1beta.json b/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1beta.json
index 7b32f7e..59c1679 100644
--- a/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1beta.json
+++ b/samples/generated_samples/snippet_metadata_google.cloud.metastore.v1beta.json
@@ -8,7 +8,7 @@
],
"language": "PYTHON",
"name": "google-cloud-dataproc-metastore",
- "version": "1.8.0"
+ "version": "1.9.0"
},
"snippets": [
{
diff --git a/setup.py b/setup.py
index 0c9f9e0..0b60b14 100644
--- a/setup.py
+++ b/setup.py
@@ -38,6 +38,7 @@
dependencies = [
"google-api-core[grpc] >= 1.34.0, <3.0.0dev,!=2.0.*,!=2.1.*,!=2.2.*,!=2.3.*,!=2.4.*,!=2.5.*,!=2.6.*,!=2.7.*,!=2.8.*,!=2.9.*,!=2.10.*",
"proto-plus >= 1.22.0, <2.0.0dev",
+ "proto-plus >= 1.22.2, <2.0.0dev; python_version>='3.11'",
"protobuf>=3.19.5,<5.0.0dev,!=3.20.0,!=3.20.1,!=4.21.0,!=4.21.1,!=4.21.2,!=4.21.3,!=4.21.4,!=4.21.5",
]
url = "https://github.com/googleapis/python-dataproc-metastore"
@@ -77,6 +78,7 @@
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
+ "Programming Language :: Python :: 3.11",
"Operating System :: OS Independent",
"Topic :: Internet",
],
diff --git a/testing/constraints-3.12.txt b/testing/constraints-3.12.txt
new file mode 100644
index 0000000..ed7f9ae
--- /dev/null
+++ b/testing/constraints-3.12.txt
@@ -0,0 +1,6 @@
+# -*- coding: utf-8 -*-
+# This constraints file is required for unit tests.
+# List all library dependencies and extras in this file.
+google-api-core
+proto-plus
+protobuf