mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 01:50:30 -04:00 
			
		
		
		
	
		
			
	
	
		
			215 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
		
		
			
		
	
	
			215 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|  | #!/usr/bin/python | ||
|  | 
 | ||
|  | # Copyright 2014 Steven Watanabe | ||
|  | # Copyright 2015 Artur Shepilko | ||
|  | # Distributed under the Boost Software License, Version 1.0. | ||
|  | # (See accompanying file LICENSE_1_0.txt or http://www.boost.org/LICENSE_1_0.txt) | ||
|  | 
 | ||
|  | # This tests the GLOB_ARCHIVE rule. | ||
|  | 
 | ||
|  | import os | ||
|  | import sys | ||
|  | import StringIO | ||
|  | import BoostBuild | ||
|  | 
 | ||
|  | vms = ( os.name == 'posix' and sys.platform == 'OpenVMS') | ||
|  | 
 | ||
|  | t = BoostBuild.Tester() | ||
|  | 
 | ||
|  | ## Setup test archive sources and symbols they contain. | ||
|  | sources = { | ||
|  |     "a.cpp" : ["a"], | ||
|  |     "b.cpp" : ["b"], | ||
|  |     "b_match.cpp" : ["b_match"], | ||
|  |     "c/nopath_check.cpp" : ["nopath_check"], | ||
|  |     "CaseCheck.cpp" : ["CaseCheck"], | ||
|  |     "seq_check1.cpp" : ["seq_check1"], | ||
|  |     "seq_check2.cpp" : ["seq_check2"], | ||
|  |     "seq_check3.cpp" : ["seq_check3"], | ||
|  |     "symbols_check.c" : ["symbol", "symbol_match"], | ||
|  |     "members_and_symbols_check.c" : ["member_and_symbol_match"], | ||
|  |     "symbol_case_check.c" : ["SymbolCaseCheck"], | ||
|  |     "main_check.cpp" : ["main"] | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | def create_sources(path, sources): | ||
|  |     for s in sources : | ||
|  |         f = os.path.join(path, s) | ||
|  |         t.write(f, "") | ||
|  |         output = StringIO.StringIO() | ||
|  |         for sym in sources[s] : | ||
|  |             output.write("int %s() { return 0; }\n" % sym) | ||
|  |         t.write(f, output.getvalue()) | ||
|  | 
 | ||
|  | 
 | ||
|  | def setup_archive(name, sources): | ||
|  |     global archive | ||
|  |     global obj_suffix | ||
|  |     archive = t.adjust_names(name)[0] | ||
|  |     obj_suffix = t.adjust_names(".obj")[0] | ||
|  |     output = StringIO.StringIO() | ||
|  |     t.write("jamroot.jam","") | ||
|  |     output.write("""\
 | ||
|  | static-lib %s : | ||
|  | """ % name.split(".")[0])
 | ||
|  |     ## sort the sources, so we can test order of the globbed members | ||
|  |     for s in sorted(sources) : | ||
|  |         output.write("""\
 | ||
|  |     %s | ||
|  | """ % s)
 | ||
|  |     output.write("""\
 | ||
|  |     ; | ||
|  | """)
 | ||
|  |     t.write("lib/jamfile.jam", output.getvalue()) | ||
|  |     create_sources("lib", sources) | ||
|  |     t.run_build_system(subdir="lib") | ||
|  |     built_archive = "lib/bin/$toolset/debug/%s" % name | ||
|  |     t.expect_addition(built_archive) | ||
|  |     t.copy(built_archive, name) | ||
|  |     t.rm("lib") | ||
|  | 
 | ||
|  | 
 | ||
|  | def test_glob_archive(archives, glob, expected, sort_results = False): | ||
|  |     output = StringIO.StringIO() | ||
|  |     ## replace placeholders | ||
|  |     glob = glob.replace("$archive1", archives[0]).replace("$obj", obj_suffix) | ||
|  |     expected = [ m.replace("$archive1", | ||
|  |                archives[0]).replace("$obj", obj_suffix) for m in expected ] | ||
|  |     if len(archives) > 1 : | ||
|  |         glob = glob.replace("$archive2", archives[1]).replace("$obj", obj_suffix) | ||
|  |         expected = [ m.replace("$archive2", | ||
|  |                archives[1]).replace("$obj", obj_suffix) for m in expected ] | ||
|  |     ## create test jamfile | ||
|  |     if sort_results : glob = "[ SORT %s ]" % glob | ||
|  |     output.write("""\
 | ||
|  |     for local p in %s | ||
|  |     { | ||
|  |         ECHO $(p) ; | ||
|  |     } | ||
|  |     UPDATE ; | ||
|  |     """ % glob)
 | ||
|  |     t.write("file.jam", output.getvalue()) | ||
|  |     ## run test jamfile and match against expected results | ||
|  |     if sort_results : expected.sort() | ||
|  |     t.run_build_system(["-ffile.jam"], stdout="\n".join(expected + [""])) | ||
|  |     t.rm("file.jam") | ||
|  | 
 | ||
|  | 
 | ||
|  | ## RUN TESTS | ||
|  | setup_archive("auxilliary1.lib", sources) | ||
|  | archive1 = archive | ||
|  | setup_archive("auxilliary2.lib", sources) | ||
|  | archive2 = archive | ||
|  | 
 | ||
|  | ## all arguments empty | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE ]", []) | ||
|  | 
 | ||
|  | ## empty query | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : ]", []) | ||
|  | 
 | ||
|  | ## no-match | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : a ]", []) | ||
|  | 
 | ||
|  | ## match exact | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : a$obj ]", | ||
|  |                   ["$archive1(a$obj)"]) | ||
|  | 
 | ||
|  | ## glob wildcards:1 | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : b.* ]", | ||
|  |                   ["$archive1(b$obj)"]) | ||
|  | 
 | ||
|  | ## glob wildcards:2 | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : \\b?match[\.]* ]", | ||
|  |                   ["$archive1(b_match$obj)"]) | ||
|  | 
 | ||
|  | ## glob wildcards:3 | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : b* ]", | ||
|  |                   ["$archive1(b$obj)", "$archive1(b_match$obj)"]) | ||
|  | 
 | ||
|  | ## glob multiple patterns with multiple results. | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : b.* b_* ]", | ||
|  |                   ["$archive1(b$obj)", "$archive1(b_match$obj)"]) | ||
|  | 
 | ||
|  | ## glob multiple archives and patterns. | ||
|  | test_glob_archive([archive1, archive2], | ||
|  |                   "[ GLOB_ARCHIVE $archive1 $archive2 : b.* b_* ]", | ||
|  |                   ["$archive1(b$obj)", "$archive1(b_match$obj)", | ||
|  |                    "$archive2(b$obj)", "$archive2(b_match$obj)"]) | ||
|  | 
 | ||
|  | ## glob same archive multiple times. | ||
|  | test_glob_archive([archive1, archive1], | ||
|  |                   "[ GLOB_ARCHIVE $archive1 $archive2 $archive1 : b.* ]", | ||
|  |                    ["$archive1(b$obj)", "$archive2(b$obj)", "$archive1(b$obj)"]) | ||
|  | 
 | ||
|  | ## returned archive member has no path, even though its source object-file did. | ||
|  | ## this is rather NT-specific, where members also store their object-file's path. | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : nopath_check$obj ]", | ||
|  |                   ["$archive1(nopath_check$obj)"]) | ||
|  | 
 | ||
|  | ## case insensitive matching, when archives support case sensitive member names. | ||
|  | ## VMS implementation forces case-insensitive matching and downcased member names. | ||
|  | 
 | ||
|  | case_sensitive_members = ( not vms ) | ||
|  | 
 | ||
|  | if case_sensitive_members: | ||
|  |     test_glob_archive([archive1], | ||
|  |                       "[ GLOB_ARCHIVE $archive1 : casecheck$obj : true ]", | ||
|  |                       ["$archive1(CaseCheck$obj)"]) | ||
|  | elif vms: | ||
|  |     test_glob_archive([archive1], | ||
|  |                       "[ GLOB_ARCHIVE $archive1 : CaseCheck$obj : false ]", | ||
|  |                       ["$archive1(casecheck$obj)"]) | ||
|  | 
 | ||
|  | 
 | ||
|  | ## test the order of matched members, in general it should match the | ||
|  | ## insertion sequence. | ||
|  | test_glob_archive([archive1], "[ GLOB_ARCHIVE $archive1 : seq_check*$obj ]", | ||
|  |                   ["$archive1(seq_check1$obj)", "$archive1(seq_check2$obj)", | ||
|  |                    "$archive1(seq_check3$obj)"]) | ||
|  | 
 | ||
|  | 
 | ||
|  | ## glob members by symbols they contain. | ||
|  | ## Currently supported only on VMS. | ||
|  | symbol_glob_supported = ( vms ) | ||
|  | 
 | ||
|  | if symbol_glob_supported : | ||
|  |     ## NOTE: generated symbols are compiler-dependent and may be specifically | ||
|  |     ## mangled (as in C++ case), so globbing by exact symbol is non-trivial. | ||
|  |     ## However, C-generated symbols are likely to have more portable names, | ||
|  |     ## so for the glob-by-symbol tests we glob C-generated archive members. | ||
|  | 
 | ||
|  |     ## glob members by exact symbol. | ||
|  |     test_glob_archive([archive1], | ||
|  |                       "[ GLOB_ARCHIVE $archive1 : : : symbol ]", | ||
|  |                       ["$archive1(symbols_check$obj)"]) | ||
|  | 
 | ||
|  |     ## glob members by symbol wildcard. | ||
|  |     test_glob_archive([archive1], | ||
|  |                       "[ GLOB_ARCHIVE $archive1 : : : symbol_* ]", | ||
|  |                       ["$archive1(symbols_check$obj)"]) | ||
|  | 
 | ||
|  |     ## glob members by member pattern AND symbol pattern. | ||
|  |     test_glob_archive([archive1], | ||
|  |                       "[ GLOB_ARCHIVE $archive1 : *symbol* : : *member* ]", | ||
|  |                       ["$archive1(members_and_symbols_check$obj)"]) | ||
|  | 
 | ||
|  |     ## case insensitive symbol glob. | ||
|  |     test_glob_archive([archive1], | ||
|  |                       "[ GLOB_ARCHIVE $archive1 : : true : symbolcasecheck ]", | ||
|  |                       ["$archive1(symbol_case_check$obj)"]) | ||
|  | 
 | ||
|  |     ## glob member that contains main symbol. | ||
|  |     test_glob_archive([archive1], | ||
|  |                       "[ GLOB_ARCHIVE $archive1 : : : main _main ]", | ||
|  |                       ["$archive1(main_check$obj)"]) | ||
|  | 
 | ||
|  | else: | ||
|  |     test_glob_archive([archive1], | ||
|  |                       "[ GLOB_ARCHIVE $archive1 : : : symbol ]", | ||
|  |                       []) | ||
|  | 
 | ||
|  | 
 | ||
|  | t.cleanup() | ||
|  | 
 |