mirror of https://github.com/Nonannet/copapy.git
123 lines
3.3 KiB
Python
123 lines
3.3 KiB
Python
from copapy import value
|
|
from copapy.backend import Store, compile_to_dag, add_read_command
|
|
import copapy as cp
|
|
import subprocess
|
|
from copapy import _binwrite
|
|
import copapy.backend
|
|
import pytest
|
|
|
|
|
|
def run_command(command: list[str]) -> str:
|
|
result = subprocess.run(command, stdout=subprocess.PIPE, stderr=subprocess.PIPE, encoding='utf8', check=False)
|
|
assert result.returncode != 11, f"SIGSEGV (segmentation fault)\n -Error occurred: {result.stderr}\n -Output: {result.stdout}"
|
|
assert result.returncode == 0, f"\n -Error occurred: {result.stderr}\n -Output: {result.stdout}"
|
|
return result.stdout
|
|
|
|
|
|
@pytest.mark.runner
|
|
def test_compile_sqrt():
|
|
test_vals = [0.0, 0.0001, 0.1, 0.5, 1.0, 1.5, 2.0, 2.5, 3.0, 3.5, 4.0, 4.5, 5.0, 5.5, 6.0, 6.28318530718, 100.0, 1000.0, 100000.0]
|
|
|
|
ret = [r for v in test_vals for r in (cp.sqrt(value(v)),)]
|
|
|
|
|
|
out = [Store(r) for r in ret]
|
|
|
|
il, variables = compile_to_dag(out, copapy.generic_sdb)
|
|
|
|
# run program command
|
|
il.write_com(_binwrite.Command.RUN_PROG)
|
|
|
|
for v in ret:
|
|
assert isinstance(v, value)
|
|
add_read_command(il, variables, v.net)
|
|
|
|
il.write_com(_binwrite.Command.END_COM)
|
|
|
|
#print('* Data to runner:')
|
|
#il.print()
|
|
|
|
il.to_file('build/runner/test.copapy')
|
|
|
|
result = run_command(['build/runner/coparun', 'build/runner/test.copapy'])
|
|
print('* Output from runner:\n--')
|
|
print(result)
|
|
print('--')
|
|
|
|
assert 'Return value: 1' in result
|
|
#assert 'END_COM' in result
|
|
|
|
|
|
@pytest.mark.runner
|
|
def test_compile_log():
|
|
test_vals = [0.0, 0.0001, 0.1, 0.5, 1.0, 1.5, 2.0, 2.5, 3.0, 3.5, 4.0, 4.5, 5.0, 5.5, 6.0, 6.28318530718, 100.0, 1000.0, 100000.0]
|
|
|
|
ret = [r for v in test_vals for r in (cp.log(value(v)),)]
|
|
|
|
|
|
out = [Store(r) for r in ret]
|
|
|
|
il, variables = compile_to_dag(out, copapy.generic_sdb)
|
|
|
|
# run program command
|
|
il.write_com(_binwrite.Command.RUN_PROG)
|
|
|
|
for v in ret:
|
|
assert isinstance(v, value)
|
|
add_read_command(il, variables, v.net)
|
|
|
|
il.write_com(_binwrite.Command.END_COM)
|
|
|
|
#print('* Data to runner:')
|
|
#il.print()
|
|
|
|
il.to_file('build/runner/test.copapy')
|
|
|
|
result = run_command(['build/runner/coparun', 'build/runner/test.copapy'])
|
|
print('* Output from runner:\n--')
|
|
print(result)
|
|
print('--')
|
|
|
|
assert 'Return value: 1' in result
|
|
#assert 'END_COM' in result
|
|
|
|
|
|
@pytest.mark.runner
|
|
def test_compile_sin():
|
|
test_vals = [0.0, 0.0001, 0.1, 0.5, 1.0, 1.5, 2.0, 2.5, 3.0, 3.5, 4.0, 4.5, 5.0, 5.5, 6.0, 6.28318530718, 100.0, 1000.0, 100000.0]
|
|
|
|
ret = [r for v in test_vals for r in (cp.sin(value(v)),)]
|
|
|
|
|
|
out = [Store(r) for r in ret]
|
|
|
|
il, variables = compile_to_dag(out, copapy.generic_sdb)
|
|
|
|
# run program command
|
|
il.write_com(_binwrite.Command.RUN_PROG)
|
|
|
|
for v in ret:
|
|
assert isinstance(v, copapy.value)
|
|
add_read_command(il, variables, v.net)
|
|
|
|
il.write_com(_binwrite.Command.END_COM)
|
|
|
|
print('* Data to runner:')
|
|
#il.print()
|
|
|
|
il.to_file('build/runner/test.copapy')
|
|
|
|
result = run_command(['build/runner/coparun', 'build/runner/test.copapy'])
|
|
print('* Output from runner:\n--')
|
|
print(result)
|
|
print('--')
|
|
|
|
assert 'Return value: 1' in result
|
|
#assert 'END_COM' in result
|
|
|
|
|
|
if __name__ == "__main__":
|
|
test_compile_sqrt()
|
|
test_compile_log()
|
|
test_compile_sin()
|