Skip to content

Commit

Permalink
Merge pull request #77 from negz/its-happening-dot-gif
Browse files Browse the repository at this point in the history
Return a response, not a request
  • Loading branch information
negz authored Aug 17, 2024
2 parents f8f842d + 39b1128 commit 9850b18
Show file tree
Hide file tree
Showing 2 changed files with 72 additions and 1 deletion.
2 changes: 1 addition & 1 deletion crossplane/function/runtime.py
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ async def RunFunction( # noqa: N802 # gRPC requires this name.
gareq.ParseFromString(req.SerializeToString())

garsp = await self.wrapped.RunFunction(gareq, context)
rsp = fnv1beta1.RunFunctionRequest()
rsp = fnv1beta1.RunFunctionResponse()
rsp.ParseFromString(garsp.SerializeToString())

return rsp
71 changes: 71 additions & 0 deletions tests/test_runtime.py
Original file line number Diff line number Diff line change
@@ -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()

0 comments on commit 9850b18

Please sign in to comment.