Merge "gcs: Remove unused fallback to oauth2client"

This commit is contained in:
Zuul 2024-08-19 02:40:44 +00:00 committed by Gerrit Code Review
commit 24a560f4c0
4 changed files with 10 additions and 41 deletions

View File

@ -37,11 +37,6 @@ try:
except ImportError: except ImportError:
service_account = google_auth_httplib2 = gexceptions = None service_account = google_auth_httplib2 = gexceptions = None
try:
from oauth2client import client
except ImportError:
client = None
from googleapiclient import discovery from googleapiclient import discovery
from googleapiclient import errors from googleapiclient import errors
from googleapiclient import http from googleapiclient import http
@ -176,16 +171,14 @@ class GoogleBackupDriver(chunkeddriver.ChunkedBackupDriver):
creds = service_account.Credentials.from_service_account_file( creds = service_account.Credentials.from_service_account_file(
backup_credential) backup_credential)
OAUTH_EXCEPTIONS = (gexceptions.RefreshError, OAUTH_EXCEPTIONS = (gexceptions.RefreshError,
gexceptions.DefaultCredentialsError, gexceptions.DefaultCredentialsError)
client.Error)
# The (deprecated) client is imported if the oauth2client library is
# available
elif client:
creds = client.GoogleCredentials.from_stream(backup_credential)
OAUTH_EXCEPTIONS = client.Error
else: else:
msg = _('google-auth-httplib2 or oauth2client should be ' # NOTE(tkajinam): google-api-python-client is now in requirements
'installed.') # and google-auth-httplib2 is its dependency. So
# this error should not be raised now. But it's
# kept now in case the client library is moved to
# extra dependencies
msg = _('google-api-python-client not found')
raise exception.BackupDriverException(reason=msg) raise exception.BackupDriverException(reason=msg)
self.conn = discovery.build('storage', self.conn = discovery.build('storage',

View File

@ -66,8 +66,6 @@ class FakeObjectName(object):
def gcs_client(func): def gcs_client(func):
@mock.patch.object(google_dr.client, 'GoogleCredentials',
fake_google_client.FakeGoogleCredentials)
@mock.patch.object(google_dr.discovery, 'build', @mock.patch.object(google_dr.discovery, 'build',
fake_google_client.FakeGoogleDiscovery.Build) fake_google_client.FakeGoogleDiscovery.Build)
@mock.patch.object(google_dr, 'GoogleMediaIoBaseDownload', @mock.patch.object(google_dr, 'GoogleMediaIoBaseDownload',
@ -85,8 +83,6 @@ def gcs_client(func):
def gcs_client2(func): def gcs_client2(func):
@mock.patch.object(google_dr.client, 'GoogleCredentials',
fake_google_client2.FakeGoogleCredentials)
@mock.patch.object(google_dr.discovery, 'build', @mock.patch.object(google_dr.discovery, 'build',
fake_google_client2.FakeGoogleDiscovery.Build) fake_google_client2.FakeGoogleDiscovery.Build)
@mock.patch.object(google_dr, 'GoogleMediaIoBaseDownload', @mock.patch.object(google_dr, 'GoogleMediaIoBaseDownload',
@ -635,34 +631,15 @@ class GoogleBackupDriverTestCase(test.TestCase):
self.assertEqual('none', result[0]) self.assertEqual('none', result[0])
self.assertEqual(already_compressed_data, result[1]) self.assertEqual(already_compressed_data, result[1])
@mock.patch.object(google_dr.client.GoogleCredentials, 'from_stream')
@mock.patch.object(google_dr.discovery, 'build')
@mock.patch.object(google_dr, 'service_account', None)
def test_no_httplib2_auth(self, build, from_stream):
# Google api client requires google-auth-httplib2 if not present we
# use legacy credentials
google_dr.CONF.set_override('backup_gcs_credential_file',
'credentials_file')
google_dr.GoogleBackupDriver(self.ctxt)
from_stream.assert_called_once_with('credentials_file')
build.assert_called_once_with('storage', 'v1', cache_discovery=False,
credentials=from_stream.return_value)
@mock.patch.object(google_dr, 'gexceptions', mock.Mock()) @mock.patch.object(google_dr, 'gexceptions', mock.Mock())
@mock.patch.object(google_dr.client.GoogleCredentials, 'from_stream')
@mock.patch.object(google_dr.discovery, 'build') @mock.patch.object(google_dr.discovery, 'build')
@mock.patch.object(google_dr, 'service_account') @mock.patch.object(google_dr, 'service_account')
def test_google_auth_used(self, account, build, from_stream): def test_client_setup(self, account, build):
# Google api client requires google-auth-httplib2 if not present we
# use legacy credentials
google_dr.CONF.set_override('backup_gcs_credential_file', google_dr.CONF.set_override('backup_gcs_credential_file',
'credentials_file') 'credentials_file')
google_dr.GoogleBackupDriver(self.ctxt) google_dr.GoogleBackupDriver(self.ctxt)
from_stream.assert_not_called()
create_creds = account.Credentials.from_service_account_file create_creds = account.Credentials.from_service_account_file
create_creds.assert_called_once_with('credentials_file') create_creds.assert_called_once_with('credentials_file')
build.assert_called_once_with('storage', 'v1', cache_discovery=False, build.assert_called_once_with('storage', 'v1', cache_discovery=False,

View File

@ -18,8 +18,8 @@ import json
import os import os
import zlib import zlib
from google.auth import exceptions as gexceptions
from googleapiclient import errors from googleapiclient import errors
from oauth2client import client
from oslo_utils import units from oslo_utils import units
@ -55,7 +55,7 @@ class FakeGoogleBucketListExecute(object):
def execute(self, *args, **kwargs): def execute(self, *args, **kwargs):
if self.container_name == 'gcs_oauth2_failure': if self.container_name == 'gcs_oauth2_failure':
raise client.Error raise gexceptions.DefaultCredentialsError
return {u'items': [{u'name': u'gcscinderbucket'}, return {u'items': [{u'name': u'gcscinderbucket'},
{u'name': u'gcsbucket'}]} {u'name': u'gcsbucket'}]}

View File

@ -12,7 +12,6 @@ jsonschema>=3.2.0 # MIT
keystoneauth1>=4.2.1 # Apache-2.0 keystoneauth1>=4.2.1 # Apache-2.0
keystonemiddleware>=9.1.0 # Apache-2.0 keystonemiddleware>=9.1.0 # Apache-2.0
lxml>=4.5.2 # BSD lxml>=4.5.2 # BSD
oauth2client>=4.1.3 # Apache-2.0
oslo.config>=8.3.2 # Apache-2.0 oslo.config>=8.3.2 # Apache-2.0
oslo.concurrency>=4.5.0 # Apache-2.0 oslo.concurrency>=4.5.0 # Apache-2.0
oslo.context>=3.4.0 # Apache-2.0 oslo.context>=3.4.0 # Apache-2.0