forked from trueagi-io/hyperon-experimental
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_extend.py
119 lines (106 loc) · 4.49 KB
/
test_extend.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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
import unittest
from hyperon import *
from test_common import change_dir_to_parent_of
class ExtendTest(unittest.TestCase):
def setUp(self):
change_dir_to_parent_of(__file__)
def test_extend(self):
'''
This test verifies that importing from a python-implemnted module along with @register_atoms and @register_tokens works
'''
metta = MeTTa(env_builder=Environment.custom_env(working_dir=os.getcwd(), disable_config=True, is_test=True))
self.assertEqual(
metta.run('''
!(import! &self extension)
!(get-by-key &my-dict "A")
!(get-by-key &my-dict 6)
'''),
[[E()],
[ValueAtom(5)],
[ValueAtom('B')]])
self.assertEqual(
metta.run('! &runner')[0][0].get_object().value, metta)
class ExtendTestDirMod(unittest.TestCase):
def test_extend_dir_pymod(self):
'''
This test verifies that importing from a python module directory also works
'''
metta = MeTTa(env_builder=Environment.custom_env(working_dir=os.getcwd(), disable_config=True, is_test=True))
self.assertEqual(
metta.run('''
!(import! &self ext_dir)
!(get-by-key &my-dict "A")
!(get-by-key &my-dict 6)
'''),
[[E()],
[ValueAtom(5)],
[ValueAtom('B')]])
self.assertEqual(
metta.run('! &runner')[0][0].get_object().value, metta)
#LP-TODO-Next: Temporarily disabled as I change the way modules that are in the process of being
# loaded are accessed by name. See comments around `relative_submodule_import_test`
#
# def test_extend_subdir_pymod(self):
# '''
# This test verifies that importing from a module that imports its own sub-module also works
# '''
# metta = MeTTa(env_builder=Environment.custom_env(working_dir=os.getcwd(), disable_config=True, is_test=True))
# self.assertEqual(
# metta.run('''
# !(import! &self ext_sub)
# !(get-by-key &my-dict "A")
# !(get-by-key &my-dict 6)
# '''),
# [[E()],
# [ValueAtom(5)],
# [ValueAtom('B')]])
# self.assertEqual(
# metta.run('! &runner')[0][0].get_object().value, metta)
def test_extend_recursive_pymod(self):
'''
This test verifies that importing from a sub-module will cause the necessary parents to be imported as well
'''
metta = MeTTa(env_builder=Environment.custom_env(working_dir=os.getcwd(), disable_config=True, is_test=True))
self.assertEqual(
metta.run('''
!(import! &self ext_recursive:level-2:ext_nested)
!(get-by-key &my-dict "A")
!(get-by-key &my-dict 6)
'''),
[[E()],
[ValueAtom(5)],
[ValueAtom('B')]])
self.assertEqual(
metta.run('! &runner')[0][0].get_object().value, metta)
class ExtendGlobalTest(unittest.TestCase):
def test_extend_global(self):
'''
This test is intended to check that if the extension uses internal states,
they are not lost between metta.run's and are also accessible from Python
'''
from extension import g_object
# Sanity check
self.assertEqual(g_object, None)
metta = MeTTa(env_builder=Environment.custom_env(working_dir=os.getcwd(), disable_config=True, is_test=True))
metta.run('''
!(import! &self extension)
!(set-global! 42)
''')
# Checking that the object is accessible and its value is correct
self.assertEqual(
metta.run('!(get-global)'),
metta.run('! 42'))
# We may have to reimport g_object, but its value should be set
# We also can use import with extension.g_object instead of from to make it work without re-importing
from extension import g_object
self.assertEqual(g_object, 42)
class ExtendErrorTest(unittest.TestCase):
def test_error_pyext(self):
'''
This test verifies that an error from a Python extension is properly propagated
'''
metta = MeTTa(env_builder=Environment.custom_env(working_dir=os.getcwd(), disable_config=True, is_test=True))
result = metta.run("!(import! &self error_pyext)")
self.assertEqual(S('Error'), result[0][0].get_children()[0])
if __name__ == "__main__":
unittest.main()