~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/stub_sftp.py

  • Committer: Robert Collins
  • Date: 2009-07-07 04:32:13 UTC
  • mto: This revision was merged to the branch mainline in revision 4524.
  • Revision ID: robertc@robertcollins.net-20090707043213-4hjjhgr40iq7gk2d
More informative assertions in xml serialisation.

Show diffs side-by-side

added added

removed removed

Lines of Context:
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
17
"""
18
18
A stub SFTP server for loopback SFTP testing.
71
71
        if home is None:
72
72
            self.home = ''
73
73
        else:
74
 
            assert home.startswith(self.root), \
75
 
                    "home must be a subdirectory of root (%s vs %s)" \
76
 
                    % (home, root)
 
74
            if not home.startswith(self.root):
 
75
                raise AssertionError(
 
76
                    "home must be a subdirectory of root (%s vs %s)"
 
77
                    % (home, root))
77
78
            self.home = home[len(self.root):]
78
79
        if self.home.startswith('/'):
79
80
            self.home = self.home[1:]
82
83
    def _realpath(self, path):
83
84
        # paths returned from self.canonicalize() always start with
84
85
        # a path separator. So if 'root' is just '/', this would cause
85
 
        # a double slash at the beginning '//home/dir'. 
 
86
        # a double slash at the beginning '//home/dir'.
86
87
        if self.root == '/':
87
88
            return self.canonicalize(path)
88
89
        return self.root + self.canonicalize(path)
95
96
            #     /h:/foo/bar
96
97
            # and relative paths stay the same:
97
98
            #     foo/bar
98
 
            # win32 needs to use the Unicode APIs. so we require the 
 
99
            # win32 needs to use the Unicode APIs. so we require the
99
100
            # paths to be utf8 (Linux just uses bytestreams)
100
101
            thispath = path.decode('utf8')
101
102
            if path.startswith('/'):
123
124
            out = [ ]
124
125
            # TODO: win32 incorrectly lists paths with non-ascii if path is not
125
126
            # unicode. However on Linux the server should only deal with
126
 
            # bytestreams and posix.listdir does the right thing 
 
127
            # bytestreams and posix.listdir does the right thing
127
128
            if sys.platform == 'win32':
128
129
                flist = [f.encode('utf8') for f in os.listdir(path)]
129
130
            else: