forked from trekhleb/learn-python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_function_documentation_string.py
42 lines (30 loc) · 1.95 KB
/
test_function_documentation_string.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
"""Documentation Strings.
@see: https://docs.python.org/3/tutorial/controlflow.html#documentation-strings
Here are some conventions about the content and formatting of documentation strings.
The first line should always be a short, concise summary of the object’s purpose. For brevity,
it should not explicitly state the object’s name or type, since these are available by other means
(except if the name happens to be a verb describing a function’s operation). This line should begin
with a capital letter and end with a period.
If there are more lines in the documentation string, the second line should be blank, visually
separating the summary from the rest of the description. The following lines should be one or more
paragraphs describing the object’s calling conventions, its side effects, etc.
"""
def do_nothing():
"""Do nothing, but document it.
No, really, it doesn't do anything.
"""
pass
def test_function_documentation_string():
"""Test documentation string."""
# The Python parser does not strip indentation from multi-line string literals in Python, so
# tools that process documentation have to strip indentation if desired. This is done using the
# following convention. The first non-blank line after the first line of the string determines
# the amount of indentation for the entire documentation string. (We can’t use the first line
# since it is generally adjacent to the string’s opening quotes so its indentation is not
# apparent in the string literal.) Whitespace “equivalent” to this indentation is then stripped
# from the start of all lines of the string. Lines that are indented less should not occur, but
# if they occur all their leading whitespace should be stripped. Equivalence of whitespace
# should be tested after expansion of tabs (to 8 spaces, normally).
assert do_nothing.__doc__ == """Do nothing, but document it.
No, really, it doesn't do anything.
"""