summaryrefslogtreecommitdiffstats
path: root/templates/md.jinja2
blob: 400da26afcb335cd19e82c9ce0f2060b4b9592f6 (plain)
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
{%- macro expand_function(function_name, function_contents, x = "Function") -%}
 - `{{ function_name }}`:
{%- if function_contents["present"] %}
    - **Arguments:** 
        - `{{ function_contents["arguments"] }}` 
        - {{ bool_to_checkbox(function_contents["minimum_arguments"] >= get_required_num_args(function_name)) }} Enough? 
    - **Documentation**:
        - {{ len_documentation(function_contents["documentation"]["comments"], function_contents["documentation"]["doc"]) }} characters long
{%- if md_show_full_docs == "True" %}
        - Comments:
            {%- if function_contents["documentation"]["comments"] == "None" %}
            - [ ] No comments present
{%- else %}
{{ code_block(function_contents["documentation"]["comments"])|indent(12, True) }}
{%- endif %}
        - Docstring:
{%- if function_contents["documentation"]["doc"] == "None" %}
            - [ ] No docstring present
{%- else %}
{{ code_block(function_contents["documentation"]["doc"])|indent(12, True) }}
{%- endif -%}
{%- endif %}
     - **Source**:
        - {{ get_source_numlines(function_contents["source_code"]) }}
{%- if md_show_source == "True" %}
        - Code:
{{ code_block(function_contents["source_code"])|indent(12, True) }}
{%- endif %}
{%- else %}
    - [ ] {{ x }} not present
{%- endif %}
{%- endmacro -%}

{%- macro code_block(code) -%}
```
{{ code }}
```
{%- endmacro -%}

# {{ name }} - Student ID: {{ student_no }} Automatic marking report 
Report generated at {{ get_datetime() }}
## Class Tree: 

```
{{ recurse_class_tree_text(class_tree) }}
```

## File Analysis

{%- set flat_files = flatten_struct(files) %}
{% for filename, files_contents in flat_files.items() %}
### File `{{ filename }}`:
{%- if files_contents["present"] -%}
{%- if files_contents["has_exception"] %}
*** File cannot be run - has compile time exception ***
Please note that this file cannot be analysed or have tests preformed upon it- 
    this can lead to the whole test suite failing if another module imports this.
 - Exception Type: `{{ files_contents["exception"]["type"] }}`
 - Exception String: `{{ files_contents["exception"]["str"] }}`
 - Full Traceback:
```
{{ files_contents["exception"]["traceback"] }}
```
{%- else %}
 - #### Documentation:
    {%- set len_docs = len_documentation(files_contents["documentation"]["comments"], files_contents["documentation"]["doc"]) %}
    - {{ len_docs }} characters long
{%- if md_show_full_docs == "True" %}
    - ##### Comments:
{%- if files_contents["documentation"]["comments"] == "None" %}
        - [ ] No comments present
{%- else %}
{{ code_block(files_contents["documentation"]["comments"])|indent(8, True) }}
{%- endif %}
    - ##### Docstring:
{%- if files_contents["documentation"]["doc"] == "None" %}
        - [ ] No docstring present
{%- else %}
{{ code_block(files_contents["documentation"]["doc"])|indent(8, True) }}
{%- endif -%}
{%- endif %}
{%- if "classes" in files_contents.keys() %}
    - #### Classes:
{%- set flat_classes = flatten_struct(files_contents["classes"]) -%}
{% for class_name, class_contents in flat_classes.items() %}
        - ##### `{{ class_name}}`:
{%- if "methods" in class_contents.keys() %}
            - ###### Methods:
{%- set flat_methods = flatten_struct(class_contents["methods"]) -%}
{%- for method_name, method_contents in flat_methods.items() %}
{{ expand_function(method_name, method_contents, "Method")|indent(16, True) }}
{%- endfor -%}
{%- endif -%}
{%- endfor -%}
{%- endif -%}
{% if "functions" in files_contents.keys() %}
    - #### Functions:
{%- set flat_functions = flatten_struct(files_contents["functions"]) %}
{%- for function_name, function_contents in flat_functions.items() %}
{{ expand_function(function_name, function_contents)|indent(8, True) }}
{%- endfor -%}
{%- endif -%}
{%- endif -%}
{% else %}
 - [ ] File not present
{% endif %}
{% endfor %}

{% if out != "stdout" and format != "html" -%}
## Tests:
```
{{ test_results["pytest_report"].replace("\n", "") }}
```
{%- endif -%}