Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(486)

Side by Side Diff: chrome/common/extensions/docs/server2/test_file_system.py

Issue 12996003: Dynamically generate a heading for Extension Docs API pages (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressing comments - Patch currently being broken up Created 7 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 # Copyright 2013 The Chromium Authors. All rights reserved. 1 # Copyright 2013 The Chromium Authors. All rights reserved.
2 # 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
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 from file_system import FileSystem, FileNotFoundError, StatInfo 5 from file_system import FileSystem, FileNotFoundError, StatInfo
6 from future import Future 6 from future import Future
7 7
8 class TestFileSystem(FileSystem): 8 class TestFileSystem(FileSystem):
9 '''A FileSystem backed by an object. Create with an object representing file 9 '''A FileSystem backed by an object. Create with an object representing file
10 paths such that {'a': {'b': 'hello'}} will resolve Read('a/b') as 'hello', 10 paths such that {'a': {'b': 'hello'}} will resolve Read('a/b') as 'hello',
11 Read('a/') as ['b'], and Stat determined by a value incremented via 11 Read('a/') as ['b'], and Stat determined by a value incremented via
12 IncrementStat. 12 IncrementStat.
13 ''' 13 '''
14 14
15 # TODO(kalman): this method would be unnecessary if we injected paths properly 15 # TODO(kalman): this method would be unnecessary if we injected paths properly
16 # in ServerInstance. 16 # in ServerInstance.
17 @staticmethod 17 @staticmethod
18 def MoveTo(base, obj): 18 def MoveTo(base, obj):
19 '''Returns an object as |obj| moved to |prefix|. That is, 19 '''Returns an object as |obj| moved to |base|. That is,
20 MoveTo('foo/bar', {'a': 'b'}) -> {'foo': {'bar': {'a': 'b'}}} 20 MoveTo('foo/bar', {'a': 'b'}) -> {'foo': {'bar': {'a': 'b'}}}
21 ''' 21 '''
22 result = {} 22 result = {}
23 leaf = result 23 leaf = result
24 for k in base.split('/'): 24 for k in base.split('/'):
25 leaf[k] = {} 25 leaf[k] = {}
26 leaf = leaf[k] 26 leaf = leaf[k]
27 leaf.update(obj) 27 leaf.update(obj)
28 return result 28 return result
29 29
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after
108 # 108 #
109 109
110 def IncrementStat(self, path=None): 110 def IncrementStat(self, path=None):
111 if path is not None: 111 if path is not None:
112 self._path_stats[path] = self._path_stats.get(path, 0) + 1 112 self._path_stats[path] = self._path_stats.get(path, 0) + 1
113 else: 113 else:
114 self._global_stat += 1 114 self._global_stat += 1
115 115
116 def GetIdentity(self): 116 def GetIdentity(self):
117 return self.__class__.__name__ 117 return self.__class__.__name__
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698