-
Notifications
You must be signed in to change notification settings - Fork 195
/
test_extract_entity_attribute_mapper.py
69 lines (57 loc) · 3.78 KB
/
test_extract_entity_attribute_mapper.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
import unittest
import json
from loguru import logger
from data_juicer.core.data import NestedDataset as Dataset
from data_juicer.ops.mapper.extract_entity_attribute_mapper import ExtractEntityAttributeMapper
from data_juicer.utils.unittest_utils import (SKIPPED_TESTS,
DataJuicerTestCaseBase)
from data_juicer.utils.constant import Fields, MetaKeys
# Skip tests for this OP.
# These tests have been tested locally.
@SKIPPED_TESTS.register_module()
class ExtractEntityAttributeMapperTest(DataJuicerTestCaseBase):
def _run_op(self, api_model, response_path=None):
query_entities = ["李莲花", "方多病"]
query_attributes = ["语言风格", "角色性格"]
op = ExtractEntityAttributeMapper(
api_model=api_model,
query_entities=query_entities,
query_attributes=query_attributes,
response_path=response_path)
raw_text = """△笛飞声独自坐在莲花楼屋顶上。李莲花边走边悠闲地给马喂草。方多病则走在一侧,却总不时带着怀疑地盯向楼顶的笛飞声。
方多病走到李莲花身侧:我昨日分明看到阿飞神神秘秘地见了一人,我肯定他有什么瞒着我们。阿飞的来历我必须去查清楚!
李莲花继续悠然地喂草:放心吧,我认识他十几年了,对他一清二楚。
方多病:认识十几年?你上次才说是一面之缘?
李莲花忙圆谎:见得不多,但知根知底。哎,这老马吃得也太多了。
方多病一把夺过李莲花手中的草料:别转移话题!——快说!
李莲花:阿飞啊,脾气不太好,他......这十年也没出过几次门,所以见识短,你不要和他计较。还有他是个武痴,武功深藏不露,你平时别惹他。
方多病:呵,阿飞武功高?编瞎话能不能用心点?
李莲花:可都是大实话啊。反正,我和他彼此了解得很。你就别瞎操心了。
方多病很是质疑:(突然反应过来)等等!你说你和他认识十几年?你们彼此了解?!这么说,就我什么都不知道?!
△李莲花一愣,意外方多病是如此反应。
方多病很是不爽:不行,你们现在投奔我,我必须对我的手下都了解清楚。现在换我来问你,你,李莲花究竟籍贯何处?今年多大?家里还有什么人?平时都有些什么喜好?还有,可曾婚配?
△此时的笛飞声正坐在屋顶,从他的位置远远地向李莲花和方多病二人看去,二人声音渐弱。
李莲花:鄙人李莲花,有个兄弟叫李莲蓬,莲花山莲花镇莲花村人,曾经订过亲,但媳妇跟人跑子。这一辈子呢,没什么抱负理想,只想种种萝卜、逗逗狗,平时豆花爱吃甜的,粽子要肉的......
方多病:没一句实话。
"""
samples = [{
'text': raw_text,
}]
dataset = Dataset.from_list(samples)
dataset = op.run(dataset)
for sample in dataset:
ents = sample[Fields.meta][MetaKeys.main_entities]
attrs = sample[Fields.meta][MetaKeys.attributes]
descs = sample[Fields.meta][MetaKeys.attribute_descriptions]
sups = sample[Fields.meta][MetaKeys.attribute_support_texts]
for ent, attr, desc, sup in zip(ents, attrs, descs, sups):
logger.info(f'{ent} {attr}: {desc}')
self.assertNotEqual(desc, '')
self.assertNotEqual(len(sup), 0)
def test(self):
# before runing this test, set below environment variables:
# export OPENAI_BASE_URL=https://dashscope.aliyuncs.com/compatible-mode/v1/
# export OPENAI_API_KEY=your_dashscope_key
self._run_op('qwen2.5-72b-instruct')
if __name__ == '__main__':
unittest.main()