Bulk Actions
Overview
Bulk actions are a common extension point within Enterprise Tester, exposed as features of the grid (normally a button, or selection field and button combination).
Bulk actions can be invoked asynchronously by issuing a POST request to the backgroundtasks collection resource, with the configuration information including the command being invoked passed in the Parameters collection, as show in the example below:
{ "Type": "bulkaction", "Parameters": { "commandName": "BulkCopy", "scenarioName": "BulkCopyScriptsScenario", "targetId": "ab1bd3c3-f30b-43b2-82e2-a07e0133511c", "targetType": "TestScriptPackage", "targetPackageId": "ab1bd3c3-f30b-43b2-82e2-a07e0133511c", "sourcePackageId": "4016f35b-817f-459e-8533-9fc8015335c8", "projectId": "c651ed19-5375-475a-a539-9f6401467130", "selections":[ {"Id":"0a02cb6d-4afa-463c-a6df-9fe400b7d8fc","Type":"TestScript"}, {"Id":"0a675d09-78cd-463e-a600-9fc80153481b","Type":"TestScript"} ], "retainStructure":true } }
If we pull apart the above request we can see that we are:
- Invoking the command "BulkCopy".
- Invoking the command scenario "BulkCopyScriptsScenario" - many commands have more then one associated scenario, and you must use the scenario applicable to your source and target package type, and the type of items you have selected.
- For move and copy operations there needs to be a target and source package (targetPackageId and sourcePackageId) - the source package is used as the "Root" of the bulk copy/move operation so that retain structure can calculate what folders are required.
- In the above example, our targetType and targetId is the same as the targetPackage.
- The selected items to copy "selections" - each selection features an Id and a Type (any type which is supported in TQL as a valid EntityType alias will work here i.e. Script and TestScript will both be treated as a TestScript entity type).
- "retainStructure" - which is a parameter specific to bulk/copy move to retain the packages related to the sourcePackage when copying to the targetPackage.
Available commands
- Bulk Assign (AssignBulkActionScenario)
- Bulk Copy (BulkCopyAssignmentsScenario, BulkCopyRequirementsScenario, BulkCopyScriptsScenario)
- Bulk Create Assignments (BulkCreateScriptAssignmentsScenario)
- Bulk Create Scripts (BulkCreateScriptsScenario)
- Bulk Create Scripts From Agile Runs (BulkCreateScriptsFromAgileRunsScenario)
- Bulk Move (BulkMoveAssignmentsScenario, BulkMoveRequirementsScenario, BulkMoveScriptsScenario)
- Export (CSV)
- Traceability (CSV)
- Update Script Statuses (UpdateScriptStatusBulkActionScenario)
CSV Export command
The CSV Export command is an example of an action which has a payload (an exported file) which you can download after completing the action - first, here is an example of a CSV export task being created:
{ "Type": "bulkaction", "Parameters": { "scenarioName": "CSV", "encoding": "UTF8", "delimiter": "comma", "onlyVisibleColumns": false, "includeHeader": true, "includeSteps": true, "includeStepsResults": true, "query": "Name ~ export", "exportAll": true, "commandName": "Export" } }
As a result of creating this task, the response will indicate where the task updates can be fetched from via GET using the "Self" URL:
{ "Complete": false, "TotalElements": 0, "ProcessedElements": 0, "StartedAt": "2012-07-03T12:16:30Z", "ProgressInPercent": 0.0, "Id": "bulkaction_Export_CSV_56065c63-cdf7-4285-ab10-321646317be8", "Message": null, "Self": "http://localhost:29840/api/backgroundtask/bulkaction_Export_CSV_56065c63-cdf7-4285-ab10-321646317be8" }
When the task has completed, fetching the task will include in it's response details of the where you can then download the exported file from (indicated in the "exportedfile" link).
{ "Complete": true, "StartedAt": "2012-07-03T12:16:30Z", "FinishedAt": "2012-07-03T12:16:30Z", "ProgressInPercent": 1.0, "Id": "bulkaction_Export_CSV_56065c63-cdf7-4285-ab10-321646317be8", "Message": "Completed", "TotalTimeToExecute": "0s", "FileName": "export-Entities-2012-07-04-121630am.csv", "ContentType": "text/csv", "Encoding": "UTF8", "Self": "http://localhost:29840/api/backgroundtask/bulkaction_Export_CSV_56065c63-cdf7-4285-ab10-321646317be8", "Links": [ { "Href": "http://localhost:29840/api/exportfile/export-Entities-2012-07-04-121630am.csv", "Rel": "exportedfile" } ] }