mirror of
https://github.com/OpenSPG/openspg.git
synced 2025-07-26 18:40:42 +00:00
71 lines
2.1 KiB
Python
71 lines
2.1 KiB
Python
![]() |
# Copyright 2023 Ant Group CO., Ltd.
|
||
|
#
|
||
|
# 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.
|
||
|
|
||
|
import sys
|
||
|
import unittest
|
||
|
import unittest.mock
|
||
|
from dataclasses import dataclass
|
||
|
|
||
|
from nn4k.invoker import NNInvoker
|
||
|
|
||
|
|
||
|
@dataclass
|
||
|
class MockCompletion:
|
||
|
choices: list
|
||
|
|
||
|
|
||
|
@dataclass
|
||
|
class MockChoice:
|
||
|
text: str
|
||
|
|
||
|
|
||
|
class TestOpenAIInvoker(unittest.TestCase):
|
||
|
"""
|
||
|
OpenAIInvoker unittest
|
||
|
"""
|
||
|
|
||
|
def setUp(self):
|
||
|
self._saved_openai = sys.modules.get("openai")
|
||
|
self._mocked_openai = unittest.mock.MagicMock()
|
||
|
sys.modules["openai"] = self._mocked_openai
|
||
|
|
||
|
def tearDown(self):
|
||
|
del sys.modules["openai"]
|
||
|
if self._saved_openai is not None:
|
||
|
sys.modules["openai"] = self._saved_openai
|
||
|
|
||
|
def testOpenAIInvoker(self):
|
||
|
nn_config = {
|
||
|
"nn_name": "gpt-3.5-turbo",
|
||
|
"openai_api_key": "EMPTY",
|
||
|
"openai_api_base": "http://localhost:38080/v1",
|
||
|
"openai_max_tokens": 2000,
|
||
|
}
|
||
|
invoker = NNInvoker.from_config(nn_config)
|
||
|
self.assertEqual(invoker.init_args, nn_config)
|
||
|
self.assertEqual(self._mocked_openai.api_key, nn_config["openai_api_key"])
|
||
|
self.assertEqual(self._mocked_openai.api_base, nn_config["openai_api_base"])
|
||
|
|
||
|
mock_completion = MockCompletion(choices=[MockChoice("a dog named Bolt ...")])
|
||
|
self._mocked_openai.Completion.create.return_value = mock_completion
|
||
|
|
||
|
result = invoker.remote_inference("Long long ago, ")
|
||
|
self._mocked_openai.Completion.create.assert_called_with(
|
||
|
prompt=["Long long ago, "],
|
||
|
model=nn_config["nn_name"],
|
||
|
max_tokens=nn_config["openai_max_tokens"],
|
||
|
)
|
||
|
self.assertEqual(result, [mock_completion.choices[0].text])
|
||
|
|
||
|
|
||
|
if __name__ == "__main__":
|
||
|
unittest.main()
|