Commit 10c2ca2
authored
MPT-20328: Added endpoints and e2e tests for program templates and parameters (#308)
This pull request adds support for managing program templates in the API
client. It introduces new service classes for both synchronous and
asynchronous operations on templates, updates the main Program services
to expose these new capabilities, and provides comprehensive unit and
end-to-end tests to verify the new functionality.
New Program Templates Support:
Added Template model and TemplatesService / AsyncTemplatesService
classes to
[programs_templates.py](vscode-webview://0mprrqrlqlg3oapm12jkov8h9pk4dfj2hv323gd0ha7nmus4tfma/mpt_api_client/resources/program/programs_templates.py),
including endpoint configuration and resource mixins.
Updated ProgramsService and AsyncProgramsService classes in
[programs.py](vscode-webview://0mprrqrlqlg3oapm12jkov8h9pk4dfj2hv323gd0ha7nmus4tfma/mpt_api_client/resources/program/programs.py)
to provide .templates(program_id) methods for accessing the new
services.
Testing Enhancements:
Added unit tests for the new services and model in
[test_programs_templates.py](vscode-webview://0mprrqrlqlg3oapm12jkov8h9pk4dfj2hv323gd0ha7nmus4tfma/tests/unit/resources/program/test_programs_templates.py),
covering endpoints, method presence, and model field parsing.
Added end-to-end tests for both sync and async template operations
(create, update, get, delete, filter/select) in
[test_sync_template.py](vscode-webview://0mprrqrlqlg3oapm12jkov8h9pk4dfj2hv323gd0ha7nmus4tfma/tests/e2e/program/program/template/test_sync_template.py)
and
[test_async_template.py](vscode-webview://0mprrqrlqlg3oapm12jkov8h9pk4dfj2hv323gd0ha7nmus4tfma/tests/e2e/program/program/template/test_async_template.py),
with supporting fixtures in
[conftest.py](vscode-webview://0mprrqrlqlg3oapm12jkov8h9pk4dfj2hv323gd0ha7nmus4tfma/tests/e2e/program/program/template/conftest.py).
Updated unit tests for Program services to check for the presence of the
new .templates methods in
[test_programs.py](vscode-webview://0mprrqrlqlg3oapm12jkov8h9pk4dfj2hv323gd0ha7nmus4tfma/tests/unit/resources/program/test_programs.py).
Configuration Updates:
Added a seeded template ID to
[e2e_config.test.json](vscode-webview://0mprrqrlqlg3oapm12jkov8h9pk4dfj2hv323gd0ha7nmus4tfma/e2e_config.test.json)
for use in tests.
Closes MPT-20328
Added Template model with typed fields for content (name, content, type,
status), behavior (default), and relationships (external_ids, program,
audit).
Introduced TemplatesService and AsyncTemplatesService with endpoint
configuration at /public/v1/program/programs/{program_id}/templates and
support for managed resource operations (create, read, update, delete,
list, filter, select).
Extended ProgramsService and AsyncProgramsService with
templates(program_id) factory methods for accessing template services.
Added comprehensive end-to-end tests for synchronous and asynchronous
template operations including create, update, get, delete, and filtered
listing with field selection.
Added unit tests validating service configuration, endpoint paths,
public method availability, and model field parsing.
Added pytest fixtures for template e2e tests with test data and
configuration.
<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->
Closes [MPT-20328](https://softwareone.atlassian.net/browse/MPT-20328)
- Add Template model and TemplatesService / AsyncTemplatesService for
program templates (CRUD, list, filter, select) at
/public/v1/program/programs/{program_id}/templates
- Expose .templates(program_id) factory on ProgramsService and
AsyncProgramsService
- Add Parameter model and ParametersService / AsyncParametersService
plus .parameters(program_id) factories for program parameters
- Add unit tests for templates and parameters services and models
(endpoint paths, method presence, model parsing)
- Add synchronous and asynchronous end-to-end tests and pytest fixtures
for template and parameter flows (create, update, get, delete,
filter/select)
- Seed e2e_config.test.json with program.template.id and
program.parameter.id (and repositioned program.document.file.id)
- Update flake8 per-file-ignores for
mpt_api_client/resources/program/*.py
<!-- end of auto-generated comment: release notes by coderabbit.ai -->
[MPT-20328]:
https://softwareone.atlassian.net/browse/MPT-20328?atlOrigin=eyJpIjoiNWRkNTljNzYxNjVmNDY3MDlhMDU5Y2ZhYzA5YTRkZjUiLCJwIjoiZ2l0aHViLWNvbS1KU1cifQ14 files changed
Lines changed: 697 additions & 1 deletion
File tree
- mpt_api_client/resources/program
- tests
- e2e/program/program
- parameter
- template
- unit/resources/program
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
70 | 70 | | |
71 | 71 | | |
72 | 72 | | |
| 73 | + | |
73 | 74 | | |
74 | 75 | | |
| 76 | + | |
75 | 77 | | |
76 | | - | |
| 78 | + | |
77 | 79 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
22 | 22 | | |
23 | 23 | | |
24 | 24 | | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
25 | 33 | | |
26 | 34 | | |
27 | 35 | | |
| |||
101 | 109 | | |
102 | 110 | | |
103 | 111 | | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
104 | 124 | | |
105 | 125 | | |
106 | 126 | | |
| |||
140 | 160 | | |
141 | 161 | | |
142 | 162 | | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 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 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 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 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
125 | 125 | | |
126 | 126 | | |
127 | 127 | | |
| 128 | + | |
128 | 129 | | |
129 | 130 | | |
130 | 131 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 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 | + | |
Lines changed: 68 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 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 | + | |
Lines changed: 68 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 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 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
0 commit comments