Index: chrome/common/extensions/docs/server2/reference_resolver_test.py |
diff --git a/chrome/common/extensions/docs/server2/reference_resolver_test.py b/chrome/common/extensions/docs/server2/reference_resolver_test.py |
index ce46ef4a99d5a3ef30a02ab775ff8876c56d3602..fcb8842c697ecef14b1cf30578a9d9f761d4747b 100755 |
--- a/chrome/common/extensions/docs/server2/reference_resolver_test.py |
+++ b/chrome/common/extensions/docs/server2/reference_resolver_test.py |
@@ -9,12 +9,13 @@ import sys |
import unittest |
from file_system import FileNotFoundError |
+from future import Future |
from reference_resolver import ReferenceResolver |
from test_object_store import TestObjectStore |
from test_util import Server2Path |
-class FakeAPIDataSource(object): |
+class _FakeAPIDataSource(object): |
def __init__(self, json_data): |
self._json = json_data |
@@ -25,15 +26,23 @@ class FakeAPIDataSource(object): |
return self._json[key] |
-class FakeAPIModels(object): |
+class _FakeNamespace(object): |
+ def __init__(self): |
+ self.documentation_options = {} |
+ |
+ |
+class _FakeAPIModels(object): |
def __init__(self, names): |
self._names = names |
def GetNames(self): |
return self._names |
+ def GetModel(self, name): |
+ return Future(value=_FakeNamespace()) |
+ |
-class APIDataSourceTest(unittest.TestCase): |
+class ReferenceResolverTest(unittest.TestCase): |
def setUp(self): |
self._base_path = Server2Path('test_data', 'test_json') |
@@ -43,86 +52,86 @@ class APIDataSourceTest(unittest.TestCase): |
def testGetLink(self): |
test_data = json.loads(self._ReadLocalFile('fake_data_source.json')) |
- resolver = ReferenceResolver(FakeAPIDataSource(test_data), |
- FakeAPIModels(test_data.keys()), |
+ resolver = ReferenceResolver(_FakeAPIDataSource(test_data), |
+ _FakeAPIModels(test_data.keys()), |
TestObjectStore('test')) |
self.assertEqual({ |
- 'href': 'foo.html', |
+ 'href': 'foo', |
'text': 'foo', |
'name': 'foo' |
}, resolver.GetLink('foo', namespace='baz')) |
self.assertEqual({ |
- 'href': 'foo.html#type-foo_t1', |
+ 'href': 'foo#type-foo_t1', |
'text': 'foo.foo_t1', |
'name': 'foo_t1' |
}, resolver.GetLink('foo.foo_t1', namespace='baz')) |
self.assertEqual({ |
- 'href': 'baz.html#event-baz_e1', |
+ 'href': 'baz#event-baz_e1', |
'text': 'baz_e1', |
'name': 'baz_e1' |
}, resolver.GetLink('baz.baz_e1', namespace='baz')) |
self.assertEqual({ |
- 'href': 'baz.html#event-baz_e1', |
+ 'href': 'baz#event-baz_e1', |
'text': 'baz_e1', |
'name': 'baz_e1' |
}, resolver.GetLink('baz_e1', namespace='baz')) |
self.assertEqual({ |
- 'href': 'foo.html#method-foo_f1', |
+ 'href': 'foo#method-foo_f1', |
'text': 'foo.foo_f1', |
'name': 'foo_f1' |
}, resolver.GetLink('foo.foo_f1', namespace='baz')) |
self.assertEqual({ |
- 'href': 'foo.html#property-foo_p3', |
+ 'href': 'foo#property-foo_p3', |
'text': 'foo.foo_p3', |
'name': 'foo_p3' |
}, resolver.GetLink('foo.foo_p3', namespace='baz')) |
self.assertEqual({ |
- 'href': 'bar.bon.html#type-bar_bon_t3', |
+ 'href': 'bar.bon#type-bar_bon_t3', |
'text': 'bar.bon.bar_bon_t3', |
'name': 'bar_bon_t3' |
}, resolver.GetLink('bar.bon.bar_bon_t3', namespace='baz')) |
self.assertEqual({ |
- 'href': 'bar.bon.html#property-bar_bon_p3', |
+ 'href': 'bar.bon#property-bar_bon_p3', |
'text': 'bar_bon_p3', |
'name': 'bar_bon_p3' |
}, resolver.GetLink('bar_bon_p3', namespace='bar.bon')) |
self.assertEqual({ |
- 'href': 'bar.bon.html#property-bar_bon_p3', |
+ 'href': 'bar.bon#property-bar_bon_p3', |
'text': 'bar_bon_p3', |
'name': 'bar_bon_p3' |
}, resolver.GetLink('bar.bon.bar_bon_p3', namespace='bar.bon')) |
self.assertEqual({ |
- 'href': 'bar.html#event-bar_e2', |
+ 'href': 'bar#event-bar_e2', |
'text': 'bar_e2', |
'name': 'bar_e2' |
}, resolver.GetLink('bar.bar_e2', namespace='bar')) |
self.assertEqual({ |
- 'href': 'bar.html#type-bon', |
+ 'href': 'bar#type-bon', |
'text': 'bon', |
'name': 'bon' |
}, resolver.GetLink('bar.bon', namespace='bar')) |
self.assertEqual({ |
- 'href': 'foo.html#event-foo_t3-foo_t3_e1', |
+ 'href': 'foo#event-foo_t3-foo_t3_e1', |
'text': 'foo_t3.foo_t3_e1', |
'name': 'foo_t3_e1' |
}, resolver.GetLink('foo_t3.foo_t3_e1', namespace='foo')) |
self.assertEqual({ |
- 'href': 'foo.html#event-foo_t3-foo_t3_e1', |
+ 'href': 'foo#event-foo_t3-foo_t3_e1', |
'text': 'foo_t3.foo_t3_e1', |
'name': 'foo_t3_e1' |
}, resolver.GetLink('foo.foo_t3.foo_t3_e1', namespace='foo')) |
self.assertEqual({ |
- 'href': 'foo.html#event-foo_t3-foo_t3_e1', |
+ 'href': 'foo#event-foo_t3-foo_t3_e1', |
'text': 'foo_t3.foo_t3_e1', |
'name': 'foo_t3_e1' |
}, resolver.GetLink('foo.foo_p1.foo_t3_e1', namespace='foo')) |
self.assertEqual({ |
- 'href': 'bar.html#property-bar_t1-bar_t1_p1', |
+ 'href': 'bar#property-bar_t1-bar_t1_p1', |
'text': 'bar.bar_t1.bar_t1_p1', |
'name': 'bar_t1_p1' |
}, resolver.GetLink('bar.bar_p3.bar_t1_p1', namespace='foo')) |
self.assertEqual({ |
- 'href': 'bar.html#property-bar_t1-bar_t1_p1', |
+ 'href': 'bar#property-bar_t1-bar_t1_p1', |
'text': 'bar_t1.bar_t1_p1', |
'name': 'bar_t1_p1' |
}, resolver.GetLink('bar_p3.bar_t1_p1', namespace='bar')) |
@@ -142,72 +151,72 @@ class APIDataSourceTest(unittest.TestCase): |
None, |
resolver.GetLink('bar_p3', namespace='foo')) |
self.assertEqual( |
- 'Hello <a href="bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>, ' |
- '<a href="bar.bon.html#property-bar_bon_p3">Bon Bon</a>, ' |
- '<a href="bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>', |
+ 'Hello <a href="bar.bon#property-bar_bon_p3">bar_bon_p3</a>, ' |
+ '<a href="bar.bon#property-bar_bon_p3">Bon Bon</a>, ' |
+ '<a href="bar.bon#property-bar_bon_p3">bar_bon_p3</a>', |
resolver.ResolveAllLinks( |
'Hello $ref:bar_bon_p3, $ref:[bar_bon_p3 Bon Bon], $ref:bar_bon_p3', |
namespace='bar.bon')) |
self.assertEqual( |
- 'I like <a href="bar.html#property-bar_t1-bar_t1_p1">food</a>.', |
+ 'I like <a href="bar#property-bar_t1-bar_t1_p1">food</a>.', |
resolver.ResolveAllLinks('I like $ref:[bar.bar_p3.bar_t1_p1 food].', |
namespace='foo')) |
self.assertEqual( |
- 'Ref <a href="foo.html">It\'s foo!</a>', |
+ 'Ref <a href="foo">It\'s foo!</a>', |
resolver.ResolveAllLinks('Ref $ref:[foo It\'s foo!]', namespace='bar')) |
self.assertEqual( |
- 'Ref <a href="bar.html#type-bon">Bon</a>', |
+ 'Ref <a href="bar#type-bon">Bon</a>', |
resolver.ResolveAllLinks('Ref $ref:[bar.bon Bon]', namespace='bar')) |
# Different kinds of whitespace can be significant inside <pre> tags. |
self.assertEqual( |
- '<pre><a href="bar.html#type-bon">bar.bon</a>({\nkey: value})', |
+ '<pre><a href="bar#type-bon">bar.bon</a>({\nkey: value})', |
resolver.ResolveAllLinks('<pre>$ref:[bar.bon]({\nkey: value})', |
namespace='baz')) |
# Allow bare "$ref:foo.bar." at the end of a string. |
self.assertEqual( |
- '<a href="bar.html#type-bon">bar.bon</a>.', |
+ '<a href="bar#type-bon">bar.bon</a>.', |
resolver.ResolveAllLinks('$ref:bar.bon.', |
namespace='baz')) |
# If a request is provided it should construct an appropriate relative link. |
self.assertEqual( |
- 'Hi <a href="../../bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>, ' |
- '<a href="../../bar.bon.html#property-bar_bon_p3">Bon Bon</a>, ' |
- '<a href="../../bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>', |
+ 'Hi <a href="../../bar.bon#property-bar_bon_p3">bar_bon_p3</a>, ' |
+ '<a href="../../bar.bon#property-bar_bon_p3">Bon Bon</a>, ' |
+ '<a href="../../bar.bon#property-bar_bon_p3">bar_bon_p3</a>', |
resolver.ResolveAllLinks( |
'Hi $ref:bar_bon_p3, $ref:[bar_bon_p3 Bon Bon], $ref:bar_bon_p3', |
relative_to='big/long/path/bar.html', |
namespace='bar.bon')) |
self.assertEqual( |
- 'Hi <a href="bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>, ' |
- '<a href="bar.bon.html#property-bar_bon_p3">Bon Bon</a>, ' |
- '<a href="bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>', |
+ 'Hi <a href="bar.bon#property-bar_bon_p3">bar_bon_p3</a>, ' |
+ '<a href="bar.bon#property-bar_bon_p3">Bon Bon</a>, ' |
+ '<a href="bar.bon#property-bar_bon_p3">bar_bon_p3</a>', |
resolver.ResolveAllLinks( |
'Hi $ref:bar_bon_p3, $ref:[bar_bon_p3 Bon Bon], $ref:bar_bon_p3', |
relative_to='', |
namespace='bar.bon')) |
self.assertEqual( |
- 'Hi <a href="bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>, ' |
- '<a href="bar.bon.html#property-bar_bon_p3">Bon Bon</a>, ' |
- '<a href="bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>', |
+ 'Hi <a href="bar.bon#property-bar_bon_p3">bar_bon_p3</a>, ' |
+ '<a href="bar.bon#property-bar_bon_p3">Bon Bon</a>, ' |
+ '<a href="bar.bon#property-bar_bon_p3">bar_bon_p3</a>', |
resolver.ResolveAllLinks( |
'Hi $ref:bar_bon_p3, $ref:[bar_bon_p3 Bon Bon], $ref:bar_bon_p3', |
relative_to='bar.html', |
namespace='bar.bon')) |
self.assertEqual( |
- 'Hi <a href="bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>, ' |
- '<a href="bar.bon.html#property-bar_bon_p3">Bon Bon</a>, ' |
- '<a href="bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>', |
+ 'Hi <a href="bar.bon#property-bar_bon_p3">bar_bon_p3</a>, ' |
+ '<a href="bar.bon#property-bar_bon_p3">Bon Bon</a>, ' |
+ '<a href="bar.bon#property-bar_bon_p3">bar_bon_p3</a>', |
resolver.ResolveAllLinks( |
'Hi $ref:bar_bon_p3, $ref:[bar_bon_p3 Bon Bon], $ref:bar_bon_p3', |
relative_to='foo/bar.html', |
namespace='bar.bon')) |
self.assertEqual( |
- 'Hi <a href="../bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>, ' |
- '<a href="../bar.bon.html#property-bar_bon_p3">Bon Bon</a>, ' |
- '<a href="../bar.bon.html#property-bar_bon_p3">bar_bon_p3</a>', |
+ 'Hi <a href="../bar.bon#property-bar_bon_p3">bar_bon_p3</a>, ' |
+ '<a href="../bar.bon#property-bar_bon_p3">Bon Bon</a>, ' |
+ '<a href="../bar.bon#property-bar_bon_p3">bar_bon_p3</a>', |
resolver.ResolveAllLinks( |
'Hi $ref:bar_bon_p3, $ref:[bar_bon_p3 Bon Bon], $ref:bar_bon_p3', |
relative_to='foo/baz/bar.html', |