Return a response, not a request
Signed-off-by: Nic Cope <nicc@rk0n.org>
This commit is contained in:
parent
0f7d85f43d
commit
39b1128332
|
@ -141,7 +141,7 @@ class BetaFunctionRunner(grpcv1beta1.FunctionRunnerService):
|
||||||
gareq.ParseFromString(req.SerializeToString())
|
gareq.ParseFromString(req.SerializeToString())
|
||||||
|
|
||||||
garsp = await self.wrapped.RunFunction(gareq, context)
|
garsp = await self.wrapped.RunFunction(gareq, context)
|
||||||
rsp = fnv1beta1.RunFunctionRequest()
|
rsp = fnv1beta1.RunFunctionResponse()
|
||||||
rsp.ParseFromString(garsp.SerializeToString())
|
rsp.ParseFromString(garsp.SerializeToString())
|
||||||
|
|
||||||
return rsp
|
return rsp
|
||||||
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
# Copyright 2023 The Crossplane Authors.
|
||||||
|
#
|
||||||
|
# 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 dataclasses
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
import grpc
|
||||||
|
|
||||||
|
import crossplane.function.proto.v1.run_function_pb2 as fnv1
|
||||||
|
import crossplane.function.proto.v1.run_function_pb2_grpc as grpcv1
|
||||||
|
import crossplane.function.proto.v1beta1.run_function_pb2 as fnv1beta1
|
||||||
|
from crossplane.function import logging, runtime
|
||||||
|
|
||||||
|
|
||||||
|
class TestRuntime(unittest.IsolatedAsyncioTestCase):
|
||||||
|
def setUp(self) -> None:
|
||||||
|
logging.configure(level=logging.Level.DISABLED)
|
||||||
|
|
||||||
|
async def test_run_function(self) -> None:
|
||||||
|
@dataclasses.dataclass
|
||||||
|
class TestCase:
|
||||||
|
reason: str
|
||||||
|
runner: grpcv1.FunctionRunnerService
|
||||||
|
req: fnv1beta1.RunFunctionRequest
|
||||||
|
want: fnv1beta1.RunFunctionResponse
|
||||||
|
|
||||||
|
cases = [
|
||||||
|
TestCase(
|
||||||
|
reason="The v1 response should be returned as a v1beta1 response.",
|
||||||
|
runner=EchoRunner(),
|
||||||
|
req=fnv1beta1.RunFunctionRequest(meta=fnv1beta1.RequestMeta(tag="hi")),
|
||||||
|
want=fnv1beta1.RunFunctionResponse(
|
||||||
|
meta=fnv1beta1.ResponseMeta(tag="hi")
|
||||||
|
),
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
||||||
|
for case in cases:
|
||||||
|
beta_runner = runtime.BetaFunctionRunner(wrapped=case.runner)
|
||||||
|
rsp = await beta_runner.RunFunction(case.req, None)
|
||||||
|
|
||||||
|
self.assertEqual(rsp, case.want, "-want, +got")
|
||||||
|
|
||||||
|
|
||||||
|
class EchoRunner(grpcv1.FunctionRunnerService):
|
||||||
|
def __init__(self):
|
||||||
|
self.log = logging.get_logger()
|
||||||
|
|
||||||
|
async def RunFunction( # noqa: N802 # gRPC requires this name.
|
||||||
|
self,
|
||||||
|
req: fnv1.RunFunctionRequest,
|
||||||
|
_: grpc.aio.ServicerContext,
|
||||||
|
) -> fnv1beta1.RunFunctionResponse:
|
||||||
|
return fnv1beta1.RunFunctionResponse(
|
||||||
|
meta=fnv1beta1.ResponseMeta(tag=req.meta.tag)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
unittest.main()
|
Loading…
Reference in New Issue