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

Side by Side Diff: chrome/common/extensions/docs/server2/availability_data_source_test.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: Moving logic into availability_data_source Created 7 years, 8 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
(Empty)
1 #!/usr/bin/env python
2 # Copyright (c) 2013 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file.
5
6 import json
7 import os
8 import unittest
9
10 from availability_data_source import AvailabilityDataSource
11 from caching_file_system import CachingFileSystem
12 from object_store_creator import ObjectStoreCreator
13 from test_file_system import TestFileSystem
14
15 _TEST_DIR = 'test_data/availability_data_source/'
16
17 def _LoadJson(name, mode='rb'):
18 with open(os.path.join(_TEST_DIR, name), mode) as f:
19 return json.load(f)
20
21 def _CreateTestFileSystemForBranch(branch):
22 file_system_json = _LoadJson('test_avail_file_system.json')
23 test_file_system = CachingFileSystem(TestFileSystem(file_system_json[branch]),
24 ObjectStoreCreator.Factory())
25 return test_file_system
26
27 class _FakeChromeVersionDataSource(object):
28 def GetLatestVersionNumber(self):
29 return '27'
30
31 def GetBranchNumberForVersion(self, version_number):
32 branch_dict_json = _LoadJson('test_avail_branch_list.json')
33 branch_number = branch_dict_json[version_number]
34 return branch_number
35
36 class AvailabilityDataSourceTest(unittest.TestCase):
37 def setUp(self):
38 self._availability_ds_factory = AvailabilityDataSource.Factory(
39 _FakeChromeVersionDataSource())
40 self._availability_ds_factory._existing_availabilities = {'fake' : 'beta'}
41 self._availability_ds = self._availability_ds_factory.Create()
42 (self._availability_ds.
43 _CreateSvnFileSystemForBranch) = _CreateTestFileSystemForBranch
44
45 def testCheckExistence(self):
46 self.assertEquals(False,
47 self._availability_ds._CheckApiExistence('gobbledigook', '23'))
48 self.assertEquals(True,
49 self._availability_ds._CheckApiExistence('alarms', '22'))
50 self.assertEquals(True,
51 self._availability_ds._CheckApiExistence('alarms', '21'))
52 self.assertEquals(False,
53 self._availability_ds._CheckApiExistence('alarms', '20'))
54 self.assertEquals(True,
55 self._availability_ds._CheckApiExistence('tabs', '18'))
56 self.assertEquals(False,
57 self._availability_ds._CheckApiExistence('tabs', '17'))
58
59 def testFindEarliestAvailability(self):
60 self.assertEquals('beta',
61 self._availability_ds.FindEarliestAvailability('fake'))
62 self.assertEquals(None,
63 self._availability_ds.FindEarliestAvailability('gobblediegook'))
64 self.assertEquals('21',
65 self._availability_ds.FindEarliestAvailability('alarms'))
66 self.assertEquals('18',
67 self._availability_ds.FindEarliestAvailability('bookmarks'))
68 self.assertEquals('18',
69 self._availability_ds.FindEarliestAvailability('browserAction'))
70 self.assertEquals('18',
71 self._availability_ds.FindEarliestAvailability('contextMenus'))
72 self.assertEquals('18',
73 self._availability_ds.FindEarliestAvailability('cookies'))
74 self.assertEquals('21',
75 self._availability_ds.FindEarliestAvailability('fileSystem'))
76 self.assertEquals('24',
77 self._availability_ds.FindEarliestAvailability('pushMessaging'))
78 self.assertEquals('21',
79 self._availability_ds.FindEarliestAvailability('runtime'))
80 self.assertEquals('19',
81 self._availability_ds.FindEarliestAvailability('storage'))
82 self.assertEquals('18',
83 self._availability_ds.FindEarliestAvailability('tabs'))
84
85 if __name__ == '__main__':
86 unittest.main()
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698