blob: 810d038aa4916802b5b7b5aad79954e104ca3e1b [file] [log] [blame]
# Copyright 2016 Google Inc.
#
# 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.
import datetime
import mock
import pytest
from google.auth import _helpers
from google.auth import credentials
from google.auth import transport
try:
# pylint: disable=ungrouped-imports
import grpc
import google.auth.transport.grpc
HAS_GRPC = True
except ImportError: # pragma: NO COVER
HAS_GRPC = False
pytestmark = pytest.mark.skipif(not HAS_GRPC, reason="gRPC is unavailable.")
class CredentialsStub(credentials.Credentials):
def __init__(self, token="token"):
super(CredentialsStub, self).__init__()
self.token = token
self.expiry = None
def refresh(self, request):
self.token += "1"
class TestAuthMetadataPlugin(object):
def test_call_no_refresh(self):
credentials = CredentialsStub()
request = mock.create_autospec(transport.Request)
plugin = google.auth.transport.grpc.AuthMetadataPlugin(credentials, request)
context = mock.create_autospec(grpc.AuthMetadataContext, instance=True)
context.method_name = mock.sentinel.method_name
context.service_url = mock.sentinel.service_url
callback = mock.create_autospec(grpc.AuthMetadataPluginCallback)
plugin(context, callback)
callback.assert_called_once_with(
[(u"authorization", u"Bearer {}".format(credentials.token))], None
)
def test_call_refresh(self):
credentials = CredentialsStub()
credentials.expiry = datetime.datetime.min + _helpers.CLOCK_SKEW
request = mock.create_autospec(transport.Request)
plugin = google.auth.transport.grpc.AuthMetadataPlugin(credentials, request)
context = mock.create_autospec(grpc.AuthMetadataContext, instance=True)
context.method_name = mock.sentinel.method_name
context.service_url = mock.sentinel.service_url
callback = mock.create_autospec(grpc.AuthMetadataPluginCallback)
plugin(context, callback)
assert credentials.token == "token1"
callback.assert_called_once_with(
[(u"authorization", u"Bearer {}".format(credentials.token))], None
)
@mock.patch("grpc.composite_channel_credentials", autospec=True)
@mock.patch("grpc.metadata_call_credentials", autospec=True)
@mock.patch("grpc.ssl_channel_credentials", autospec=True)
@mock.patch("grpc.secure_channel", autospec=True)
def test_secure_authorized_channel(
secure_channel,
ssl_channel_credentials,
metadata_call_credentials,
composite_channel_credentials,
):
credentials = CredentialsStub()
request = mock.create_autospec(transport.Request)
target = "example.com:80"
channel = google.auth.transport.grpc.secure_authorized_channel(
credentials, request, target, options=mock.sentinel.options
)
# Check the auth plugin construction.
auth_plugin = metadata_call_credentials.call_args[0][0]
assert isinstance(auth_plugin, google.auth.transport.grpc.AuthMetadataPlugin)
assert auth_plugin._credentials == credentials
assert auth_plugin._request == request
# Check the ssl channel call.
assert ssl_channel_credentials.called
# Check the composite credentials call.
composite_channel_credentials.assert_called_once_with(
ssl_channel_credentials.return_value, metadata_call_credentials.return_value
)
# Check the channel call.
secure_channel.assert_called_once_with(
target,
composite_channel_credentials.return_value,
options=mock.sentinel.options,
)
assert channel == secure_channel.return_value
@mock.patch("grpc.composite_channel_credentials", autospec=True)
@mock.patch("grpc.metadata_call_credentials", autospec=True)
@mock.patch("grpc.ssl_channel_credentials", autospec=True)
@mock.patch("grpc.secure_channel", autospec=True)
def test_secure_authorized_channel_explicit_ssl(
secure_channel,
ssl_channel_credentials,
metadata_call_credentials,
composite_channel_credentials,
):
credentials = mock.Mock()
request = mock.Mock()
target = "example.com:80"
ssl_credentials = mock.Mock()
google.auth.transport.grpc.secure_authorized_channel(
credentials, request, target, ssl_credentials=ssl_credentials
)
# Check the ssl channel call.
assert not ssl_channel_credentials.called
# Check the composite credentials call.
composite_channel_credentials.assert_called_once_with(
ssl_credentials, metadata_call_credentials.return_value
)