[Zope3-checkins] CVS: Zope3/lib/python/Zope/Server/VFS/tests - testOSFileSystem.py:1.3

Stephan Richter srichter@cbu.edu
Fri, 20 Dec 2002 04:25:47 -0500


Update of /cvs-repository/Zope3/lib/python/Zope/Server/VFS/tests
In directory cvs.zope.org:/tmp/cvs-serv31450/Zope/Server/VFS/tests

Modified Files:
	testOSFileSystem.py 
Log Message:
Refactoring and fixing VFS and FTP

I am glad to make this commit that fixes up a lot of the FTP
implementation. I fixed the behavior of many of the FTP commands,
including LIST, SIZE, and CWD.

I moved the original VFSFile/DirectoryView into abstract classes and wrote
a special implementation for each content type, which makes the code much
more flexible.

Also I finally implemented a smart way of adding files via VFS through
file extension introspection, based on Jim's ExtensionViewName proposal.

I am adding documentation in the DevelCookbook right now and will later
add a README file.

TODOs:

- make VFS View names flexible, so that file extensions specify views.

- Simplify ZCML directives, so that one can add new extensions for Add views
  quicker. A solution might look like that:

      <vfs:view
          name=".dtml"
          for="Zope.App.OFS.Container.IAdding."
          factory=".DTMLPageAdd."
          permission="Zope.ManageContent">
        <vfs:extension name=".html" />
        <vfs:extension name=".xul" /> 
        <vfs:extension name=".xml" /> 
        ...
      </vfs:view>
			   
  This method would also be good for defining a default fiel extension.

- Show an object with its default file extension.
								     


=== Zope3/lib/python/Zope/Server/VFS/tests/testOSFileSystem.py 1.2 => 1.3 ===
--- Zope3/lib/python/Zope/Server/VFS/tests/testOSFileSystem.py:1.2	Mon Jun 10 19:29:37 2002
+++ Zope3/lib/python/Zope/Server/VFS/tests/testOSFileSystem.py	Fri Dec 20 04:25:46 2002
@@ -15,12 +15,13 @@
 
 $Id$
 """
-
-
 import unittest
 import os
 import shutil
 import tempfile
+import datetime
+fromts = datetime.datetime.fromtimestamp
+
 from StringIO import StringIO
 
 from Zope.Server.VFS.OSFileSystem import OSFileSystem
@@ -95,6 +96,7 @@
 
     def testStat(self):
         stat = os.stat(joinToRoot(self.root, self.file_name))
+        stat = stat[0:6], fromts(stat[7]), fromts(stat[8]), fromts(stat[9]) 
         self.assertEqual(self.filesystem.stat(self.file_name), stat)