|
| 1 | +from __future__ import absolute_import, division, print_function |
| 2 | + |
1 | 3 | import os |
2 | 4 |
|
| 5 | +import pytest |
| 6 | + |
3 | 7 | from bs4 import BeautifulSoup |
4 | 8 | from mock import patch, mock_open |
5 | 9 |
|
6 | 10 | from doc2dash.parsers import types |
7 | | -from doc2dash.parsers.base import TOCEntry |
| 11 | +from doc2dash.parsers.base import TOCEntry, ParserEntry |
8 | 12 | from doc2dash.parsers.pydoctor import PyDoctorParser, _guess_type |
9 | 13 |
|
10 | 14 |
|
11 | 15 | HERE = os.path.dirname(__file__) |
12 | 16 |
|
13 | 17 |
|
14 | | -def test_guess_type(): |
15 | | - ts = [ |
| 18 | +@pytest.mark.parametrize( |
| 19 | + "name, path, expected", [ |
16 | 20 | ('startServer', |
17 | 21 | 'twisted.conch.test.test_cftp.CFTPClientTestBase.html#startServer', |
18 | | - types.METHOD), |
| 22 | + types.METHOD |
| 23 | + ), |
19 | 24 | ('A', 'twisted.test.myrebuilder1.A.html', types.CLASS), |
20 | 25 | ('epollreactor', 'twisted.internet.epollreactor.html', |
21 | 26 | types.PACKAGE) |
22 | 27 | ] |
23 | | - |
24 | | - for t in ts: |
25 | | - assert _guess_type(t[0], t[1]) == t[2] |
| 28 | +) |
| 29 | +def test_guess_type(name, path, expected): |
| 30 | + """ |
| 31 | + Symbol types are correctly guessed. |
| 32 | + """ |
| 33 | + assert _guess_type(name, path) == expected |
26 | 34 |
|
27 | 35 |
|
28 | 36 | EXAMPLE_PARSE_RESULT = [ |
29 | | - ('twisted.conch.insults.insults.ServerProtocol' |
30 | | - '.ControlSequenceParser.A', types.METHOD, |
31 | | - 'twisted.conch.insults.insults.ServerProtocol' |
32 | | - '.ControlSequenceParser.html#A'), |
33 | | - ('twisted.test.myrebuilder1.A', types.CLASS, |
34 | | - 'twisted.test.myrebuilder1.A.html'), |
35 | | - ('twisted.test.myrebuilder2.A', types.CLASS, |
36 | | - 'twisted.test.myrebuilder2.A.html'), |
37 | | - ('twisted.test.test_jelly.A', types.CLASS, |
38 | | - 'twisted.test.test_jelly.A.html'), |
39 | | - ('twisted.test.test_persisted.A', types.CLASS, |
40 | | - 'twisted.test.test_persisted.A.html'), |
41 | | - ('twisted.test.myrebuilder1.A.a', types.METHOD, |
42 | | - 'twisted.test.myrebuilder1.A.html#a'), |
43 | | - ('twisted.test.myrebuilder1.Inherit.a', types.METHOD, |
44 | | - 'twisted.test.myrebuilder1.Inherit.html#a'), |
45 | | - ('twisted.test.myrebuilder2.A.a', types.METHOD, |
46 | | - 'twisted.test.myrebuilder2.A.html#a'), |
47 | | - ('twisted.test.myrebuilder2.Inherit.a', types.METHOD, |
48 | | - 'twisted.test.myrebuilder2.Inherit.html#a'), |
49 | | - ('twisted.web._newclient.HTTP11ClientProtocol.abort', types.METHOD, |
50 | | - 'twisted.web._newclient.HTTP11ClientProtocol.html#abort') |
51 | | -] |
| 37 | + ParserEntry(name=t[0], type=t[1], path=t[2]) |
| 38 | + for t in [ |
| 39 | + ('twisted.conch.insults.insults.ServerProtocol' |
| 40 | + '.ControlSequenceParser.A', types.METHOD, |
| 41 | + 'twisted.conch.insults.insults.ServerProtocol' |
| 42 | + '.ControlSequenceParser.html#A'), |
| 43 | + ('twisted.test.myrebuilder1.A', types.CLASS, |
| 44 | + 'twisted.test.myrebuilder1.A.html'), |
| 45 | + ('twisted.test.myrebuilder2.A', types.CLASS, |
| 46 | + 'twisted.test.myrebuilder2.A.html'), |
| 47 | + ('twisted.test.test_jelly.A', types.CLASS, |
| 48 | + 'twisted.test.test_jelly.A.html'), |
| 49 | + ('twisted.test.test_persisted.A', types.CLASS, |
| 50 | + 'twisted.test.test_persisted.A.html'), |
| 51 | + ('twisted.test.myrebuilder1.A.a', types.METHOD, |
| 52 | + 'twisted.test.myrebuilder1.A.html#a'), |
| 53 | + ('twisted.test.myrebuilder1.Inherit.a', types.METHOD, |
| 54 | + 'twisted.test.myrebuilder1.Inherit.html#a'), |
| 55 | + ('twisted.test.myrebuilder2.A.a', types.METHOD, |
| 56 | + 'twisted.test.myrebuilder2.A.html#a'), |
| 57 | + ('twisted.test.myrebuilder2.Inherit.a', types.METHOD, |
| 58 | + 'twisted.test.myrebuilder2.Inherit.html#a'), |
| 59 | + ('twisted.web._newclient.HTTP11ClientProtocol.abort', types.METHOD, |
| 60 | + 'twisted.web._newclient.HTTP11ClientProtocol.html#abort') |
| 61 | + ]] |
52 | 62 |
|
53 | 63 |
|
54 | 64 | def test_parse(): |
| 65 | + """ |
| 66 | + The shipped example results in the expected parsing result. |
| 67 | + """ |
55 | 68 | example = open(os.path.join(HERE, 'pydoctor_example.html')).read() |
56 | 69 | with patch('doc2dash.parsers.pydoctor.open', mock_open(read_data=example), |
57 | 70 | create=True): |
|
0 commit comments