summaryrefslogtreecommitdiff
path: root/rdiff-backup/testing/robusttest.py
diff options
context:
space:
mode:
authorben <ben@2b77aa54-bcbc-44c9-a7ec-4f6cf2b41109>2002-03-21 07:22:43 +0000
committerben <ben@2b77aa54-bcbc-44c9-a7ec-4f6cf2b41109>2002-03-21 07:22:43 +0000
commit8c37a5bdfdd46d5cfad6e9d67925ddef9ca382bf (patch)
tree8f19be83962ef31d8ad58429d575c6f17d89c0ea /rdiff-backup/testing/robusttest.py
parent8259a0d8a9ad1396a93cd6320943dc33446ac6ed (diff)
downloadrdiff-backup-8c37a5bdfdd46d5cfad6e9d67925ddef9ca382bf.tar.gz
First checkin
git-svn-id: http://svn.savannah.nongnu.org/svn/rdiff-backup/trunk@2 2b77aa54-bcbc-44c9-a7ec-4f6cf2b41109
Diffstat (limited to 'rdiff-backup/testing/robusttest.py')
-rw-r--r--rdiff-backup/testing/robusttest.py86
1 files changed, 86 insertions, 0 deletions
diff --git a/rdiff-backup/testing/robusttest.py b/rdiff-backup/testing/robusttest.py
new file mode 100644
index 0000000..4f08e44
--- /dev/null
+++ b/rdiff-backup/testing/robusttest.py
@@ -0,0 +1,86 @@
+import os, unittest
+
+execfile("commontest.py")
+rbexec("setconnections.py")
+
+class TestRobustAction(unittest.TestCase):
+ """Test some robust actions"""
+ def testCopyWithAttribs(self):
+ """Test copy with attribs action"""
+ rpin = RPath(Globals.local_connection, "./testfiles/robust/in")
+ fp = open("./testfiles/robust/in", "wb")
+ fp.write("hello there")
+ fp.close()
+ os.chmod("./testfiles/robust/in", 0604)
+ rpin.setdata()
+ assert rpin.isreg() and rpin.getperms() % 01000 == 0604
+
+ rpout = RPath(Globals.local_connection, "./testfiles/robust/out")
+ Robust.copy_with_attribs_action(rpin, rpout).execute()
+ if not rpout == rpin:
+ print rpout, rpin
+ assert 0
+
+ rpout.delete()
+ rpin.delete()
+
+
+class TempFileTest(unittest.TestCase):
+ """Test creation and management of tempfiles"""
+ rp_base = RPath(Globals.local_connection,
+ "./testfiles/robust/testfile_base")
+ def testBasic(self):
+ """Make a temp file, write to it, and then delete it
+
+ Also test tempfile accounting and file name prefixing.
+
+ """
+ assert not TempFileManager._tempfiles
+ tf = TempFileManager.new(self.rp_base)
+ assert TempFileManager._tempfiles == [tf]
+ assert tf.dirsplit()[0] == "testfiles/robust", tf.dirsplit()[0]
+ assert not tf.lstat()
+ fp = tf.open("w")
+ fp.write("hello")
+ assert not fp.close()
+ fp = tf.open("r")
+ assert fp.read() == "hello"
+ assert not fp.close()
+ tf.delete()
+ assert not TempFileManager._tempfiles
+
+ def testRename(self):
+ """Test renaming of tempfile"""
+ tf = TempFileManager.new(self.rp_base)
+ assert TempFileManager._tempfiles
+ tf.touch()
+ destination = RPath(Globals.local_connection,
+ "./testfiles/robust/testfile_dest")
+ tf.rename(destination)
+ assert not TempFileManager._tempfiles
+ assert destination.lstat()
+ destination.delete()
+
+
+class SaveStateTest(unittest.TestCase):
+ """Test SaveState class"""
+ data_dir = RPath(Globals.local_connection, "testfiles/robust")
+ def testSymlinking(self):
+ """Test recording last file with symlink"""
+ last_rorp = RORPath(('usr', 'local', 'bin', 'ls'))
+ Globals.rbdir = self.data_dir
+ Time.setcurtime()
+ SetConnections.BackupInitConnections(Globals.local_connection,
+ Globals.local_connection)
+ SaveState.init_filenames(None)
+ SaveState.record_last_file_action(last_rorp).execute()
+
+ sym_rp = RPath(Globals.local_connection,
+ "testfiles/robust/last-file-mirrored.%s.snapshot" %
+ Time.curtimestr)
+ assert sym_rp.issym()
+ assert sym_rp.readlink() == "increments/usr/local/bin/ls"
+ sym_rp.delete()
+
+
+if __name__ == '__main__': unittest.main()