From 83c9879462101b4a547b04fd3afc371f4bf0d129 Mon Sep 17 00:00:00 2001 From: Yongjoo Ahn Date: Tue, 29 Oct 2024 16:53:31 +0900 Subject: [PATCH] [test] Add a disabled test for executorch-llama - Add a simple test to show how to use executorch-llama with single api Signed-off-by: Yongjoo Ahn --- tests/capi/unittest_capi_inference_single.cc | 46 ++++++++++++++++++++ 1 file changed, 46 insertions(+) diff --git a/tests/capi/unittest_capi_inference_single.cc b/tests/capi/unittest_capi_inference_single.cc index 84ad6d6d..e2f31575 100644 --- a/tests/capi/unittest_capi_inference_single.cc +++ b/tests/capi/unittest_capi_inference_single.cc @@ -3180,6 +3180,52 @@ TEST (nnstreamer_capi_singleshot, invoke_ncnn) } #endif /* ENABLE_NCNN */ +/** + * @brief DISABLED Test to show executorch_llama filter usage + */ +TEST (nnstreamer_capi_singleshot, executorch_llama) +{ + int status; + ml_single_h single; + + status = ml_single_open (&single, "/path/to/pte,/path/to/tokienizer", NULL, + NULL, ML_NNFW_TYPE_EXECUTORCH_LLAMA, ML_NNFW_HW_ANY); + ASSERT_EQ (status, ML_ERROR_NONE); + + /* prepare input data */ + std::string prompt ("Once upon a time"); + ml_tensors_info_h in_info; + ml_tensors_data_h in_data; + ml_tensor_dimension dim = { (unsigned int) prompt.size () + 1, 0 }; + + ml_tensors_info_create (&in_info); + ml_tensors_info_set_count (in_info, 1); + ml_tensors_info_set_tensor_type (in_info, 0, ML_TENSOR_TYPE_UINT8); + ml_tensors_info_set_tensor_dimension (in_info, 0, dim); + + ml_tensors_data_create (in_info, &in_data); + ml_tensors_data_set_tensor_data (in_data, 0, prompt.c_str (), prompt.size () + 1); + + /* invoke */ + ml_tensors_data_h out_data; + status = ml_single_invoke (single, in_data, &out_data); + EXPECT_EQ (ML_ERROR_NONE, status); + + char *result; + size_t result_size; + status = ml_tensors_data_get_tensor_data (out_data, 0U, (void **) &result, &result_size); + EXPECT_EQ (ML_ERROR_NONE, status); + + g_info ("result: %s", result); + EXPECT_EQ (0, strncmp (result, prompt.c_str (), prompt.size ())); + + /* free data */ + ml_tensors_data_destroy (out_data); + ml_tensors_data_destroy (in_data); + ml_tensors_info_destroy (in_info); + ml_single_close (single); +} + /** * @brief Test NNStreamer single shot (custom filter) * @detail Run pipeline with custom filter with allocate in invoke, handle multi tensors.