summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteven Knight <knight@baldmt.com>2006-02-27 06:09:15 (GMT)
committerSteven Knight <knight@baldmt.com>2006-02-27 06:09:15 (GMT)
commit6deacf2c5357261c935ade714bf5ec00aff8b358 (patch)
tree844bc90158f6f576887cd2da60813130e9a1a749
parentc32fd05c5b00b7658c8459c54bb7df37fd890284 (diff)
downloadSCons-6deacf2c5357261c935ade714bf5ec00aff8b358.zip
SCons-6deacf2c5357261c935ade714bf5ec00aff8b358.tar.gz
SCons-6deacf2c5357261c935ade714bf5ec00aff8b358.tar.bz2
Check in a new TestCmd.py with chmod() and touch() methods.
-rw-r--r--etc/TestCmd.py48
-rw-r--r--etc/TestCommon.py8
2 files changed, 32 insertions, 24 deletions
diff --git a/etc/TestCmd.py b/etc/TestCmd.py
index c3d438c..9b3e7a2 100644
--- a/etc/TestCmd.py
+++ b/etc/TestCmd.py
@@ -176,8 +176,8 @@ version.
# SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
__author__ = "Steven Knight <knight at baldmt dot com>"
-__revision__ = "TestCmd.py 0.21.D001 2006/02/21 21:18:43 knight"
-__version__ = "0.21"
+__revision__ = "TestCmd.py 0.22.D001 2006/02/26 15:45:18 knight"
+__version__ = "0.22"
import os
import os.path
@@ -499,6 +499,13 @@ class TestCmd:
arg = '"' + arg + '"'
return arg
+ def canonicalize(self, path):
+ if is_List(path):
+ path = apply(os.path.join, tuple(path))
+ if not os.path.isabs(path):
+ path = os.path.join(self.workdir, path)
+ return path
+
def cleanup(self, condition = None):
"""Removes any temporary working directories for the specified
TestCmd environment. If the environment variable PRESERVE was
@@ -537,6 +544,12 @@ class TestCmd:
except (AttributeError, ValueError):
pass
+ def chmod(self, path, mode):
+ """Changes permissions on the specified file or directory
+ path name."""
+ path = self.canonicalize(path)
+ os.chmod(path, mode)
+
def description_set(self, description):
"""Set the description of the functionality being tested.
"""
@@ -630,10 +643,7 @@ class TestCmd:
be specified; it must begin with an 'r'. The default is
'rb' (binary read).
"""
- if is_List(file):
- file = apply(os.path.join, tuple(file))
- if not os.path.isabs(file):
- file = os.path.join(self.workdir, file)
+ file = self.canonicalize(file)
if mode[0] != 'r':
raise ValueError, "mode must begin with 'r'"
return open(file, mode).read()
@@ -806,12 +816,20 @@ class TestCmd:
is an absolute path name. The target is *not* assumed to be
under the temporary working directory.
"""
- if is_List(link):
- link = apply(os.path.join, tuple(link))
- if not os.path.isabs(link):
- link = os.path.join(self.workdir, link)
+ link = self.canonicalize(link)
os.symlink(target, link)
+ def touch(self, path, mtime=None):
+ """Updates the modification time on the specified file or
+ directory path name. The default is to update to the
+ current time if no explicit modification time is specified.
+ """
+ path = self.canonicalize(path)
+ atime = os.path.getatime(path)
+ if mtime is None:
+ mtime = time.time()
+ os.utime(path, (atime, mtime))
+
def unlink(self, file):
"""Unlinks the specified file name.
The file name may be a list, in which case the elements are
@@ -819,10 +837,7 @@ class TestCmd:
assumed to be under the temporary working directory unless it
is an absolute path name.
"""
- if is_List(file):
- file = apply(os.path.join, tuple(file))
- if not os.path.isabs(file):
- file = os.path.join(self.workdir, file)
+ file = self.canonicalize(file)
os.unlink(file)
def verbose_set(self, verbose):
@@ -1009,10 +1024,7 @@ class TestCmd:
exist. The I/O mode for the file may be specified; it must
begin with a 'w'. The default is 'wb' (binary write).
"""
- if is_List(file):
- file = apply(os.path.join, tuple(file))
- if not os.path.isabs(file):
- file = os.path.join(self.workdir, file)
+ file = self.canonicalize(file)
if mode[0] != 'w':
raise ValueError, "mode must begin with 'w'"
open(file, mode).write(content)
diff --git a/etc/TestCommon.py b/etc/TestCommon.py
index 008cf5a..b30b75c 100644
--- a/etc/TestCommon.py
+++ b/etc/TestCommon.py
@@ -80,8 +80,8 @@ The TestCommon module also provides the following variables
# SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
__author__ = "Steven Knight <knight at baldmt dot com>"
-__revision__ = "TestCommon.py 0.21.D001 2006/02/21 21:18:43 knight"
-__version__ = "0.21"
+__revision__ = "TestCommon.py 0.22.D001 2006/02/26 15:45:18 knight"
+__version__ = "0.22"
import os
import os.path
@@ -231,10 +231,6 @@ class TestCommon(TestCmd):
# $test->subdir('subdir', ...);
#
# $test->copy('src_file', 'dst_file');
- #
- # $test->chmod($mode, 'file', ...);
- #
- # $test->touch('file', ...);
def __init__(self, **kw):
"""Initialize a new TestCommon instance. This involves just