|
from llamafactory.data import Role |
|
from llamafactory.data.converter import get_dataset_converter |
|
from llamafactory.data.parser import DatasetAttr |
|
from llamafactory.hparams import DataArguments |
|
|
|
|
|
def test_alpaca_converter(): |
|
dataset_attr = DatasetAttr("hf_hub", "llamafactory/tiny-supervised-dataset") |
|
data_args = DataArguments() |
|
example = { |
|
"instruction": "Solve the math problem.", |
|
"input": "3 + 4", |
|
"output": "The answer is 7.", |
|
} |
|
dataset_converter = get_dataset_converter("alpaca", dataset_attr, data_args) |
|
assert dataset_converter(example) == { |
|
"_prompt": [{"role": Role.USER.value, "content": "Solve the math problem.\n3 + 4"}], |
|
"_response": [{"role": Role.ASSISTANT.value, "content": "The answer is 7."}], |
|
"_system": "", |
|
"_tools": "", |
|
"_images": None, |
|
"_videos": None, |
|
"_audios": None, |
|
} |
|
|
|
|
|
def test_sharegpt_converter(): |
|
dataset_attr = DatasetAttr("hf_hub", "llamafactory/tiny-supervised-dataset") |
|
data_args = DataArguments() |
|
example = { |
|
"conversations": [ |
|
{"from": "system", "value": "You are a helpful assistant."}, |
|
{"from": "human", "value": "Solve the math problem.\n3 + 4"}, |
|
{"from": "gpt", "value": "The answer is 7."}, |
|
] |
|
} |
|
dataset_converter = get_dataset_converter("sharegpt", dataset_attr, data_args) |
|
assert dataset_converter(example) == { |
|
"_prompt": [{"role": Role.USER.value, "content": "Solve the math problem.\n3 + 4"}], |
|
"_response": [{"role": Role.ASSISTANT.value, "content": "The answer is 7."}], |
|
"_system": "You are a helpful assistant.", |
|
"_tools": "", |
|
"_images": None, |
|
"_videos": None, |
|
"_audios": None, |
|
} |
|
|