Merged revisions 1675-1736 via svnmerge from
[scons.git] / test / scons-time / run / config / subdir.py
1 #!/usr/bin/env python
2 #
3 # __COPYRIGHT__
4 #
5 # Permission is hereby granted, free of charge, to any person obtaining
6 # a copy of this software and associated documentation files (the
7 # "Software"), to deal in the Software without restriction, including
8 # without limitation the rights to use, copy, modify, merge, publish,
9 # distribute, sublicense, and/or sell copies of the Software, and to
10 # permit persons to whom the Software is furnished to do so, subject to
11 # the following conditions:
12 #
13 # The above copyright notice and this permission notice shall be included
14 # in all copies or substantial portions of the Software.
15 #
16 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
17 # KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
18 # WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19 # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20 # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21 # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22 # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23 #
24
25 __revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__"
26
27 """
28 Verify picking up the subdir value from a config file.
29 """
30
31 import os
32 import re
33
34 import TestSCons_time
35
36 test = TestSCons_time.TestSCons_time()
37
38 test.write_fake_scons_py()
39
40 test.write_sample_project('foo.tar.gz', 'subdir')
41
42 test.write('config', """\
43 subdir = 'subdir'
44 """)
45
46 test.run(arguments = 'run -f config foo.tar.gz')
47
48 test.must_exist('foo-000-0.log',
49                 'foo-000-0.prof',
50                 'foo-000-1.log',
51                 'foo-000-1.prof',
52                 'foo-000-2.log',
53                 'foo-000-2.prof')
54
55 content = test.read(test.workpath('foo-000-0.log'), mode='r')
56
57 expect = [
58     'SConstruct file directory: .*%ssubdir$' % re.escape(os.sep),
59 ]
60
61 test.must_contain_all_lines('foo-000-0.log', content, expect, re.search)
62
63 test.pass_test()