OLD | NEW |
1 #!/usr/bin/python | |
2 # Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 # Copyright (c) 2011 The Chromium Authors. All rights reserved. |
3 # Use of this source code is governed by a BSD-style license that can be | 2 # Use of this source code is governed by a BSD-style license that can be |
4 # found in the LICENSE file. | 3 # found in the LICENSE file. |
5 | 4 |
6 import errno | 5 import errno |
7 import os | 6 import os |
8 import re | 7 import re |
9 import StringIO | 8 import StringIO |
10 | 9 |
| 10 |
11 def _RaiseNotFound(path): | 11 def _RaiseNotFound(path): |
12 raise IOError(errno.ENOENT, path, os.strerror(errno.ENOENT)) | 12 raise IOError(errno.ENOENT, path, os.strerror(errno.ENOENT)) |
13 | 13 |
14 | 14 |
15 class MockFileSystem(object): | 15 class MockFileSystem(object): |
16 """Stripped-down version of WebKit's webkitpy.common.system.filesystem_mock | 16 """Stripped-down version of WebKit's webkitpy.common.system.filesystem_mock |
17 | 17 |
18 Implements a filesystem-like interface on top of a dict of filenames -> | 18 Implements a filesystem-like interface on top of a dict of filenames -> |
19 file contents. A file content value of None indicates that the file should | 19 file contents. A file content value of None indicates that the file should |
20 not exist (IOError will be raised if it is opened; | 20 not exist (IOError will be raised if it is opened; |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
66 return re.sub(re.escape(os.path.sep), self.sep, os.path.join(*comps)) | 66 return re.sub(re.escape(os.path.sep), self.sep, os.path.join(*comps)) |
67 | 67 |
68 def open_for_reading(self, path): | 68 def open_for_reading(self, path): |
69 return StringIO.StringIO(self.read_binary_file(path)) | 69 return StringIO.StringIO(self.read_binary_file(path)) |
70 | 70 |
71 def read_binary_file(self, path): | 71 def read_binary_file(self, path): |
72 # Intentionally raises KeyError if we don't recognize the path. | 72 # Intentionally raises KeyError if we don't recognize the path. |
73 if self.files[path] is None: | 73 if self.files[path] is None: |
74 _RaiseNotFound(path) | 74 _RaiseNotFound(path) |
75 return self.files[path] | 75 return self.files[path] |
OLD | NEW |