Skip to content

Commit

Permalink
Merge pull request #4965 from saravanan30erd/issue-4906
Browse files Browse the repository at this point in the history
aws_ses_receipt_rule fails when kms_key_arn is not specified
  • Loading branch information
bflad authored Jun 25, 2018
2 parents f6af939 + f73b7c1 commit 0229b93
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 3 deletions.
12 changes: 9 additions & 3 deletions aws/resource_aws_ses_receipt_rule.go
Original file line number Diff line number Diff line change
Expand Up @@ -683,9 +683,15 @@ func buildReceiptRule(d *schema.ResourceData, meta interface{}) *ses.ReceiptRule
elem := element.(map[string]interface{})

s3Action := &ses.S3Action{
BucketName: aws.String(elem["bucket_name"].(string)),
KmsKeyArn: aws.String(elem["kms_key_arn"].(string)),
ObjectKeyPrefix: aws.String(elem["object_key_prefix"].(string)),
BucketName: aws.String(elem["bucket_name"].(string)),
}

if elem["kms_key_arn"] != "" {
s3Action.KmsKeyArn = aws.String(elem["kms_key_arn"].(string))
}

if elem["object_key_prefix"] != "" {
s3Action.ObjectKeyPrefix = aws.String(elem["object_key_prefix"].(string))
}

if elem["topic_arn"] != "" {
Expand Down
44 changes: 44 additions & 0 deletions aws/resource_aws_ses_receipt_rule_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,24 @@ func TestAccAWSSESReceiptRule_basic(t *testing.T) {
})
}

func TestAccAWSSESReceiptRule_s3Action(t *testing.T) {
resource.Test(t, resource.TestCase{
PreCheck: func() {
testAccPreCheck(t)
},
Providers: testAccProviders,
CheckDestroy: testAccCheckSESReceiptRuleDestroy,
Steps: []resource.TestStep{
resource.TestStep{
Config: testAccAWSSESReceiptRuleS3ActionConfig,
Check: resource.ComposeTestCheckFunc(
testAccCheckAwsSESReceiptRuleExists("aws_ses_receipt_rule.basic"),
),
},
},
})
}

func TestAccAWSSESReceiptRule_order(t *testing.T) {
resource.Test(t, resource.TestCase{
PreCheck: func() {
Expand Down Expand Up @@ -244,6 +262,32 @@ resource "aws_ses_receipt_rule" "basic" {
}
`, srrsRandomInt)

var testAccAWSSESReceiptRuleS3ActionConfig = fmt.Sprintf(`
resource "aws_ses_receipt_rule_set" "test" {
rule_set_name = "test-me-%d"
}
resource "aws_s3_bucket" "emails" {
bucket = "ses-terraform-emails-%d"
acl = "public-read-write"
force_destroy = "true"
}
resource "aws_ses_receipt_rule" "basic" {
name = "basic"
rule_set_name = "${aws_ses_receipt_rule_set.test.rule_set_name}"
recipients = ["[email protected]"]
enabled = true
scan_enabled = true
tls_policy = "Require"
s3_action {
bucket_name = "${aws_s3_bucket.emails.id}"
position = 1
}
}
`, srrsRandomInt, srrsRandomInt)

var testAccAWSSESReceiptRuleOrderConfig = fmt.Sprintf(`
resource "aws_ses_receipt_rule_set" "test" {
rule_set_name = "test-me-%d"
Expand Down

0 comments on commit 0229b93

Please sign in to comment.