summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2015-08-29 17:24:29 +0300
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2015-08-29 17:24:29 +0300
commit5cb524673eff51be4b3abdf04548ac854dd32ef1 (patch)
treee4aa508e7a06c6137f31343913a35dd2e4f1881c
parenta66a99bfd8c87e79682bddc0a08bfeeabe978c2a (diff)
downloadmicropython-5cb524673eff51be4b3abdf04548ac854dd32ef1.tar.gz
micropython-5cb524673eff51be4b3abdf04548ac854dd32ef1.zip
tests/ffi_float: Split tgammaf() testcase to a separate test.
Some libc's may implement tgammaf as a header macro using tgamma(), so don't assume it'll be in the library.
-rw-r--r--tests/unix/ffi_float.py3
-rw-r--r--tests/unix/ffi_float.py.exp6
-rw-r--r--tests/unix/ffi_float2.py32
-rw-r--r--tests/unix/ffi_float2.py.exp6
4 files changed, 39 insertions, 8 deletions
diff --git a/tests/unix/ffi_float.py b/tests/unix/ffi_float.py
index 788b818be5..cc12fa7ad9 100644
--- a/tests/unix/ffi_float.py
+++ b/tests/unix/ffi_float.py
@@ -28,7 +28,6 @@ print('%.6f' % strtod('1.23', None))
# test passing double and float args
libm = ffi_open(('libm.so', 'libm.so.6', 'libc.so.0', 'libc.so.6', 'libc.dylib'))
tgamma = libm.func('d', 'tgamma', 'd')
-tgammaf = libm.func('f', 'tgammaf', 'f')
-for fun in (tgamma, tgammaf):
+for fun in (tgamma,):
for val in (0.5, 1, 1.0, 1.5, 4, 4.0):
print('%.6f' % fun(val))
diff --git a/tests/unix/ffi_float.py.exp b/tests/unix/ffi_float.py.exp
index f50613000a..b9d7da2bdb 100644
--- a/tests/unix/ffi_float.py.exp
+++ b/tests/unix/ffi_float.py.exp
@@ -6,9 +6,3 @@
0.886227
6.000000
6.000000
-1.772454
-1.000000
-1.000000
-0.886227
-6.000000
-6.000000
diff --git a/tests/unix/ffi_float2.py b/tests/unix/ffi_float2.py
new file mode 100644
index 0000000000..d635a27140
--- /dev/null
+++ b/tests/unix/ffi_float2.py
@@ -0,0 +1,32 @@
+# test ffi float support
+import sys
+try:
+ import ffi
+except ImportError:
+ print("SKIP")
+ sys.exit()
+
+
+def ffi_open(names):
+ err = None
+ for n in names:
+ try:
+ mod = ffi.open(n)
+ return mod
+ except OSError as e:
+ err = e
+ raise err
+
+libm = ffi_open(('libm.so', 'libm.so.6', 'libc.so.0', 'libc.so.6', 'libc.dylib'))
+
+# Some libc's implement tgammaf as header macro with tgamma(), so don't assume
+# it'll be in library.
+try:
+ tgammaf = libm.func('f', 'tgammaf', 'f')
+except OSError:
+ print("SKIP")
+ sys.exit()
+
+for fun in (tgammaf,):
+ for val in (0.5, 1, 1.0, 1.5, 4, 4.0):
+ print('%.6f' % fun(val))
diff --git a/tests/unix/ffi_float2.py.exp b/tests/unix/ffi_float2.py.exp
new file mode 100644
index 0000000000..58fc6a01ac
--- /dev/null
+++ b/tests/unix/ffi_float2.py.exp
@@ -0,0 +1,6 @@
+1.772454
+1.000000
+1.000000
+0.886227
+6.000000
+6.000000