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
|
package v2
import (
"fmt"
"testing"
"github.com/gophercloud/gophercloud"
"github.com/gophercloud/gophercloud/acceptance/tools"
"github.com/gophercloud/gophercloud/openstack/workflow/v2/executions"
"github.com/gophercloud/gophercloud/openstack/workflow/v2/workflows"
th "github.com/gophercloud/gophercloud/testhelper"
)
// CreateExecution creates an execution for the given workflow.
func CreateExecution(t *testing.T, client *gophercloud.ServiceClient, workflow *workflows.Workflow) (*executions.Execution, error) {
executionDescription := tools.RandomString("execution_", 5)
t.Logf("Attempting to create execution: %s", executionDescription)
createOpts := executions.CreateOpts{
ID: executionDescription,
WorkflowID: workflow.ID,
WorkflowNamespace: workflow.Namespace,
Description: executionDescription,
Input: map[string]interface{}{
"msg": "Hello World!",
},
}
execution, err := executions.Create(client, createOpts).Extract()
if err != nil {
return execution, err
}
t.Logf("Execution created: %s", executionDescription)
th.AssertEquals(t, execution.Description, executionDescription)
t.Logf("Wait for execution status SUCCESS: %s", executionDescription)
th.AssertNoErr(t, tools.WaitFor(func() (bool, error) {
latest, err := executions.Get(client, execution.ID).Extract()
if err != nil {
return false, err
}
if latest.State == "SUCCESS" {
execution = latest
return true, nil
}
if latest.State == "ERROR" {
return false, fmt.Errorf("Execution in ERROR state")
}
return false, nil
}))
t.Logf("Execution success: %s", executionDescription)
return execution, nil
}
// DeleteExecution deletes an execution.
func DeleteExecution(t *testing.T, client *gophercloud.ServiceClient, execution *executions.Execution) {
err := executions.Delete(client, execution.ID).ExtractErr()
if err != nil {
t.Fatalf("Unable to delete executions %s: %v", execution.Description, err)
}
t.Logf("Deleted executions: %s", execution.Description)
}
// ListExecutions lists the executions.
func ListExecutions(t *testing.T, client *gophercloud.ServiceClient, opts executions.ListOptsBuilder) ([]executions.Execution, error) {
allPages, err := executions.List(client, opts).AllPages()
if err != nil {
t.Fatalf("Unable to list executions: %v", err)
}
executionsList, err := executions.ExtractExecutions(allPages)
if err != nil {
t.Fatalf("Unable to extract executions: %v", err)
}
t.Logf("Executions list find, length: %d", len(executionsList))
return executionsList, err
}
|