foreman_acd 0.2.1 → 0.7.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (195) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +107 -56
  3. data/app/controllers/foreman_acd/ansible_playbooks_controller.rb +199 -0
  4. data/app/controllers/foreman_acd/api/v2/ansible_playbooks_controller.rb +72 -0
  5. data/app/controllers/foreman_acd/api/v2/app_definitions_controller.rb +1 -0
  6. data/app/controllers/foreman_acd/api/v2/app_instances_controller.rb +62 -0
  7. data/app/controllers/foreman_acd/app_definitions_controller.rb +19 -10
  8. data/app/controllers/foreman_acd/app_instances_controller.rb +111 -137
  9. data/app/controllers/foreman_acd/concerns/ansible_playbook_parameters.rb +23 -0
  10. data/app/controllers/foreman_acd/concerns/app_definition_parameters.rb +1 -1
  11. data/app/controllers/foreman_acd/concerns/app_instance_parameters.rb +1 -1
  12. data/app/controllers/foreman_acd/remote_execution_controller.rb +62 -0
  13. data/app/controllers/ui_acd_controller.rb +20 -3
  14. data/app/lib/actions/foreman_acd/deploy_all_hosts.rb +47 -0
  15. data/app/lib/actions/foreman_acd/run_configurator.rb +44 -0
  16. data/app/models/concerns/foreman_acd/host_managed_extensions.rb +51 -0
  17. data/app/models/foreman_acd/acd_provider.rb +36 -0
  18. data/app/models/foreman_acd/ansible_playbook.rb +68 -0
  19. data/app/models/foreman_acd/app_definition.rb +25 -0
  20. data/app/models/foreman_acd/app_instance.rb +42 -0
  21. data/app/models/foreman_acd/foreman_host.rb +23 -0
  22. data/app/models/foreman_acd/taxonomy_extensions.rb +17 -0
  23. data/app/services/foreman_acd/acd_proxy_proxy_selector.rb +17 -0
  24. data/app/services/foreman_acd/app_configurator.rb +98 -0
  25. data/app/services/foreman_acd/app_deployer.rb +157 -0
  26. data/app/services/foreman_acd/inventory_creator.rb +68 -0
  27. data/app/views/foreman_acd/ansible_playbooks/_form.html.erb +64 -0
  28. data/app/views/foreman_acd/ansible_playbooks/edit.html.erb +11 -0
  29. data/app/views/foreman_acd/ansible_playbooks/index.html.erb +30 -0
  30. data/app/views/foreman_acd/ansible_playbooks/new.html.erb +3 -0
  31. data/app/views/foreman_acd/api/v2/ansible_playbooks/base.json.rabl +5 -0
  32. data/app/views/foreman_acd/api/v2/ansible_playbooks/index.json.rabl +5 -0
  33. data/app/views/foreman_acd/api/v2/ansible_playbooks/show.json.rabl +9 -0
  34. data/app/views/foreman_acd/api/v2/app_definitions/base.json.rabl +5 -0
  35. data/app/views/foreman_acd/api/v2/app_definitions/index.json.rabl +5 -0
  36. data/app/views/foreman_acd/api/v2/app_definitions/show.json.rabl +9 -0
  37. data/app/views/foreman_acd/api/v2/app_instances/base.json.rabl +5 -0
  38. data/app/views/foreman_acd/api/v2/app_instances/index.json.rabl +5 -0
  39. data/app/views/foreman_acd/api/v2/app_instances/show.json.rabl +5 -0
  40. data/app/views/foreman_acd/app_definitions/_form.html.erb +34 -12
  41. data/app/views/foreman_acd/app_definitions/edit.html.erb +10 -0
  42. data/app/views/foreman_acd/app_definitions/index.html.erb +4 -4
  43. data/app/views/foreman_acd/app_instances/_form.html.erb +11 -9
  44. data/app/views/foreman_acd/app_instances/edit.html.erb +10 -0
  45. data/app/views/foreman_acd/app_instances/index.html.erb +89 -10
  46. data/app/views/foreman_acd/app_instances/report.html.erb +6 -3
  47. data/app/views/templates/job/run_acd_ansible_playbook.erb +62 -0
  48. data/app/views/ui_acd/ansible_data.json.rabl +6 -0
  49. data/app/views/ui_acd/app.json.rabl +6 -2
  50. data/app/views/ui_acd/app_definition.json.rabl +1 -1
  51. data/app/views/ui_acd/{fdata.json.rabl → foreman_data.json.rabl} +1 -1
  52. data/config/routes.rb +32 -2
  53. data/db/migrate/20200916091018_create_ansible_playbooks.rb +20 -0
  54. data/db/migrate/20200917120220_add_ansible_playbook_id.rb +14 -0
  55. data/db/migrate/20201016002819_add_ansible_vars_all_to_app_definitions.rb +8 -0
  56. data/db/migrate/20201016104338_add_ansible_vars_all_to_app_instances.rb +8 -0
  57. data/db/migrate/20210112111548_add_organization_to_app_instance.rb +22 -0
  58. data/db/migrate/20210112113853_add_location_to_app_instance.rb +8 -0
  59. data/db/migrate/20210202141658_create_foreman_hosts.rb +24 -0
  60. data/db/migrate/20210204111306_remove_hosts_from_app_instances.rb +8 -0
  61. data/db/migrate/20210209091014_rename_acd_tables.rb +16 -0
  62. data/db/migrate/20210216083522_add_last_progress_report.rb +8 -0
  63. data/db/migrate/20210216091529_add_last_deploy_task.rb +8 -0
  64. data/db/migrate/20210316151145_add_git_commit_to_ansible_playbooks.rb +8 -0
  65. data/db/migrate/20210503122809_add_git_url_to_ansible_playbooks.rb +8 -0
  66. data/db/seeds.d/62_acd_proxy_feature.rb +4 -0
  67. data/db/seeds.d/75-job_templates.rb +13 -0
  68. data/lib/foreman_acd.rb +12 -0
  69. data/lib/foreman_acd/engine.rb +43 -3
  70. data/lib/foreman_acd/plugin.rb +88 -22
  71. data/lib/foreman_acd/version.rb +1 -1
  72. data/lib/tasks/foreman_acd_tasks.rake +0 -12
  73. data/locale/en/foreman_acd.edit.po +326 -0
  74. data/locale/en/foreman_acd.po +232 -2
  75. data/locale/en/foreman_acd.po.time_stamp +0 -0
  76. data/locale/foreman_acd.pot +343 -8
  77. data/package.json +9 -9
  78. data/test/controllers/ansible_playbooks_controller_test.rb +27 -0
  79. data/test/controllers/app_instances_controller_test.rb +8 -3
  80. data/test/controllers/ui_acd_controller_test.rb +22 -6
  81. data/test/factories/foreman_acd_factories.rb +18 -4
  82. data/test/models/acd_provider_test.rb +37 -0
  83. data/test/models/ansible_playbook_test.rb +11 -0
  84. data/test/models/app_definition_test.rb +1 -1
  85. data/test/models/app_instance_test.rb +2 -0
  86. data/test/models/concerns/host_extensions_test.rb +26 -0
  87. data/test/models/foreman_host_test.rb +12 -0
  88. data/webpack/__mocks__/foremanReact/API.js +2 -0
  89. data/webpack/__mocks__/foremanReact/common/I18n.js +3 -0
  90. data/webpack/__mocks__/foremanReact/common/helpers.js +2 -0
  91. data/webpack/__mocks__/foremanReact/components/ForemanModal.js +7 -0
  92. data/webpack/__mocks__/foremanReact/components/common/forms/CommonForm.js +2 -0
  93. data/webpack/__mocks__/foremanReact/components/common/forms/TextInput.js +2 -0
  94. data/webpack/__mocks__/foremanReact/components/hosts/powerStatus.js +1 -0
  95. data/webpack/__snapshots__/helper.test.js.snap +14 -0
  96. data/webpack/components/ApplicationDefinition/ApplicationDefinition.js +159 -29
  97. data/webpack/components/ApplicationDefinition/ApplicationDefinitionActions.js +106 -14
  98. data/webpack/components/ApplicationDefinition/ApplicationDefinitionConstants.js +8 -2
  99. data/webpack/components/ApplicationDefinition/ApplicationDefinitionHelper.js +26 -0
  100. data/webpack/components/ApplicationDefinition/ApplicationDefinitionReducer.js +143 -21
  101. data/webpack/components/ApplicationDefinition/ApplicationDefinitionSelectors.js +3 -0
  102. data/webpack/components/ApplicationDefinition/__fixtures__/applicationDefinitionConfData_1.fixtures.js +288 -0
  103. data/webpack/components/ApplicationDefinition/__fixtures__/applicationDefinitionReducer.fixtures.js +79 -0
  104. data/webpack/components/ApplicationDefinition/__tests__/ApplicationDefinition.test.js +25 -0
  105. data/webpack/components/ApplicationDefinition/__tests__/ApplicationDefinitionReducer.test.js +119 -0
  106. data/webpack/components/ApplicationDefinition/__tests__/ApplicationDefinitionSelectors.test.js +41 -0
  107. data/webpack/components/ApplicationDefinition/__tests__/__snapshots__/ApplicationDefinition.test.js.snap +200 -0
  108. data/webpack/components/ApplicationDefinition/__tests__/__snapshots__/ApplicationDefinitionReducer.test.js.snap +3033 -0
  109. data/webpack/components/ApplicationDefinition/__tests__/__snapshots__/ApplicationDefinitionSelectors.test.js.snap +299 -0
  110. data/webpack/components/ApplicationDefinition/components/AnsiblePlaybookSelector.js +50 -0
  111. data/webpack/components/ApplicationDefinition/components/__tests__/AnsiblePlaybookSelector.test.js +41 -0
  112. data/webpack/components/ApplicationDefinition/components/__tests__/__snapshots__/AnsiblePlaybookSelector.test.js.snap +121 -0
  113. data/webpack/components/ApplicationDefinition/index.js +6 -0
  114. data/webpack/components/ApplicationInstance/ApplicationInstance.js +151 -44
  115. data/webpack/components/ApplicationInstance/ApplicationInstanceActions.js +47 -10
  116. data/webpack/components/ApplicationInstance/ApplicationInstanceConstants.js +5 -2
  117. data/webpack/components/ApplicationInstance/ApplicationInstanceReducer.js +114 -28
  118. data/webpack/components/ApplicationInstance/ApplicationInstanceSelectors.js +3 -1
  119. data/webpack/components/ApplicationInstance/__fixtures__/applicationInstanceConfData_1.fixtures.js +263 -0
  120. data/webpack/components/ApplicationInstance/__fixtures__/applicationInstanceReducer.fixtures.js +78 -0
  121. data/webpack/components/ApplicationInstance/__tests__/ApplicationInstance.test.js +23 -0
  122. data/webpack/components/ApplicationInstance/__tests__/ApplicationInstanceReducer.test.js +119 -0
  123. data/webpack/components/ApplicationInstance/__tests__/ApplicationInstanceSelectors.test.js +44 -0
  124. data/webpack/components/ApplicationInstance/__tests__/__snapshots__/ApplicationInstance.test.js.snap +209 -0
  125. data/webpack/components/ApplicationInstance/__tests__/__snapshots__/ApplicationInstanceReducer.test.js.snap +2719 -0
  126. data/webpack/components/ApplicationInstance/__tests__/__snapshots__/ApplicationInstanceSelectors.test.js.snap +276 -0
  127. data/webpack/components/ApplicationInstance/components/Service.js +1 -1
  128. data/webpack/components/ApplicationInstance/index.js +4 -0
  129. data/webpack/components/ApplicationInstanceReport/ApplicationInstanceReport.js +53 -60
  130. data/webpack/components/ApplicationInstanceReport/ApplicationInstanceReport.scss +17 -0
  131. data/webpack/components/ApplicationInstanceReport/ApplicationInstanceReportActions.js +7 -51
  132. data/webpack/components/ApplicationInstanceReport/ApplicationInstanceReportConstants.js +2 -4
  133. data/webpack/components/ApplicationInstanceReport/ApplicationInstanceReportReducer.js +4 -18
  134. data/webpack/components/ApplicationInstanceReport/ApplicationInstanceReportSelectors.js +0 -1
  135. data/webpack/components/ApplicationInstanceReport/__fixtures__/applicationInstanceReportData_1.fixtures.js +349 -0
  136. data/webpack/components/ApplicationInstanceReport/__fixtures__/applicationInstanceReportReducer.fixtures.js +20 -0
  137. data/webpack/components/ApplicationInstanceReport/__tests__/ApplicationInstanceReport.test.js +47 -0
  138. data/webpack/components/ApplicationInstanceReport/__tests__/ApplicationInstanceReportReducer.test.js +41 -0
  139. data/webpack/components/ApplicationInstanceReport/__tests__/ApplicationInstanceReportSelectors.test.js +26 -0
  140. data/webpack/components/ApplicationInstanceReport/__tests__/__snapshots__/ApplicationInstanceReport.test.js.snap +130 -0
  141. data/webpack/components/ApplicationInstanceReport/__tests__/__snapshots__/ApplicationInstanceReportReducer.test.js.snap +718 -0
  142. data/webpack/components/ApplicationInstanceReport/__tests__/__snapshots__/ApplicationInstanceReportSelectors.test.js.snap +347 -0
  143. data/webpack/components/ApplicationInstanceReport/components/ReportViewer.js +1 -1
  144. data/webpack/components/ApplicationInstanceReport/components/__tests__/ReportViewer.test.js +24 -0
  145. data/webpack/components/ApplicationInstanceReport/components/__tests__/__snapshots__/ReportViewer.test.js.snap +24 -0
  146. data/webpack/components/ApplicationInstanceReport/index.js +0 -2
  147. data/webpack/components/ParameterSelection/ParameterSelection.js +85 -50
  148. data/webpack/components/ParameterSelection/ParameterSelectionActions.js +68 -62
  149. data/webpack/components/ParameterSelection/ParameterSelectionConstants.js +6 -3
  150. data/webpack/components/ParameterSelection/ParameterSelectionHelper.js +0 -32
  151. data/webpack/components/ParameterSelection/ParameterSelectionReducer.js +47 -35
  152. data/webpack/components/ParameterSelection/ParameterSelectionSelectors.js +2 -2
  153. data/webpack/components/ParameterSelection/__fixtures__/parameterSelectionData_1.fixtures.js +116 -84
  154. data/webpack/components/ParameterSelection/__fixtures__/parameterSelectionReducer.fixtures.js +10 -4
  155. data/webpack/components/ParameterSelection/__tests__/ParameterSelection.test.js +36 -46
  156. data/webpack/components/ParameterSelection/__tests__/ParameterSelectionReducer.test.js +31 -25
  157. data/webpack/components/ParameterSelection/__tests__/ParameterSelectionSelectors.test.js +6 -6
  158. data/webpack/components/ParameterSelection/__tests__/__snapshots__/ParameterSelection.test.js.snap +2 -126
  159. data/webpack/components/ParameterSelection/__tests__/__snapshots__/ParameterSelectionReducer.test.js.snap +1483 -872
  160. data/webpack/components/ParameterSelection/__tests__/__snapshots__/ParameterSelectionSelectors.test.js.snap +117 -79
  161. data/webpack/components/ParameterSelection/index.js +4 -4
  162. data/webpack/components/SyncGitRepo/SyncGitRepo.js +210 -0
  163. data/webpack/components/SyncGitRepo/SyncGitRepo.scss +1 -0
  164. data/webpack/components/SyncGitRepo/SyncGitRepoActions.js +124 -0
  165. data/webpack/components/SyncGitRepo/SyncGitRepoConstants.js +9 -0
  166. data/webpack/components/SyncGitRepo/SyncGitRepoReducer.js +80 -0
  167. data/webpack/components/SyncGitRepo/SyncGitRepoSelectors.js +6 -0
  168. data/webpack/components/SyncGitRepo/__fixtures__/syncGitRepoConfData_1.fixtures.js +7 -0
  169. data/webpack/components/SyncGitRepo/__fixtures__/syncGitRepoReducer.fixtures.js +44 -0
  170. data/webpack/components/SyncGitRepo/__tests__/SyncGitRepo.test.js +27 -0
  171. data/webpack/components/SyncGitRepo/__tests__/SyncGitRepoReducer.test.js +95 -0
  172. data/webpack/components/SyncGitRepo/__tests__/SyncGitRepoSelectors.test.js +32 -0
  173. data/webpack/components/SyncGitRepo/__tests__/__snapshots__/SyncGitRepo.test.js.snap +30 -0
  174. data/webpack/components/SyncGitRepo/__tests__/__snapshots__/SyncGitRepoReducer.test.js.snap +137 -0
  175. data/webpack/components/SyncGitRepo/__tests__/__snapshots__/SyncGitRepoSelectors.test.js.snap +13 -0
  176. data/webpack/components/SyncGitRepo/components/FormTextInput.js +42 -0
  177. data/webpack/components/SyncGitRepo/components/ScmTypeSelector.js +46 -0
  178. data/webpack/components/SyncGitRepo/index.js +28 -0
  179. data/webpack/components/common/DeleteTableEntry.js +3 -3
  180. data/webpack/components/common/EditTableEntry.js +50 -0
  181. data/webpack/components/common/ExtTextInput.js +43 -0
  182. data/webpack/components/common/LockTableEntry.js +60 -0
  183. data/webpack/components/common/__tests__/EditTableEntry.test.js +53 -0
  184. data/webpack/components/common/__tests__/LockTableEntry.test.js +35 -0
  185. data/webpack/components/common/__tests__/__snapshots__/DeleteTableEntry.test.js.snap +2 -2
  186. data/webpack/components/common/__tests__/__snapshots__/EditTableEntry.test.js.snap +81 -0
  187. data/webpack/components/common/__tests__/__snapshots__/LockTableEntry.test.js.snap +60 -0
  188. data/webpack/helper.js +15 -1
  189. data/webpack/helper.test.js +37 -0
  190. data/webpack/index.js +2 -0
  191. data/webpack/reducer.js +18 -11
  192. metadata +184 -10
  193. data/app/views/foreman_acd/app_instances/deploy.html.erb +0 -19
  194. data/webpack/components/common/__tests__/__snapshots__/AddParameter.test.js.snap +0 -35
  195. data/webpack/components/common/__tests__/__snapshots__/DeleteParameter.test.js.snap +0 -41
@@ -0,0 +1,276 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`ApplicationInstanceSelectors should return ParamEditMode from applicationInstanceConfData_1 fixtures 1`] = `undefined`;
4
+
5
+ exports[`ApplicationInstanceSelectors should return ansibleVarsAll from applicationInstanceConfData_1 fixtures 1`] = `
6
+ Array [
7
+ Object {
8
+ "id": 0,
9
+ "name": "repository",
10
+ "value": "https://github.com/bennojoy/mywebapp.git",
11
+ },
12
+ ]
13
+ `;
14
+
15
+ exports[`ApplicationInstanceSelectors should return appDefinition from applicationInstanceConfData_1 fixtures 1`] = `
16
+ Object {
17
+ "ansible_vars_all": "[{\\"id\\":0,\\"name\\":\\"repository\\",\\"value\\":\\"https://github.com/bennojoy/mywebapp.git\\"}]",
18
+ "created_at": "2021-03-11 12:51:34 +0100",
19
+ "description": "",
20
+ "id": 1,
21
+ "location_ids": Array [
22
+ 2,
23
+ ],
24
+ "name": "LAMP",
25
+ "organization_ids": Array [
26
+ 1,
27
+ ],
28
+ "services": "[{\\"id\\":1,\\"name\\":\\"web\\",\\"description\\":\\"\\",\\"hostgroup\\":\\"1\\",\\"ansibleGroup\\":\\"webservers\\",\\"minCount\\":\\"2\\",\\"maxCount\\":\\"\\",\\"foremanParameters\\":[{\\"id\\":1,\\"locked\\":false,\\"name\\":\\"CP\\",\\"description\\":\\"\\",\\"type\\":\\"computeprofile\\",\\"value\\":\\"1\\"},{\\"id\\":2,\\"locked\\":true,\\"name\\":\\"LE\\",\\"description\\":\\"\\",\\"type\\":\\"lifecycleenv\\",\\"value\\":\\"1\\"}],\\"ansibleParameters\\":[{\\"id\\":0,\\"name\\":\\"dummy_var\\",\\"value\\":\\"0\\"}]},{\\"id\\":2,\\"name\\":\\"db\\",\\"description\\":\\"\\",\\"hostgroup\\":\\"1\\",\\"ansibleGroup\\":\\"dbservers\\",\\"minCount\\":\\"1\\",\\"maxCount\\":\\"\\",\\"foremanParameters\\":[],\\"ansibleParameters\\":[{\\"id\\":0,\\"name\\":\\"mysqlservice\\",\\"value\\":\\"mysqld\\"},{\\"id\\":1,\\"name\\":\\"mysql_port\\",\\"value\\":\\"3306\\",\\"locked\\":true},{\\"id\\":2,\\"name\\":\\"dbuser\\",\\"value\\":\\"webapp\\"},{\\"id\\":3,\\"name\\":\\"dbname\\",\\"value\\":\\"ANSAP01\\"},{\\"id\\":4,\\"name\\":\\"upassword\\",\\"value\\":\\"Bond@007\\"},{\\"id\\":5,\\"name\\":\\"masterpassword\\",\\"value\\":\\"MySQL@007\\"}]}]",
29
+ "updated_at": "2021-03-13 00:06:12 +0100",
30
+ }
31
+ `;
32
+
33
+ exports[`ApplicationInstanceSelectors should return columns from applicationInstanceConfData_1 fixtures 1`] = `
34
+ Array [
35
+ Object {
36
+ "cell": Object {
37
+ "formatters": Array [
38
+ null,
39
+ ],
40
+ },
41
+ "header": Object {
42
+ "formatters": Array [
43
+ null,
44
+ ],
45
+ "label": "Hostname",
46
+ "props": Object {
47
+ "index": 0,
48
+ "style": Object {
49
+ "width": "30%",
50
+ },
51
+ },
52
+ },
53
+ "property": "hostname",
54
+ },
55
+ Object {
56
+ "cell": Object {
57
+ "formatters": Array [
58
+ null,
59
+ ],
60
+ },
61
+ "header": Object {
62
+ "formatters": Array [
63
+ null,
64
+ ],
65
+ "label": "Description",
66
+ "props": Object {
67
+ "index": 1,
68
+ "style": Object {
69
+ "width": "30%",
70
+ },
71
+ },
72
+ },
73
+ "property": "description",
74
+ },
75
+ Object {
76
+ "cell": Object {
77
+ "formatters": Array [
78
+ null,
79
+ ],
80
+ },
81
+ "header": Object {
82
+ "formatters": Array [
83
+ null,
84
+ ],
85
+ "label": "Service",
86
+ "props": Object {
87
+ "index": 2,
88
+ "style": Object {
89
+ "width": "20%",
90
+ },
91
+ },
92
+ },
93
+ "property": "service",
94
+ },
95
+ Object {
96
+ "cell": Object {
97
+ "formatters": Array [
98
+ null,
99
+ ],
100
+ },
101
+ "header": Object {
102
+ "formatters": Array [
103
+ null,
104
+ ],
105
+ "label": "Actions",
106
+ "props": Object {
107
+ "index": 4,
108
+ "style": Object {
109
+ "width": "20%",
110
+ },
111
+ },
112
+ },
113
+ "property": "actions",
114
+ },
115
+ ]
116
+ `;
117
+
118
+ exports[`ApplicationInstanceSelectors should return editMode from applicationInstanceConfData_1 fixtures 1`] = `undefined`;
119
+
120
+ exports[`ApplicationInstanceSelectors should return hosts from applicationInstanceConfData_1 fixtures 1`] = `
121
+ Array [
122
+ Object {
123
+ "ansibleParameters": Array [
124
+ Object {
125
+ "id": 0,
126
+ "name": "mysqlservice",
127
+ "value": "mysqld",
128
+ },
129
+ Object {
130
+ "id": 1,
131
+ "name": "mysql_port",
132
+ "value": "3306",
133
+ },
134
+ Object {
135
+ "id": 2,
136
+ "name": "dbuser",
137
+ "value": "webapp",
138
+ },
139
+ Object {
140
+ "id": 3,
141
+ "name": "dbname",
142
+ "value": "ANSAP01",
143
+ },
144
+ Object {
145
+ "id": 4,
146
+ "name": "upassword",
147
+ "value": "Bond@007",
148
+ },
149
+ Object {
150
+ "id": 5,
151
+ "name": "masterpassword",
152
+ "value": "MySQL@007",
153
+ },
154
+ ],
155
+ "description": "",
156
+ "foremanParameters": Array [],
157
+ "hostname": "great-web-app-db-1",
158
+ "id": 4,
159
+ "service": "2",
160
+ },
161
+ Object {
162
+ "ansibleParameters": Array [
163
+ Object {
164
+ "id": 0,
165
+ "name": "dummy_var",
166
+ "value": "0",
167
+ },
168
+ ],
169
+ "description": "",
170
+ "foremanParameters": Array [],
171
+ "hostname": "great-web-app-web-1",
172
+ "id": 1,
173
+ "service": "1",
174
+ },
175
+ Object {
176
+ "ansibleParameters": Array [
177
+ Object {
178
+ "id": 0,
179
+ "name": "dummy_var",
180
+ "value": "0",
181
+ },
182
+ ],
183
+ "description": "",
184
+ "foremanParameters": Array [],
185
+ "hostname": "great-web-app-web-2",
186
+ "id": 2,
187
+ "service": "1",
188
+ },
189
+ ]
190
+ `;
191
+
192
+ exports[`ApplicationInstanceSelectors should return parametersData from applicationInstanceConfData_1 fixtures 1`] = `undefined`;
193
+
194
+ exports[`ApplicationInstanceSelectors should return services from applicationInstanceConfData_1 fixtures 1`] = `
195
+ Array [
196
+ Object {
197
+ "ansibleGroup": "webservers",
198
+ "ansibleParameters": Array [
199
+ Object {
200
+ "id": 0,
201
+ "name": "dummy_var",
202
+ "value": "0",
203
+ },
204
+ ],
205
+ "currentCount": 2,
206
+ "description": "",
207
+ "foremanParameters": Array [
208
+ Object {
209
+ "description": "",
210
+ "id": 1,
211
+ "locked": false,
212
+ "name": "CP",
213
+ "type": "computeprofile",
214
+ "value": "1",
215
+ },
216
+ Object {
217
+ "description": "",
218
+ "id": 2,
219
+ "locked": true,
220
+ "name": "LE",
221
+ "type": "lifecycleenv",
222
+ "value": "1",
223
+ },
224
+ ],
225
+ "hostgroup": "1",
226
+ "id": 1,
227
+ "maxCount": "",
228
+ "minCount": "2",
229
+ "name": "web",
230
+ },
231
+ Object {
232
+ "ansibleGroup": "dbservers",
233
+ "ansibleParameters": Array [
234
+ Object {
235
+ "id": 0,
236
+ "name": "mysqlservice",
237
+ "value": "mysqld",
238
+ },
239
+ Object {
240
+ "id": 1,
241
+ "locked": true,
242
+ "name": "mysql_port",
243
+ "value": "3306",
244
+ },
245
+ Object {
246
+ "id": 2,
247
+ "name": "dbuser",
248
+ "value": "webapp",
249
+ },
250
+ Object {
251
+ "id": 3,
252
+ "name": "dbname",
253
+ "value": "ANSAP01",
254
+ },
255
+ Object {
256
+ "id": 4,
257
+ "name": "upassword",
258
+ "value": "Bond@007",
259
+ },
260
+ Object {
261
+ "id": 5,
262
+ "name": "masterpassword",
263
+ "value": "MySQL@007",
264
+ },
265
+ ],
266
+ "currentCount": 1,
267
+ "description": "",
268
+ "foremanParameters": Array [],
269
+ "hostgroup": "1",
270
+ "id": 2,
271
+ "maxCount": "",
272
+ "minCount": "1",
273
+ "name": "db",
274
+ },
275
+ ]
276
+ `;
@@ -9,7 +9,7 @@ const Service= ({
9
9
  }) =>{
10
10
  return (
11
11
  <div>
12
- <label>{name}:</label> {currentCount} (Min/Max: {minCount}/{maxCount})
12
+ <label>{name}:</label> {currentCount} ({__("Min/Max")}: {minCount}/{maxCount})
13
13
  </div>
14
14
  );
15
15
  };
@@ -12,6 +12,8 @@ import {
12
12
  selectServices,
13
13
  selectColumns,
14
14
  selectParametersData,
15
+ selectAnsibleVarsAll,
16
+ selectParamEditMode,
15
17
  } from './ApplicationInstanceSelectors';
16
18
 
17
19
  const mapStateToProps = state => ({
@@ -21,6 +23,8 @@ const mapStateToProps = state => ({
21
23
  services: selectServices(state),
22
24
  columns: selectColumns(state),
23
25
  parametersData: selectParametersData(state),
26
+ ansibleVarsAll: selectAnsibleVarsAll(state),
27
+ paramEditMode: selectParamEditMode(state),
24
28
  });
25
29
 
26
30
  const mapDispatchToProps = dispatch =>
@@ -5,6 +5,10 @@ import {
5
5
  VerticalTabs,
6
6
  } from 'patternfly-react-extensions';
7
7
 
8
+ import {
9
+ translate as __
10
+ } from 'foremanReact/common/I18n';
11
+
8
12
  import PowerStatus from 'foremanReact/components/hosts/powerStatus';
9
13
  import ReportViewer from './components/ReportViewer';
10
14
 
@@ -18,54 +22,20 @@ class ApplicationInstanceReport extends React.Component {
18
22
  const {
19
23
  data: { hosts, mode },
20
24
  initApplicationInstanceReport,
21
- setActiveAndLoadLiveReport,
25
+ setActiveHost,
22
26
  } = this.props;
23
27
 
24
28
  initApplicationInstanceReport(hosts);
25
-
26
- if (mode == 'liveReport') {
27
- if (hosts.length > 0) {
28
- const index = 0;
29
- const url = `/api/v2/orchestration/${hosts[index].progress_report_id}/tasks`;
30
- setActiveAndLoadLiveReport(index, url);
31
- }
32
- }
33
29
  };
34
30
 
35
31
  isActive(id) {
36
32
  return (this.props.activeHostId === id);
37
33
  }
38
34
 
39
- collectLiveData(hosts) {
40
- const {
41
- setActiveAndLoadLiveReport,
42
- } = this.props;
43
- const tabs = []
44
-
45
- for (const [index, value] of hosts.entries()) {
46
- const url = `/api/v2/orchestration/${hosts[index].progress_report_id}/tasks`
47
-
48
- tabs.push(
49
- <VerticalTabs.Tab
50
- id={index}
51
- key={"vt_tab_"+index}
52
- title={ value.name }
53
- wrapStyle='nowrap'
54
- onActivate={() => setActiveAndLoadLiveReport(index, url)}
55
- active={this.isActive(index)}
56
- />
57
- );
58
- }
59
-
60
- return tabs;
61
- }
62
-
63
35
  collectLastReportData(hosts) {
64
36
  const {
65
- setActiveAndLoadLastReport,
37
+ setActiveHost,
66
38
  } = this.props;
67
- // FIXME
68
- const url = undefined;
69
39
 
70
40
  const tabs = []
71
41
  for (const [index, value] of hosts.entries()) {
@@ -75,7 +45,7 @@ class ApplicationInstanceReport extends React.Component {
75
45
  key={"vt_tab_"+index}
76
46
  title={ value.name }
77
47
  wrapStyle='nowrap'
78
- onActivate={() => setActiveAndLoadLastReport(index, url)}
48
+ onActivate={() => setActiveHost(index)}
79
49
  active={this.isActive(index)}
80
50
  />
81
51
  );
@@ -84,43 +54,61 @@ class ApplicationInstanceReport extends React.Component {
84
54
  return tabs;
85
55
  }
86
56
 
87
- liveReportStatus(host) {
88
- return (
89
- <span>Host: <a href={ host['hostUrl'] }>{ host['hostname'] }</a></span>
90
- );
91
- }
92
-
93
57
  lastReportStatus(host) {
94
- return (
95
- <div>
96
- <span>Host: <a href={ host['hostUrl'] }>{ host['hostname'] }</a></span>
97
- <span>&nbsp;|&nbsp;</span>
98
- <span>Power Status: <PowerStatus data={{ id: host['id'], url: host['powerStatusUrl'] }} /></span>
99
- </div>
100
- )
58
+ if (!host['id']) {
59
+ return (
60
+ <div>
61
+ <span>Host: { host['name'] }</span>
62
+ <span>&nbsp;|&nbsp;</span>
63
+ <span>State: { __('not build') }</span>
64
+ <span>&nbsp;|&nbsp;</span>
65
+ <span>Power Status: { __('unknown') }</span>
66
+ </div>
67
+ )
68
+ } else {
69
+ return (
70
+ <div>
71
+ <span>Host: <a href={ host['hostUrl'] }>{ host['name'] }</a></span>
72
+ <span>&nbsp;|&nbsp;</span>
73
+ <span>State: { host['build'] == true ? "in Build" : "Deployed" }</span>
74
+ <span>&nbsp;|&nbsp;</span>
75
+ <span>Power Status: <PowerStatus key={ "power_status_"+ host['id'] } data={{ id: host['id'], url: host['powerStatusUrl'] }} /></span>
76
+ </div>
77
+ )
78
+ }
101
79
  }
102
80
 
103
81
  render() {
104
82
  const {
105
- data: { hosts, mode },
106
- report,
83
+ data: { hosts, mode, appInstanceName, deployTaskUrl, configureJobUrl },
107
84
  activeHostId,
108
85
  } = this.props;
109
86
 
110
87
  let tabs = [];
111
88
  let reportStatus = undefined;
89
+ let report = undefined;
112
90
 
113
- if (mode == 'liveReport') {
114
- tabs = this.collectLiveData(hosts);
115
- reportStatus = this.liveReportStatus(hosts[activeHostId])
116
- } else if (mode == 'lastReport') {
117
- tabs = this.collectLastReportData(hosts);
118
- reportStatus = this.lastReportStatus(hosts[activeHostId])
91
+ tabs = this.collectLastReportData(hosts);
92
+ reportStatus = this.lastReportStatus(hosts[activeHostId]);
93
+
94
+ if (hosts[activeHostId]['progress_report']) {
95
+ report = hosts[activeHostId]['progress_report'];
119
96
  }
120
97
 
121
98
  return (
122
99
  <span>
100
+ <div className="deploy_status">
101
+ <div>
102
+ <div className="deploy_status_head">Deployment task</div>
103
+ <div className="deploy_status_content"><a href={ deployTaskUrl } >Last deployment task</a></div>
104
+ </div>
105
+ <div>
106
+ <div className="deploy_status_head">Configuration job</div>
107
+ <div className="deploy_status_content"><a href={ configureJobUrl }>Configuration jobs</a></div>
108
+ </div>
109
+ </div>
123
110
  <div className="deploy_report_hosts">
111
+ Hosts
124
112
  <VerticalTabs id="vertical_tabs">
125
113
  {tabs}
126
114
  </VerticalTabs>
@@ -137,6 +125,9 @@ class ApplicationInstanceReport extends React.Component {
137
125
 
138
126
  ApplicationInstanceReport.defaultProps = {
139
127
  error: {},
128
+ appInstanceName: '',
129
+ deployTaskUrl: '',
130
+ configureJobUrl: '',
140
131
  hosts: [],
141
132
  report: [],
142
133
  activeHostId: 0,
@@ -144,10 +135,12 @@ ApplicationInstanceReport.defaultProps = {
144
135
 
145
136
  ApplicationInstanceReport.propTypes = {
146
137
  initApplicationInstanceReport: PropTypes.func,
138
+ appInstanceName: PropTypes.string,
139
+ deployTaskUrl: PropTypes.string,
140
+ configureJobUrl: PropTypes.string,
147
141
  hosts: PropTypes.array,
148
142
  report: PropTypes.array,
149
- setActiveAndLoadLiveReport: PropTypes.func,
150
- setActiveAndLoadLastReport: PropTypes.func,
143
+ setActiveHost: PropTypes.func,
151
144
  activeHostId: PropTypes.number,
152
145
 
153
146
  };