Documentation ¶
Overview ¶
CDK Integration Testing Constructs
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func IntegTestCase_IsConstruct ¶
func IntegTestCase_IsConstruct(x interface{}) *bool
Checks if `x` is a construct.
Returns: true if `x` is an object created from a class which extends `Construct`. Deprecated: use `x instanceof Construct` instead.
func NewIntegTestCase_Override ¶
func NewIntegTestCase_Override(i IntegTestCase, scope constructs.Construct, id *string, props *IntegTestCaseProps)
Experimental.
Types ¶
type IntegTestCase ¶
type IntegTestCase interface { constructs.Construct // The tree node. // Experimental. Node() constructs.Node // Returns a string representation of this construct. // Experimental. ToString() *string }
An integration test case.
Allows the definition of test properties that apply to all stacks under this case.
Example:
type stackUnderTestProps struct { stackProps architecture architecture } type stackUnderTest struct { stack } func newStackUnderTest(scope construct, id *string, props stackUnderTestProps) *stackUnderTest { this := &stackUnderTest{} newStack_Override(this, scope, id, props) lambda.NewFunction(this, jsii.String("Handler"), &functionProps{ runtime: lambda.runtime_NODEJS_12_X(), handler: jsii.String("index.handler"), code: lambda.code.fromAsset(path.join(__dirname, jsii.String("lambda-handler"))), architecture: props.architecture, }) return this } // Beginning of the test suite app := NewApp() stack := NewStack(app, jsii.String("stack")) NewIntegTestCase(stack, jsii.String("DifferentArchitectures"), &integTestCaseProps{ stacks: []*stack{ NewStackUnderTest(app, jsii.String("Stack1"), &stackUnderTestProps{ architecture: lambda.*architecture_ARM_64(), }), NewStackUnderTest(app, jsii.String("Stack2"), &stackUnderTestProps{ architecture: lambda.*architecture_X86_64(), }), }, })
Experimental.
func NewIntegTestCase ¶
func NewIntegTestCase(scope constructs.Construct, id *string, props *IntegTestCaseProps) IntegTestCase
Experimental.
type IntegTestCaseProps ¶
type IntegTestCaseProps struct { // List of CloudFormation resource types in this stack that can be destroyed as part of an update without failing the test. // // This list should only include resources that for this specific // integration test we are sure will not cause errors or an outage if // destroyed. For example, maybe we know that a new resource will be created // first before the old resource is destroyed which prevents any outage. // // e.g. ['AWS::IAM::Role'] // Experimental. AllowDestroy *[]*string `json:"allowDestroy" yaml:"allowDestroy"` // Additional options to use for each CDK command. // Experimental. CdkCommandOptions *cloudassemblyschema.CdkCommands `json:"cdkCommandOptions" yaml:"cdkCommandOptions"` // Whether or not to include asset hashes in the diff Asset hashes can introduces a lot of unneccessary noise into tests, but there are some cases where asset hashes _should_ be included. // // For example // any tests involving custom resources or bundling. // Experimental. DiffAssets *bool `json:"diffAssets" yaml:"diffAssets"` // Additional commands to run at predefined points in the test workflow. // // e.g. { postDeploy: ['yarn', 'test'] } // Experimental. Hooks *cloudassemblyschema.Hooks `json:"hooks" yaml:"hooks"` // Limit deployment to these regions. // Experimental. Regions *[]*string `json:"regions" yaml:"regions"` // Run update workflow on this test case This should only be set to false to test scenarios that are not possible to test as part of the update workflow. // Experimental. StackUpdateWorkflow *bool `json:"stackUpdateWorkflow" yaml:"stackUpdateWorkflow"` // Stacks to be deployed during the test. // Experimental. Stacks *[]awscdk.Stack `json:"stacks" yaml:"stacks"` }
Properties of an integration test case.
Example:
type stackUnderTestProps struct { stackProps architecture architecture } type stackUnderTest struct { stack } func newStackUnderTest(scope construct, id *string, props stackUnderTestProps) *stackUnderTest { this := &stackUnderTest{} newStack_Override(this, scope, id, props) lambda.NewFunction(this, jsii.String("Handler"), &functionProps{ runtime: lambda.runtime_NODEJS_12_X(), handler: jsii.String("index.handler"), code: lambda.code.fromAsset(path.join(__dirname, jsii.String("lambda-handler"))), architecture: props.architecture, }) return this } // Beginning of the test suite app := NewApp() stack := NewStack(app, jsii.String("stack")) NewIntegTestCase(stack, jsii.String("DifferentArchitectures"), &integTestCaseProps{ stacks: []*stack{ NewStackUnderTest(app, jsii.String("Stack1"), &stackUnderTestProps{ architecture: lambda.*architecture_ARM_64(), }), NewStackUnderTest(app, jsii.String("Stack2"), &stackUnderTestProps{ architecture: lambda.*architecture_X86_64(), }), }, })
Experimental.
Click to show internal directories.
Click to hide internal directories.