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.
This commit is contained in:
Paul Sokolovsky 2015-08-29 17:24:29 +03:00
parent a66a99bfd8
commit 5cb524673e
4 changed files with 39 additions and 8 deletions

View File

@ -28,7 +28,6 @@ print('%.6f' % strtod('1.23', None))
# test passing double and float args # test passing double and float args
libm = ffi_open(('libm.so', 'libm.so.6', 'libc.so.0', 'libc.so.6', 'libc.dylib')) libm = ffi_open(('libm.so', 'libm.so.6', 'libc.so.0', 'libc.so.6', 'libc.dylib'))
tgamma = libm.func('d', 'tgamma', 'd') tgamma = libm.func('d', 'tgamma', 'd')
tgammaf = libm.func('f', 'tgammaf', 'f') for fun in (tgamma,):
for fun in (tgamma, tgammaf):
for val in (0.5, 1, 1.0, 1.5, 4, 4.0): for val in (0.5, 1, 1.0, 1.5, 4, 4.0):
print('%.6f' % fun(val)) print('%.6f' % fun(val))

View File

@ -6,9 +6,3 @@
0.886227 0.886227
6.000000 6.000000
6.000000 6.000000
1.772454
1.000000
1.000000
0.886227
6.000000
6.000000

32
tests/unix/ffi_float2.py Normal file
View File

@ -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))

View File

@ -0,0 +1,6 @@
1.772454
1.000000
1.000000
0.886227
6.000000
6.000000