Skip to content

Commit

Permalink
add: workflows.stepCompleted and workflwows.stepFailed
Browse files Browse the repository at this point in the history
  • Loading branch information
nakatanakatana committed May 6, 2022
1 parent 0e14c9d commit 9d70564
Show file tree
Hide file tree
Showing 2 changed files with 109 additions and 0 deletions.
74 changes: 74 additions & 0 deletions workflow_step_execute.go
@@ -0,0 +1,74 @@
package slack

import (
"context"
"encoding/json"
)

type (
WorkflowStepCompletedRequest struct {
WorkflowStepExecuteID string `json:"workflow_step_execute_id"`
Outputs *map[string]string `json:"outputs"`
}

WorkflowStepFailedRequest struct {
WorkflowStepExecuteID string `json:"workflow_step_execute_id"`
Error struct {
Message string `json:"message"`
} `json:"error"`
}
)

// WorkflowStepCompleted indicates step is completed
func (api *Client) WorkflowStepCompleted(workflowStepExecuteID string, outputs *map[string]string) error {
// More information: https://api.slack.com/methods/workflows.stepCompleted
r := WorkflowStepCompletedRequest{
WorkflowStepExecuteID: workflowStepExecuteID,
}
if outputs != nil {
r.Outputs = outputs
}

endpoint := api.endpoint + "workflows.stepCompleted"
jsonData, err := json.Marshal(r)
if err != nil {
return err
}

response := &SlackResponse{}
if err := postJSON(context.Background(), api.httpclient, endpoint, api.token, jsonData, response, api); err != nil {
return err
}

if !response.Ok {
return response.Err()
}

return nil
}

// WorkflowStepFailed indicates step is failed
func (api *Client) WorkflowStepFailed(workflowStepExecuteID string, errorMessage string) error {
// More information: https://api.slack.com/methods/workflows.stepFailed
r := WorkflowStepFailedRequest{
WorkflowStepExecuteID: workflowStepExecuteID,
}
r.Error.Message = errorMessage

endpoint := api.endpoint + "workflows.stepFailed"
jsonData, err := json.Marshal(r)
if err != nil {
return err
}

response := &SlackResponse{}
if err := postJSON(context.Background(), api.httpclient, endpoint, api.token, jsonData, response, api); err != nil {
return err
}

if !response.Ok {
return response.Err()
}

return nil
}
35 changes: 35 additions & 0 deletions workflow_step_execute_test.go
@@ -0,0 +1,35 @@
package slack

import (
"encoding/json"
"net/http"
"testing"
)

func workflowStepHandler(rw http.ResponseWriter, r *http.Request) {
rw.Header().Set("Content-Type", "application/json")
response, _ := json.Marshal(SlackResponse{
Ok: true,
})
rw.Write(response)
}

func TestWorkflowStepCompleted(t *testing.T) {
http.HandleFunc("/workflows.stepCompleted", workflowStepHandler)
once.Do(startServer)
api := New("testing-token", OptionAPIURL("http://"+serverAddr+"/"))

if err := api.WorkflowStepCompleted("executeID", nil); err != nil {
t.Errorf("Unexpected error: %s", err)
}
}

func TestWorkflowStepFailed(t *testing.T) {
http.HandleFunc("/workflows.stepFailed", workflowStepHandler)
once.Do(startServer)
api := New("testing-token", OptionAPIURL("http://"+serverAddr+"/"))

if err := api.WorkflowStepFailed("executeID", "error message"); err != nil {
t.Errorf("Unexpected error: %s", err)
}
}

0 comments on commit 9d70564

Please sign in to comment.