-
Notifications
You must be signed in to change notification settings - Fork 4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into nodejs-absolute-findup
- Loading branch information
Showing
10 changed files
with
325 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
44 changes: 44 additions & 0 deletions
44
packages/@aws-cdk/aws-stepfunctions-tasks/lib/stepfunctions/invoke-activity.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
import * as iam from '@aws-cdk/aws-iam'; | ||
import * as sfn from '@aws-cdk/aws-stepfunctions'; | ||
import * as cdk from '@aws-cdk/core'; | ||
|
||
/** | ||
* Properties for invoking an Activity worker | ||
*/ | ||
export interface StepFunctionsInvokeActivityProps extends sfn.TaskStateBaseProps { | ||
|
||
/** | ||
* Step Functions Activity to invoke | ||
*/ | ||
readonly activity: sfn.IActivity | ||
} | ||
|
||
/** | ||
* A Step Functions Task to invoke an Activity worker. | ||
* | ||
* An Activity can be used directly as a Resource. | ||
*/ | ||
export class StepFunctionsInvokeActivity extends sfn.TaskStateBase { | ||
protected readonly taskMetrics?: sfn.TaskMetricsConfig; | ||
// No IAM permissions necessary, execution role implicitly has Activity permissions. | ||
protected readonly taskPolicies?: iam.PolicyStatement[]; | ||
|
||
constructor(scope: cdk.Construct, id: string, private readonly props: StepFunctionsInvokeActivityProps) { | ||
super(scope, id, props); | ||
|
||
this.taskMetrics = { | ||
metricDimensions: { ActivityArn: this.props.activity.activityArn }, | ||
metricPrefixSingular: 'Activity', | ||
metricPrefixPlural: 'Activities', | ||
}; | ||
} | ||
|
||
/** | ||
* @internal | ||
*/ | ||
protected _renderTask(): any { | ||
return { | ||
Resource: this.props.activity.activityArn, | ||
}; | ||
} | ||
} |
85 changes: 85 additions & 0 deletions
85
...s/@aws-cdk/aws-stepfunctions-tasks/test/stepfunctions/integ.invoke-activity.expected.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,85 @@ | ||
{ | ||
"Resources": { | ||
"SubmitJobFB773A16": { | ||
"Type": "AWS::StepFunctions::Activity", | ||
"Properties": { | ||
"Name": "awsstepfunctionsintegSubmitJobA2508960" | ||
} | ||
}, | ||
"CheckJob5FFC1D6F": { | ||
"Type": "AWS::StepFunctions::Activity", | ||
"Properties": { | ||
"Name": "awsstepfunctionsintegCheckJobC4AC762D" | ||
} | ||
}, | ||
"StateMachineRoleB840431D": { | ||
"Type": "AWS::IAM::Role", | ||
"Properties": { | ||
"AssumeRolePolicyDocument": { | ||
"Statement": [ | ||
{ | ||
"Action": "sts:AssumeRole", | ||
"Effect": "Allow", | ||
"Principal": { | ||
"Service": { | ||
"Fn::Join": [ | ||
"", | ||
[ | ||
"states.", | ||
{ | ||
"Ref": "AWS::Region" | ||
}, | ||
".amazonaws.com" | ||
] | ||
] | ||
} | ||
} | ||
} | ||
], | ||
"Version": "2012-10-17" | ||
} | ||
} | ||
}, | ||
"StateMachine2E01A3A5": { | ||
"Type": "AWS::StepFunctions::StateMachine", | ||
"Properties": { | ||
"RoleArn": { | ||
"Fn::GetAtt": [ | ||
"StateMachineRoleB840431D", | ||
"Arn" | ||
] | ||
}, | ||
"DefinitionString": { | ||
"Fn::Join": [ | ||
"", | ||
[ | ||
"{\"StartAt\":\"Submit Job\",\"States\":{\"Submit Job\":{\"Next\":\"Wait X Seconds\",\"Type\":\"Task\",\"ResultPath\":\"$.guid\",\"Resource\":\"", | ||
{ | ||
"Ref": "SubmitJobFB773A16" | ||
}, | ||
"\"},\"Wait X Seconds\":{\"Type\":\"Wait\",\"SecondsPath\":\"$.wait_time\",\"Next\":\"Get Job Status\"},\"Get Job Status\":{\"Next\":\"Job Complete?\",\"Type\":\"Task\",\"InputPath\":\"$.guid\",\"ResultPath\":\"$.status\",\"Resource\":\"", | ||
{ | ||
"Ref": "CheckJob5FFC1D6F" | ||
}, | ||
"\"},\"Job Complete?\":{\"Type\":\"Choice\",\"Choices\":[{\"Variable\":\"$.status\",\"StringEquals\":\"FAILED\",\"Next\":\"Job Failed\"},{\"Variable\":\"$.status\",\"StringEquals\":\"SUCCEEDED\",\"Next\":\"Get Final Job Status\"}],\"Default\":\"Wait X Seconds\"},\"Job Failed\":{\"Type\":\"Fail\",\"Error\":\"DescribeJob returned FAILED\",\"Cause\":\"AWS Batch Job Failed\"},\"Get Final Job Status\":{\"End\":true,\"Type\":\"Task\",\"InputPath\":\"$.guid\",\"Resource\":\"", | ||
{ | ||
"Ref": "CheckJob5FFC1D6F" | ||
}, | ||
"\"}},\"TimeoutSeconds\":300}" | ||
] | ||
] | ||
} | ||
}, | ||
"DependsOn": [ | ||
"StateMachineRoleB840431D" | ||
] | ||
} | ||
}, | ||
"Outputs": { | ||
"stateMachineArn": { | ||
"Value": { | ||
"Ref": "StateMachine2E01A3A5" | ||
} | ||
} | ||
} | ||
} |
69 changes: 69 additions & 0 deletions
69
packages/@aws-cdk/aws-stepfunctions-tasks/test/stepfunctions/integ.invoke-activity.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
import * as sfn from '@aws-cdk/aws-stepfunctions'; | ||
import * as cdk from '@aws-cdk/core'; | ||
import * as tasks from '../../lib'; | ||
|
||
/* | ||
* Creates a state machine with a job poller sample project | ||
* https://docs.aws.amazon.com/step-functions/latest/dg/sample-project-job-poller.html | ||
* | ||
* Stack verification steps: | ||
* The generated State Machine can be executed from the CLI (or Step Functions console) | ||
* and runs with an execution status of `Running`. | ||
* | ||
* An external process can call the state machine to send a heartbeat or response before it times out. | ||
* | ||
* -- aws stepfunctions start-execution --state-machine-arn <state-machine-arn-from-output> provides execution arn | ||
* -- aws stepfunctions describe-execution --execution-arn <state-machine-arn-from-output> returns a status of `Running` | ||
* | ||
* CHANGEME: extend this test to create the external resources to report heartbeats | ||
*/ | ||
class InvokeActivityStack extends cdk.Stack { | ||
constructor(scope: cdk.App, id: string, props: cdk.StackProps = {}) { | ||
super(scope, id, props); | ||
|
||
const submitJobActivity = new sfn.Activity(this, 'SubmitJob'); | ||
const checkJobActivity = new sfn.Activity(this, 'CheckJob'); | ||
|
||
const submitJob = new tasks.StepFunctionsInvokeActivity(this, 'Submit Job', { | ||
activity: submitJobActivity, | ||
resultPath: '$.guid', | ||
}); | ||
const waitX = new sfn.Wait(this, 'Wait X Seconds', { time: sfn.WaitTime.secondsPath('$.wait_time') }); | ||
const getStatus = new tasks.StepFunctionsInvokeActivity(this, 'Get Job Status', { | ||
activity: checkJobActivity, | ||
inputPath: '$.guid', | ||
resultPath: '$.status', | ||
}); | ||
const isComplete = new sfn.Choice(this, 'Job Complete?'); | ||
const jobFailed = new sfn.Fail(this, 'Job Failed', { | ||
cause: 'AWS Batch Job Failed', | ||
error: 'DescribeJob returned FAILED', | ||
}); | ||
const finalStatus = new tasks.StepFunctionsInvokeActivity(this, 'Get Final Job Status', { | ||
activity: checkJobActivity, | ||
inputPath: '$.guid', | ||
}); | ||
|
||
const chain = sfn.Chain | ||
.start(submitJob) | ||
.next(waitX) | ||
.next(getStatus) | ||
.next(isComplete | ||
.when(sfn.Condition.stringEquals('$.status', 'FAILED'), jobFailed) | ||
.when(sfn.Condition.stringEquals('$.status', 'SUCCEEDED'), finalStatus) | ||
.otherwise(waitX)); | ||
|
||
const sm = new sfn.StateMachine(this, 'StateMachine', { | ||
definition: chain, | ||
timeout: cdk.Duration.seconds(300), | ||
}); | ||
|
||
new cdk.CfnOutput(this, 'stateMachineArn', { | ||
value: sm.stateMachineArn, | ||
}); | ||
} | ||
} | ||
|
||
const app = new cdk.App(); | ||
new InvokeActivityStack(app, 'aws-stepfunctions-integ'); | ||
app.synth(); |
Oops, something went wrong.