diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:45:59 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:45:59 +0000 |
commit | 19fcec84d8d7d21e796c7624e521b60d28ee21ed (patch) | |
tree | 42d26aa27d1e3f7c0b8bd3fd14e7d7082f5008dc /src/boost/tools/build/test/lib_zlib.py | |
parent | Initial commit. (diff) | |
download | ceph-upstream.tar.xz ceph-upstream.zip |
Adding upstream version 16.2.11+ds.upstream/16.2.11+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/boost/tools/build/test/lib_zlib.py')
-rwxr-xr-x | src/boost/tools/build/test/lib_zlib.py | 184 |
1 files changed, 184 insertions, 0 deletions
diff --git a/src/boost/tools/build/test/lib_zlib.py b/src/boost/tools/build/test/lib_zlib.py new file mode 100755 index 000000000..04d32ba70 --- /dev/null +++ b/src/boost/tools/build/test/lib_zlib.py @@ -0,0 +1,184 @@ +#!/usr/bin/python + +# Copyright (C) 2013 Steven Watanabe +# Distributed under the Boost Software License, Version 1.0. +# (See accompanying file LICENSE_1_0.txt or copy at +# http://www.boost.org/LICENSE_1_0.txt) + +import BoostBuild +import MockToolset + +t = BoostBuild.Tester(arguments=['toolset=mock', '--ignore-site-config', '--user-config='], pass_toolset=0) + +MockToolset.create(t) + +# Build from source +t.write("zlib/zlib.h", 'zlib') +t.write("zlib/deflate.c", 'deflate') + +t.write("Jamroot.jam", """ +path-constant here : . ; +using zlib : : <source>$(here)/zlib ; +alias zlib : /zlib//zlib : : <link>static <link>shared ; +""") + +MockToolset.set_expected(t, ''' +source_file('deflate.c', 'deflate') +action('-c -x c -I./zlib -o $deflate.o $deflate.c') +action('-c -x c -I./zlib -DZLIB_DLL -o $deflate-shared.o $deflate.c') +action('--dll $deflate-shared.o -o $deflate.so') +action('--archive $deflate.o -o $deflate.a') +''') + +t.run_build_system() +t.expect_addition('bin/standalone/zlib/mock/debug/z.dll') +t.expect_addition('bin/standalone/zlib/mock/debug/link-static/z.lib') + +# Build from source specified in the environment +t.rm('bin') +t.rm('zlib') + +t.write("zlib root/zlib.h", 'zlib') +t.write("zlib root/deflate.c", 'deflate') + +t.write("Jamroot.jam", """ +using zlib ; +alias zlib : /zlib//zlib : : <link>static <link>shared ; +""") + +MockToolset.set_expected(t, ''' +source_file('deflate.c', 'deflate') +action(['-c', '-x', 'c', '-I./zlib root', '-o', '$deflate.o', '$deflate.c']) +action(['-c', '-x', 'c', '-I./zlib root', '-DZLIB_DLL', '-o', '$deflate-shared.o', '$deflate.c']) +action('--dll $deflate-shared.o -o $deflate.so') +action('--archive $deflate.o -o $deflate.a') +''') +t.run_build_system(['-sZLIB_SOURCE=zlib root']) +t.expect_addition('bin/standalone/zlib/mock/debug/z.dll') +t.expect_addition('bin/standalone/zlib/mock/debug/link-static/z.lib') + + +t.rm('zlib root') + +# Generic definitions that aren't configuration specific +common_stuff = ''' +source_file('test.cpp', 'test.cpp') +source_file('main.cpp', 'int main() {}') +source_file('zlib.h.cpp', '#include <zlib.h>\\n') +action('-c -x c++ $main.cpp -o $main.o') +''' +t.write('test.cpp', 'test.cpp') + +# Default initialization - static library +t.rm('bin') +t.write("Jamroot.jam", """ +path-constant here : . ; +using zlib ; +exe test : test.cpp /zlib//zlib : : <link>static <link>shared ; +""") + +MockToolset.set_expected(t, common_stuff + ''' +action('$main.o --static-lib=z -o $config.exe') +action('-c -x c++ $zlib.h.cpp -o $zlib.h.o') +action('-c -x c++ $test.cpp -o $test.o') +action('$test.o --static-lib=z -o $test') +''') +t.run_build_system() +t.expect_addition('bin/mock/debug/test.exe') +t.expect_addition('bin/mock/debug/link-static/test.exe') + +# Default initialization - shared library +t.rm('bin') +t.write("Jamroot.jam", """ +path-constant here : . ; +using zlib ; +exe test : test.cpp /zlib//zlib : : <link>static <link>shared ; +""") + +MockToolset.set_expected(t, common_stuff + ''' +action('$main.o --shared-lib=z -o $config.exe') +action('-c -x c++ $zlib.h.cpp -o $zlib.h.o') +action('-c -x c++ $test.cpp -o $test.o') +action('$test.o --shared-lib=z -o $test') +''') +t.run_build_system() +t.expect_addition('bin/mock/debug/test.exe') +t.expect_addition('bin/mock/debug/link-static/test.exe') + +# Initialization in explicit location - static library +t.rm('bin') +t.write("Jamroot.jam", """ +path-constant here : . ; +using zlib : : <name>myzlib <include>$(here)/zlib <search>$(here)/zlib ; +exe test : test.cpp /zlib//zlib : : <link>static <link>shared ; +""") + +t.write('zlib/zlib.h', 'zlib') + +MockToolset.set_expected(t, common_stuff + ''' +action('$main.o -L./zlib --static-lib=myzlib -o $config.exe') +action('-c -x c++ $test.cpp -I./zlib -o $test.o') +action('$test.o -L./zlib --static-lib=myzlib -o $test') +''') +t.run_build_system() +t.expect_addition('bin/mock/debug/test.exe') +t.expect_addition('bin/mock/debug/link-static/test.exe') + +# Initialization in explicit location - shared library +t.rm('bin') +t.write("Jamroot.jam", """ +path-constant here : . ; +using zlib : : <name>myzlib <include>$(here)/zlib <search>$(here)/zlib ; +exe test : test.cpp /zlib//zlib : : <link>static <link>shared ; +""") + +MockToolset.set_expected(t, common_stuff + ''' +action('$main.o -L./zlib --shared-lib=myzlib -o $config.exe') +action('-c -x c++ $test.cpp -I./zlib -o $test.o') +action('$test.o -L./zlib --shared-lib=myzlib -o $test') +''') +t.run_build_system() +t.expect_addition('bin/mock/debug/test.exe') +t.expect_addition('bin/mock/debug/link-static/test.exe') + +# Initialization in explicit location - both static and shared libraries +t.rm('bin') +t.write("Jamroot.jam", """ +path-constant here : . ; +using zlib : : <name>myzlib <include>$(here)/zlib <search>$(here)/zlib ; +exe test : test.cpp /zlib//zlib + : <link>shared:<define>SHARED : <link>static <link>shared ; +""") + +MockToolset.set_expected(t, common_stuff + ''' +action('$main.o -L./zlib --static-lib=myzlib -o $config.exe') +action('$main.o -L./zlib --shared-lib=myzlib -o $config.exe') +action('-c -x c++ $test.cpp -I./zlib -o $test-static.o') +action('-c -x c++ $test.cpp -I./zlib -DSHARED -o $test-shared.o') +action('$test-static.o -L./zlib --static-lib=myzlib -o $test') +action('$test-shared.o -L./zlib --shared-lib=myzlib -o $test') +''') +t.run_build_system() +t.expect_addition('bin/mock/debug/test.exe') +t.expect_addition('bin/mock/debug/link-static/test.exe') + +# Initialization from the environment +t.rm('bin') +t.write('Jamroot.jam', """ +using zlib ; +exe test : test.cpp /zlib//zlib + : : <link>static <link>shared ; +""") +t.write('zlib root/zlib.h', 'zlib') +MockToolset.set_expected(t, common_stuff + ''' +action(['$main.o', '-L./zlib root', '--shared-lib=myzlib', '-o', '$config.exe']) +action(['-c', '-x', 'c++', '$test.cpp', '-I./zlib root', '-o', '$test.o']) +action(['$test.o', '-L./zlib root', '--shared-lib=myzlib', '-o', '$test']) +''') +t.run_build_system(['-sZLIB_INCLUDE=zlib root', + '-sZLIB_LIBRARY_PATH=zlib root', + '-sZLIB_NAME=myzlib']) +t.expect_addition('bin/mock/debug/test.exe') +t.expect_addition('bin/mock/debug/link-static/test.exe') + +t.cleanup() |