diff options
author | Steven Knight <knight@baldmt.com> | 2005-06-07 11:32:40 (GMT) |
---|---|---|
committer | Steven Knight <knight@baldmt.com> | 2005-06-07 11:32:40 (GMT) |
commit | 086a115a4add32f83be62140e9c0677cfdb90d73 (patch) | |
tree | d6cd2aac66041c1064740f28d018220815d9a210 /test | |
parent | 7a75ef62e1067b6c8af61f1656c54f5d6853432c (diff) | |
download | SCons-086a115a4add32f83be62140e9c0677cfdb90d73.zip SCons-086a115a4add32f83be62140e9c0677cfdb90d73.tar.gz SCons-086a115a4add32f83be62140e9c0677cfdb90d73.tar.bz2 |
Split Node-specific stuff from BuildInfo into a separate NodeInfo class. Add size info to the File information we collect.
Diffstat (limited to 'test')
-rw-r--r-- | test/chained-build.py | 18 | ||||
-rw-r--r-- | test/sconsign/old.py | 197 | ||||
-rw-r--r-- | test/sconsign/script.py | 228 |
3 files changed, 154 insertions, 289 deletions
diff --git a/test/chained-build.py b/test/chained-build.py index d2772e2..9d87347 100644 --- a/test/chained-build.py +++ b/test/chained-build.py @@ -76,9 +76,11 @@ test.write(['w1', 'foo.in'], "foo.in 2") test.run(chdir='w1', arguments="--max-drift=0 -f SConstruct1 foo.mid", stdout = test.wrap_stdout('build(["foo.mid"], ["foo.in"])\n')) -test.run(chdir='w1', - arguments="--max-drift=0 -f SConstruct2 foo.out", - stdout = test.wrap_stdout('build(["foo.out"], ["foo.mid"])\n')) +# Because we're using --max-drift=0, we use the cached csig value +# and think that foo.mid hasn't changed even though it has on disk. +test.up_to_date(chdir='w1', + options="--max-drift=0 -f SConstruct2", + arguments="foo.out") test.up_to_date(chdir='w1', options="--max-drift=0 -f SConstruct1", @@ -87,4 +89,14 @@ test.up_to_date(chdir='w1', options="--max-drift=0 -f SConstruct2", arguments="foo.out") +# Now try with --max-drift disabled. The build of foo.mid should still +# be considered up-to-date, but the build of foo.out now detects the +# change and rebuilds, too. +test.up_to_date(chdir='w1', + options="--max-drift=-1 -f SConstruct1", + arguments="foo.mid") +test.run(chdir='w1', + arguments="--max-drift=-1 -f SConstruct2 foo.out", + stdout = test.wrap_stdout('build(["foo.out"], ["foo.mid"])\n')) + test.pass_test() diff --git a/test/sconsign/old.py b/test/sconsign/old.py deleted file mode 100644 index 703a924..0000000 --- a/test/sconsign/old.py +++ /dev/null @@ -1,197 +0,0 @@ -#!/usr/bin/env python -# -# __COPYRIGHT__ -# -# Permission is hereby granted, free of charge, to any person obtaining -# a copy of this software and associated documentation files (the -# "Software"), to deal in the Software without restriction, including -# without limitation the rights to use, copy, modify, merge, publish, -# distribute, sublicense, and/or sell copies of the Software, and to -# permit persons to whom the Software is furnished to do so, subject to -# the following conditions: -# -# The above copyright notice and this permission notice shall be included -# in all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY -# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE -# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND -# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE -# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION -# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION -# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -# - -__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" - -""" -Test the transition from the old .sconsign format(s). -""" - -import os -import os.path -import string -import sys -import TestSCons - -python = TestSCons.python - -test = TestSCons.TestSCons() - -test.subdir('src1', ['src1', 'subdir'], - 'src2', ['src2', 'subdir']) - -convert = test.workpath('convert.py') -convert_dblite = test.workpath('convert_dblite.py') - -test.write(convert, """\ -import cPickle -import sys -import SCons.SConsign -import SCons.Sig - -try: - SConsignEntry = SCons.Sig.SConsignEntry -except AttributeError: - class SConsignEntry: - timestamp = None - bsig = None - csig = None - implicit = None - -filename = sys.argv[1] - -sconsign = SCons.SConsign.Dir(open(filename, 'rb')) - -old_entries = {} -for name, entry in sconsign.entries.items(): - oe = SConsignEntry() - for attr in ['timestamp', 'bsig', 'csig', 'implicit']: - try: setattr(oe, attr, getattr(entry, attr)) - except AttributeError: pass - old_entries[name] = oe - -cPickle.dump(old_entries, open(filename, 'wb'), 1) -""") - -test.write(convert_dblite, """\ -import cPickle -import SCons.dblite -import sys -import SCons.SConsign -import SCons.Sig - -try: - SConsignEntry = SCons.Sig.SConsignEntry -except AttributeError: - class SConsignEntry: - timestamp = None - bsig = None - csig = None - implicit = None - -filename = sys.argv[1] - -db = SCons.dblite.open(filename, "r") - -old_db = {} -for dir in db.keys(): - #self.printentries(dir, db[dir]) - - new_entries = cPickle.loads(db[dir]) - old_db[dir] = old_entries = {} - for name, entry in new_entries.items(): - oe = SConsignEntry() - for attr in ['timestamp', 'bsig', 'csig', 'implicit']: - try: setattr(oe, attr, getattr(entry, attr)) - except AttributeError: pass - old_entries[name] = oe - -db = SCons.dblite.open(filename, "c") -for key, val in old_db.items(): - db[key] = cPickle.dumps(val) -db.sync() -""") - - - -# Now generate a simple .sconsign file for a simple build. -test.write(['src1', 'SConstruct'], """\ -SConsignFile(None) -import os -def cat(env, source, target): - target = str(target[0]) - source = map(str, source) - f = open(target, "wb") - for src in source: - f.write(open(src, "rb").read()) - f.close() - -env = Environment() -env.Append(BUILDERS={'Cat':Builder(action=cat)}) - -Export("env") -SConscript('SConscript') -""") - -test.write(['src1', 'SConscript'], """\ -Import("env") -env.Cat('file1', 'file1.in') -env.Cat('subdir/file2', 'subdir/file2.in') -""") - -test.write(['src1', 'file1.in'], "file1.in 1\n") -test.write(['src1', 'subdir', 'file2.in'], "subdir/file2.in 1\n") - -test.run(chdir='src1', arguments='.') - -test.up_to_date(chdir='src1', arguments='.') - -sconsign_list = [ - test.workpath('src1', '.sconsign'), - test.workpath('src1', 'subdir', '.sconsign'), -] - -for sconsign in sconsign_list: - test.run(interpreter=python, program=convert, arguments=sconsign) - -test.up_to_date(chdir='src1', arguments='.') - - - -# Now do the same with SConsignFile(). -test.write(['src2', 'SConstruct'], """\ -import os -def cat(env, source, target): - target = str(target[0]) - source = map(str, source) - f = open(target, "wb") - for src in source: - f.write(open(src, "rb").read()) - f.close() - -env = Environment() -env.Append(BUILDERS={'Cat':Builder(action=cat)}) -env.Cat('file1', 'file1.in') -env.Cat('subdir/file2', 'subdir/file2.in') -""") - -test.write(['src2', 'file1.in'], "file1.in 1\n") -test.write(['src2', 'subdir', 'file2.in'], "subdir/file2.in 1\n") - -test.run(chdir='src2', arguments='.') - -test.up_to_date(chdir='src2', arguments='.') - -sconsign_list = [ - test.workpath('src2', '.sconsign'), -] - -for sconsign in sconsign_list: - test.run(interpreter=python, program=convert_dblite, arguments=sconsign) - -test.up_to_date(chdir='src2', arguments='.') - - - -test.pass_test() diff --git a/test/sconsign/script.py b/test/sconsign/script.py index 9758d5a..2c54e40 100644 --- a/test/sconsign/script.py +++ b/test/sconsign/script.py @@ -115,24 +115,26 @@ test.run(chdir = 'work1', arguments = '--debug=stacktrace --implicit-cache .') test.run_sconsign(arguments = "work1/sub1/.sconsign", stdout = """\ -hello.exe: None \S+ None +hello.exe: \S+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ """) test.run_sconsign(arguments = "-v work1/sub1/.sconsign", stdout = """\ hello.exe: - timestamp: None bsig: \S+ csig: None + timestamp: \d+ + size: \d+ implicit: hello.obj: \S+ hello.obj: - timestamp: None bsig: \S+ csig: None + timestamp: \d+ + size: \d+ implicit: hello.c: \S+ """) @@ -153,19 +155,35 @@ hello.obj: csig: None """) +test.run_sconsign(arguments = "-s -v work1/sub1/.sconsign", + stdout = """\ +hello.exe: + size: \d+ +hello.obj: + size: \d+ +""") + +test.run_sconsign(arguments = "-t -v work1/sub1/.sconsign", + stdout = """\ +hello.exe: + timestamp: \d+ +hello.obj: + timestamp: \d+ +""") + test.run_sconsign(arguments = "-e hello.obj work1/sub1/.sconsign", stdout = """\ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ """) test.run_sconsign(arguments = "-e hello.obj -e hello.exe -e hello.obj work1/sub1/.sconsign", stdout = """\ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ -hello.exe: None \S+ None +hello.exe: \S+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ """) @@ -175,33 +193,33 @@ sub2_inc2_h = re_sep('sub2', 'inc2.h') test.run_sconsign(arguments = "work1/sub2/.sconsign", stdout = """\ -hello.exe: None \S+ None +hello.exe: \S+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ inc1.h: \S+ inc2.h: \S+ """) -test.run_sconsign(arguments = "-i -v work1/sub2/.sconsign", - stdout = """\ -hello.exe: - implicit: - hello.obj: \S+ -hello.obj: - implicit: - hello.c: \S+ - inc1.h: \S+ - inc2.h: \S+ -""") +#test.run_sconsign(arguments = "-i -v work1/sub2/.sconsign", +# stdout = """\ +#hello.exe: +# implicit: +# hello.obj: \S+ None \d+ \d+ +#hello.obj: +# implicit: +# hello.c: None \S+ \d+ \d+ +# inc1.h: None \S+ \d+ \d+ +# inc2.h: None \S+ \d+ \d+ +#""") test.run_sconsign(arguments = "-e hello.obj work1/sub2/.sconsign work1/sub1/.sconsign", stdout = """\ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ inc1.h: \S+ inc2.h: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ """) @@ -222,17 +240,17 @@ test.run(chdir = 'work1', arguments = '. --max-drift=1 --debug=stacktrace') test.run_sconsign(arguments = "-e hello.exe -e hello.obj work1/sub1/.sconsign", stdout = """\ -hello.exe: None \S+ None +hello.exe: \S+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ """) test.run_sconsign(arguments = "-e hello.exe -e hello.obj -r work1/sub1/.sconsign", stdout = """\ -hello.exe: None \S+ None +hello.exe: \S+ None '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' \d+ hello.c: \S+ """) @@ -284,14 +302,14 @@ test.run_sconsign(arguments = "work2/.sconsign") test.run_sconsign(arguments = "work2/.sconsign", stdout = """\ === sub1: -hello.exe: None \S+ None +hello.exe: \S+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ === sub2: -hello.exe: None \S+ None +hello.exe: \S+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ inc1.h: \S+ inc2.h: \S+ @@ -301,28 +319,32 @@ test.run_sconsign(arguments = "-v work2/.sconsign", stdout = """\ === sub1: hello.exe: - timestamp: None bsig: \S+ csig: None + timestamp: \d+ + size: \d+ implicit: hello.obj: \S+ hello.obj: - timestamp: None bsig: \S+ csig: None + timestamp: \d+ + size: \d+ implicit: hello.c: \S+ === sub2: hello.exe: - timestamp: None bsig: \S+ csig: None + timestamp: \d+ + size: \d+ implicit: hello.obj: \S+ hello.obj: - timestamp: None bsig: \S+ csig: None + timestamp: \d+ + size: \d+ implicit: hello.c: \S+ inc1.h: \S+ @@ -357,13 +379,41 @@ hello.obj: csig: None """) +test.run_sconsign(arguments = "-s -v work2/.sconsign", + stdout = """\ +=== sub1: +hello.exe: + size: \d+ +hello.obj: + size: \d+ +=== sub2: +hello.exe: + size: \d+ +hello.obj: + size: \d+ +""") + +test.run_sconsign(arguments = "-t -v work2/.sconsign", + stdout = """\ +=== sub1: +hello.exe: + timestamp: \d+ +hello.obj: + timestamp: \d+ +=== sub2: +hello.exe: + timestamp: \d+ +hello.obj: + timestamp: \d+ +""") + test.run_sconsign(arguments = "-e hello.obj work2/.sconsign", stdout = """\ === sub1: -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ === sub2: -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ inc1.h: \S+ inc2.h: \S+ @@ -372,44 +422,44 @@ hello.obj: None \S+ None test.run_sconsign(arguments = "-e hello.obj -e hello.exe -e hello.obj work2/.sconsign", stdout = """\ === sub1: -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ -hello.exe: None \S+ None +hello.exe: \S+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ === sub2: -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ inc1.h: \S+ inc2.h: \S+ -hello.exe: None \S+ None +hello.exe: \S+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \S+ None \d+ \d+ hello.c: \S+ inc1.h: \S+ inc2.h: \S+ """) -test.run_sconsign(arguments = "-i -v work2/.sconsign", - stdout = """\ -=== sub1: -hello.exe: - implicit: - hello.obj: \S+ -hello.obj: - implicit: - hello.c: \S+ -=== sub2: -hello.exe: - implicit: - hello.obj: \S+ -hello.obj: - implicit: - hello.c: \S+ - inc1.h: \S+ - inc2.h: \S+ -""") +#test.run_sconsign(arguments = "-i -v work2/.sconsign", +# stdout = """\ +#=== sub1: +#hello.exe: +# implicit: +# hello.obj: \S+ +#hello.obj: +# implicit: +# hello.c: \S+ +#=== sub2: +#hello.exe: +# implicit: +# hello.obj: \S+ +#hello.obj: +# implicit: +# hello.c: \S+ +# inc1.h: \S+ +# inc2.h: \S+ +#""") test.run(chdir = 'work2', arguments = '--clean .') @@ -429,65 +479,65 @@ test.run(chdir = 'work2', arguments = '. --max-drift=1') expect = """\ === sub1: -hello.c: \d+ None \d+ +hello.c: None \S+ \d+ \d+ """ test.run_sconsign(arguments = "-e hello.exe -e hello.obj -d sub1 -f dblite work2/my_sconsign", stdout = """\ === sub1: -hello.exe: None \S+ None - hello.obj: \S+ -hello.obj: None \S+ None - hello.c: \S+ +hello.exe: \d+ None \d+ \d+ + hello.obj: \d+ +hello.obj: \d+ None \d+ \d+ + hello.c: \d+ """) test.run_sconsign(arguments = "-e hello.exe -e hello.obj -d sub1 -f dblite work2/my_sconsign.dblite", stdout = """\ === sub1: -hello.exe: None \S+ None +hello.exe: \d+ None \d+ \d+ hello.obj: \S+ -hello.obj: None \S+ None +hello.obj: \d+ None \d+ \d+ hello.c: \S+ """) test.run_sconsign(arguments = "-e hello.c -e hello.exe -e hello.obj -d sub1 -f dblite work2/my_sconsign", stdout = """\ === sub1: -hello.c: \d+ None \d+ -hello.exe: None \S+ None - hello.obj: \S+ -hello.obj: None \S+ None - hello.c: \S+ +hello.c: None \d+ \d+ \d+ +hello.exe: \d+ None \d+ \d+ + hello.obj: \d+ +hello.obj: \d+ None \d+ \d+ + hello.c: \d+ """) test.run_sconsign(arguments = "-e hello.c -e hello.exe -e hello.obj -d sub1 -f dblite work2/my_sconsign.dblite", stdout = """\ === sub1: -hello.c: \d+ None \d+ -hello.exe: None \S+ None - hello.obj: \S+ -hello.obj: None \S+ None - hello.c: \S+ +hello.c: None \d+ \d+ \d+ +hello.exe: \S+ None \d+ \d+ + hello.obj: \d+ +hello.obj: \S+ None \d+ \d+ + hello.c: \d+ """) test.run_sconsign(arguments = "-e hello.c -e hello.exe -e hello.obj -r -d sub1 -f dblite work2/my_sconsign", stdout = """\ === sub1: -hello.c: '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' None \d+ -hello.exe: None \S+ None - hello.obj: \S+ -hello.obj: None \S+ None - hello.c: \S+ +hello.c: None \d+ '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' \d+ +hello.exe: \d+ None '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' \d+ + hello.obj: \d+ +hello.obj: \d+ None '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' \d+ + hello.c: \d+ """) test.run_sconsign(arguments = "-e hello.c -e hello.exe -e hello.obj -r -d sub1 -f dblite work2/my_sconsign.dblite", stdout = """\ === sub1: -hello.c: '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' None \d+ -hello.exe: None \S+ None - hello.obj: \S+ -hello.obj: None \S+ None - hello.c: \S+ +hello.c: None \d+ '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' \d+ +hello.exe: \d+ None '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' \d+ + hello.obj: \d+ +hello.obj: \d+ None '\S+ \S+ [ \d]\d \d\d:\d\d:\d\d \d\d\d\d' \d+ + hello.c: \d+ """) ############################################################################## |