13
0

Add --single-tests option to also build each libardour test as a separate program

This commit is contained in:
Paul Davis 2013-07-11 10:57:21 -04:00
parent 83a92a0ea1
commit 7a5118f403
4 changed files with 115 additions and 90 deletions

View File

@ -3,30 +3,12 @@
# Run libardour profiling tests. # Run libardour profiling tests.
# #
if [ ! -f './tempo.cc' ]; then
echo "This script must be run from within the libs/ardour directory";
exit 1;
fi
if [ "$1" == "" ]; then if [ "$1" == "" ]; then
echo "Syntax: run-profiling.sh [flag] <test> [<args>]" echo "Syntax: run-profiling.sh [flag] <test> [<args>]"
exit 1; exit 1;
fi fi
cd ../.. . test-env.sh
top=`pwd`
cd build
libs='libs'
export LD_LIBRARY_PATH=$libs/audiographer:$libs/vamp-sdk:$libs/surfaces:$libs/surfaces/control_protocol:$libs/ardour:$libs/midi++2:$libs/pbd:$libs/rubberband:$libs/soundtouch:$libs/gtkmm2ext:$libs/appleutility:$libs/taglib:$libs/evoral:$libs/evoral/src/libsmf:$libs/timecode:/usr/local/lib:/usr/local/lib64:$LD_LIBRARY_PATH
export ARDOUR_CONFIG_PATH=$top:$top/gtk2_ardour:$libs/..:$libs/../gtk2_ardour
export ARDOUR_PANNER_PATH=$libs/panners/2in2out:$libs/panners/1in2out:$libs/panners/vbap
export ARDOUR_SURFACES_PATH=$libs/surfaces/osc:$libs/surfaces/generic_midi:$libs/surfaces/tranzport:$libs/surfaces/powermate:$libs/surfaces/mackie
export ARDOUR_MCP_PATH="../mcp"
export ARDOUR_DLL_PATH=$libs
export ARDOUR_DATA_PATH=$top/gtk2_ardour:$top/build/gtk2_ardour:.
export LD_PRELOAD=/home/carl/src/libfakejack/libjack.so export LD_PRELOAD=/home/carl/src/libfakejack/libjack.so
# session='32tracks' # session='32tracks'

View File

@ -3,30 +3,32 @@
# Run libardour test suite. # Run libardour test suite.
# #
if [ ! -f './tempo.cc' ]; then if [ "$1" == "--single" ] || [ "$2" == "--single" ]; then
echo "This script must be run from within the libs/ardour directory"; if [ "$1" == "--single" ]; then
exit 1; TESTS="test_*$2*"
fi elif [ "$2" == "--single" ]; then
TESTS="test_*$3*"
cd ../.. else
top=`pwd` TESTS='test_*'
cd build fi
for test_program in `find libs/ardour -name "$TESTS" -type f -perm /u+x`;
libs='libs' do
echo "Running $test_program..."
export LD_LIBRARY_PATH=$libs/audiographer:$libs/vamp-sdk:$libs/surfaces:$libs/surfaces/control_protocol:$libs/ardour:$libs/midi++2:$libs/pbd:$libs/rubberband:$libs/soundtouch:$libs/gtkmm2ext:$libs/appleutility:$libs/taglib:$libs/evoral:$libs/evoral/src/libsmf:$libs/timecode:$libs/libltc:/usr/local/lib:/usr/local/lib64:$LD_LIBRARY_PATH if [ "$1" == "--debug" ]; then
gdb ./"$test_program"
export ARDOUR_CONFIG_PATH=$top:$top/gtk2_ardour:$libs/..:$libs/../gtk2_ardour elif [ "$1" == "--valgrind" ]; then
export ARDOUR_PANNER_PATH=$libs/panners/2in2out:$libs/panners/1in2out:$libs/panners/vbap valgrind ./"$test_program"
export ARDOUR_SURFACES_PATH=$libs/surfaces/osc:$libs/surfaces/generic_midi:$libs/surfaces/tranzport:$libs/surfaces/powermate:$libs/surfaces/mackie else
export ARDOUR_MCP_PATH="../mcp" ./"$test_program"
export ARDOUR_DLL_PATH=$libs fi
export ARDOUR_DATA_PATH=$top/gtk2_ardour:$top/build/gtk2_ardour:. done
if [ "$1" == "--debug" ]; then
gdb ./libs/ardour/run-tests
elif [ "$1" == "--valgrind" ]; then
valgrind ./libs/ardour/run-tests
else else
./libs/ardour/run-tests $* if [ "$1" == "--debug" ]; then
gdb ./libs/ardour/run-tests
elif [ "$1" == "--valgrind" ]; then
valgrind ./libs/ardour/run-tests
else
./libs/ardour/run-tests $*
fi
fi fi

View File

@ -440,29 +440,65 @@ def build(bld):
if bld.env['BUILD_TESTS'] and bld.is_defined('HAVE_CPPUNIT'): if bld.env['BUILD_TESTS'] and bld.is_defined('HAVE_CPPUNIT'):
# Unit tests # Unit tests
testobj = bld(features = 'cxx cxxprogram') # only build these common sources once
testobj.source = ''' testcommon = bld(features = 'cxx')
test/dummy_lxvst.cc testcommon.includes = obj.includes + ['test', '../pbd', '..']
test/test_util.cc testcommon.source = ['test/test_globals.cc', 'test/testrunner.cc', 'test/test_needing_session.cc',
test/test_needing_session.cc 'test/dummy_lxvst.cc', 'test/audio_region_test.cc', 'test/test_util.cc' ]
test/audio_region_test.cc testcommon.uselib = ['CPPUNIT','SIGCPP','JACK','GLIBMM','GTHREAD',
test/test_globals.cc 'SAMPLERATE','XML','LRDF','COREAUDIO']
test/automation_list_property_test.cc testcommon.use = ['libpbd','libmidipp','libevoral','libvamphost',
test/bbt_test.cc 'libvampplugin','libtaglib','librubberband',
test/tempo_test.cc 'libaudiographer','libltc','ardour']
test/interpolation_test.cc testcommon.defines = [
test/midi_clock_slave_test.cc 'DATA_DIR="' + os.path.normpath(bld.env['DATADIR']) + '"',
test/resampled_source_test.cc 'CONFIG_DIR="' + os.path.normpath(bld.env['SYSCONFDIR']) + '"',
test/framewalk_to_beats_test.cc 'LOCALEDIR="' + os.path.join(
test/framepos_plus_beats_test.cc os.path.normpath(bld.env['DATADIR']), 'locale') + '"',
test/framepos_minus_beats_test.cc 'VAMP_DIR="' + os.path.join(
test/playlist_layering_test.cc os.path.normpath(bld.env['LIBDIR']), 'ardour3', 'vamp') + '"'
test/playlist_equivalent_regions_test.cc ]
test/control_surfaces_test.cc testcommon.name = 'testcommon'
test/region_naming_test.cc
test/load_sessions_test.cc if bld.env['FPU_OPTIMIZATION']:
test/mtdm_test.cc testcommon.source += [ 'sse_functions_xmm.cc' ]
test/testrunner.cc if (bld.env['build_target'] == 'i386'
or bld.env['build_target'] == 'i686'):
testcommon.source += [ 'sse_functions.s' ]
elif bld.env['build_target'] == 'x86_64':
testcommon.source += [ 'sse_functions_64bit.s' ]
if bld.env['SINGLE_TESTS']:
create_ardour_test_program(bld, obj.includes, 'automation_list_property_test', 'test_automation_list_property', ['test/automation_list_property_test.cc'])
create_ardour_test_program(bld, obj.includes, 'bbt', 'test_bbt', ['test/bbt_test.cc'])
create_ardour_test_program(bld, obj.includes, 'tempo', 'test_tempo', ['test/tempo_test.cc'])
create_ardour_test_program(bld, obj.includes, 'interpolation', 'test_interpolation', ['test/interpolation_test.cc'])
create_ardour_test_program(bld, obj.includes, 'midi_clock_slave', 'test_midi_clock_slave', ['test/midi_clock_slave_test.cc'])
create_ardour_test_program(bld, obj.includes, 'resampled_source', 'test_resampled_source', ['test/resampled_source_test.cc'])
create_ardour_test_program(bld, obj.includes, 'framewalk_to_beats', 'test_framewalk_to_beats', ['test/framewalk_to_beats_test.cc'])
create_ardour_test_program(bld, obj.includes, 'framepos_plus_beats', 'test_framepos_plus_beats', ['test/framepos_plus_beats_test.cc'])
create_ardour_test_program(bld, obj.includes, 'framepos_minus_beats', 'test_framepos_minus_beats', ['test/framepos_minus_beats_test.cc'])
create_ardour_test_program(bld, obj.includes, 'playlist_equivalent_regions', 'test_playlist_equivalent_regions', ['test/playlist_equivalent_regions_test.cc'])
create_ardour_test_program(bld, obj.includes, 'playlist_layering', 'test_playlist_layering', ['test/playlist_layering_test.cc'])
create_ardour_test_program(bld, obj.includes, 'region_naming', 'test_region_naming', ['test/region_naming_test.cc'])
create_ardour_test_program(bld, obj.includes, 'control_surface', 'test_control_surfaces', ['test/control_surfaces_test.cc'])
create_ardour_test_program(bld, obj.includes, 'mtdm_test', 'test_mtdm', ['test/mtdm_test.cc'])
test_sources = '''
test/automation_list_property_test.cc
test/bbt_test.cc
test/tempo_test.cc
test/interpolation_test.cc
test/midi_clock_slave_test.cc
test/resampled_source_test.cc
test/framewalk_to_beats_test.cc
test/framepos_plus_beats_test.cc
test/framepos_minus_beats_test.cc
test/playlist_equivalent_regions_test.cc
test/playlist_layering_test.cc
test/region_naming_test.cc
test/control_surfaces_test.cc
test/mtdm_test.cc
'''.split() '''.split()
# Tests that don't work # Tests that don't work
@ -471,29 +507,7 @@ def build(bld):
# test/combine_regions_test.cc # test/combine_regions_test.cc
# test/mantis_3356_test.cc # test/mantis_3356_test.cc
testobj.includes = obj.includes + ['test', '../pbd', '../libltc', '../audiographer'] create_ardour_test_program(bld, obj.includes, 'libardour-tests', 'run-tests', test_sources)
testobj.uselib = ['CPPUNIT','SIGCPP','JACK','GLIBMM','GTHREAD',
'SAMPLERATE','XML','LRDF','COREAUDIO']
testobj.use = ['libpbd','libmidipp','ardour','libltc','libaudiographer']
testobj.name = 'libardour-tests'
testobj.target = 'run-tests'
testobj.install_path = ''
testobj.defines = [
'PACKAGE="libardour3test"',
'DATA_DIR="' + os.path.normpath(bld.env['DATADIR']) + '"',
'CONFIG_DIR="' + os.path.normpath(bld.env['SYSCONFDIR']) + '"',
'LOCALEDIR="' + os.path.join(
os.path.normpath(bld.env['DATADIR']), 'locale') + '"',
'VAMP_DIR="' + os.path.join(
os.path.normpath(bld.env['LIBDIR']), 'ardour3', 'vamp') + '"'
]
if bld.env['FPU_OPTIMIZATION']:
testobj.source += [ 'sse_functions_xmm.cc' ]
if (bld.env['build_target'] == 'i386'
or bld.env['build_target'] == 'i686'):
testobj.source += [ 'sse_functions.s' ]
elif bld.env['build_target'] == 'x86_64':
testobj.source += [ 'sse_functions_64bit.s' ]
# Tester to just load a session # Tester to just load a session
session_load_tester = bld(features = 'cxx cxxprogram') session_load_tester = bld(features = 'cxx cxxprogram')
@ -563,6 +577,29 @@ def build(bld):
elif bld.env['build_target'] == 'x86_64': elif bld.env['build_target'] == 'x86_64':
profilingobj.source += [ 'sse_functions_64bit.s' ] profilingobj.source += [ 'sse_functions_64bit.s' ]
def create_ardour_test_program(bld, includes, name, target, sources):
testobj = bld(features = 'cxx cxxprogram')
testobj.includes = includes + ['test', '../pbd', '..']
testobj.source = sources
testobj.uselib = ['CPPUNIT','SIGCPP','JACK','GLIBMM','GTHREAD',
'SAMPLERATE','XML','LRDF','COREAUDIO']
testobj.use = ['libpbd','libmidipp','libevoral','libvamphost',
'libvampplugin','libtaglib','librubberband',
'libaudiographer','libltc','ardour','testcommon']
testobj.name = name
testobj.target = target
# not sure about install path
testobj.install_path = os.path.join(bld.env['LIBDIR'], 'ardour3')
testobj.defines = [
'PACKAGE="libardour3test"',
'DATA_DIR="' + os.path.normpath(bld.env['DATADIR']) + '"',
'CONFIG_DIR="' + os.path.normpath(bld.env['SYSCONFDIR']) + '"',
'LOCALEDIR="' + os.path.join(
os.path.normpath(bld.env['DATADIR']), 'locale') + '"',
'VAMP_DIR="' + os.path.join(
os.path.normpath(bld.env['LIBDIR']), 'ardour3', 'vamp') + '"'
]
def shutdown(): def shutdown():
autowaf.shutdown() autowaf.shutdown()

View File

@ -429,6 +429,8 @@ def options(opt):
help='Raise a floating point exception if a denormal is detected') help='Raise a floating point exception if a denormal is detected')
opt.add_option('--test', action='store_true', default=False, dest='build_tests', opt.add_option('--test', action='store_true', default=False, dest='build_tests',
help="Build unit tests") help="Build unit tests")
opt.add_option('--single-tests', action='store_true', default=False, dest='single_tests',
help="Build a single executable for each unit test")
#opt.add_option('--tranzport', action='store_true', default=False, dest='tranzport', #opt.add_option('--tranzport', action='store_true', default=False, dest='tranzport',
# help='Compile with support for Frontier Designs Tranzport (if libusb is available)') # help='Compile with support for Frontier Designs Tranzport (if libusb is available)')
opt.add_option('--universal', action='store_true', default=False, dest='universal', opt.add_option('--universal', action='store_true', default=False, dest='universal',
@ -626,6 +628,8 @@ def configure(conf):
conf.env['ENABLE_NLS'] = True conf.env['ENABLE_NLS'] = True
if opts.build_tests: if opts.build_tests:
conf.env['BUILD_TESTS'] = opts.build_tests conf.env['BUILD_TESTS'] = opts.build_tests
if opts.single_tests:
conf.env['SINGLE_TESTS'] = opts.single_tests
#if opts.tranzport: #if opts.tranzport:
# conf.env['TRANZPORT'] = 1 # conf.env['TRANZPORT'] = 1
if opts.windows_vst: if opts.windows_vst: