blob: 0f3484bda90c02fe96ae70672d06aa2858b51045 [file] [log] [blame]
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you 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 asyncio
import pandas as pd
import hamilton.function_modifiers
async def simple_async_func(external_input: int) -> int:
await asyncio.sleep(0.01)
return external_input + 1
async def async_func_with_param(simple_async_func: int, external_input: int) -> int:
await asyncio.sleep(0.01)
return simple_async_func + external_input + 1
def simple_non_async_func(simple_async_func: int, async_func_with_param: int) -> int:
return simple_async_func + async_func_with_param + 1
async def another_async_func(simple_non_async_func: int) -> int:
await asyncio.sleep(0.01)
return simple_non_async_func + 1
@hamilton.function_modifiers.extract_fields(dict(result_1=int, result_2=int))
def non_async_func_with_decorator(
async_func_with_param: int, another_async_func: int
) -> dict[str, int]:
return {"result_1": another_async_func + 1, "result_2": async_func_with_param + 1}
@hamilton.function_modifiers.extract_columns(*["a", "b"])
async def return_df() -> pd.DataFrame:
return pd.DataFrame({"a": [1, 2, 3], "b": [4, 5, 6]})
@hamilton.function_modifiers.extract_fields(dict(result_3=int, result_4=int))
async def return_dict() -> dict:
return {"result_3": 1, "result_4": 2}