Skip to content

Commit a4c0db0

Browse files
committedNov 22, 2022
r/aws_mq_configuration: Add 'FindConfigurationByID'.
Acceptance test output: % make testacc TESTARGS='-run=TestAccMQConfiguration_' PKG=mq ACCTEST_PARALLELISM=2 ==> Checking that code complies with gofmt requirements... TF_ACC=1 go test ./internal/service/mq/... -v -count 1 -parallel 2 -run=TestAccMQConfiguration_ -timeout 180m === RUN TestAccMQConfiguration_basic === PAUSE TestAccMQConfiguration_basic === RUN TestAccMQConfiguration_withData === PAUSE TestAccMQConfiguration_withData === RUN TestAccMQConfiguration_withLdapData === PAUSE TestAccMQConfiguration_withLdapData === RUN TestAccMQConfiguration_tags === PAUSE TestAccMQConfiguration_tags === CONT TestAccMQConfiguration_basic === CONT TestAccMQConfiguration_withLdapData --- PASS: TestAccMQConfiguration_withLdapData (21.43s) === CONT TestAccMQConfiguration_withData --- PASS: TestAccMQConfiguration_basic (38.58s) === CONT TestAccMQConfiguration_tags --- PASS: TestAccMQConfiguration_withData (19.96s) --- PASS: TestAccMQConfiguration_tags (46.36s) PASS ok github.com/hashicorp/terraform-provider-aws/internal/service/mq 89.544s
1 parent ae931c2 commit a4c0db0

File tree

2 files changed

+132
-126
lines changed

2 files changed

+132
-126
lines changed
 

‎internal/service/mq/configuration.go

+89-43
Original file line numberDiff line numberDiff line change
@@ -5,15 +5,18 @@ import (
55
"encoding/base64"
66
"fmt"
77
"log"
8+
"strconv"
89

910
"github.com/aws/aws-sdk-go/aws"
1011
"github.com/aws/aws-sdk-go/service/mq"
1112
"github.com/hashicorp/aws-sdk-go-base/v2/awsv1shim/v2/tfawserr"
1213
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/customdiff"
14+
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
1315
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
1416
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/validation"
1517
"github.com/hashicorp/terraform-provider-aws/internal/conns"
1618
tftags "github.com/hashicorp/terraform-provider-aws/internal/tags"
19+
"github.com/hashicorp/terraform-provider-aws/internal/tfresource"
1720
"github.com/hashicorp/terraform-provider-aws/internal/verify"
1821
)
1922

@@ -97,81 +100,101 @@ func resourceConfigurationCreate(d *schema.ResourceData, meta interface{}) error
97100
defaultTagsConfig := meta.(*conns.AWSClient).DefaultTagsConfig
98101
tags := defaultTagsConfig.MergeTags(tftags.New(d.Get("tags").(map[string]interface{})))
99102

100-
input := mq.CreateConfigurationRequest{
103+
name := d.Get("name").(string)
104+
input := &mq.CreateConfigurationRequest{
101105
EngineType: aws.String(d.Get("engine_type").(string)),
102106
EngineVersion: aws.String(d.Get("engine_version").(string)),
103-
Name: aws.String(d.Get("name").(string)),
107+
Name: aws.String(name),
104108
}
105109

106110
if v, ok := d.GetOk("authentication_strategy"); ok {
107111
input.AuthenticationStrategy = aws.String(v.(string))
108112
}
113+
109114
if len(tags) > 0 {
110115
input.Tags = Tags(tags.IgnoreAWS())
111116
}
112117

113-
log.Printf("[INFO] Creating MQ Configuration: %s", input)
114-
out, err := conn.CreateConfiguration(&input)
118+
output, err := conn.CreateConfiguration(input)
119+
115120
if err != nil {
116-
return err
121+
return fmt.Errorf("creating MQ Configuration (%s): %w", name, err)
117122
}
118123

119-
d.SetId(aws.StringValue(out.Id))
120-
d.Set("arn", out.Arn)
124+
d.SetId(aws.StringValue(output.Id))
125+
126+
if v, ok := d.GetOk("data"); ok {
127+
input := &mq.UpdateConfigurationRequest{
128+
ConfigurationId: aws.String(d.Id()),
129+
Data: aws.String(base64.StdEncoding.EncodeToString([]byte(v.(string)))),
130+
}
131+
132+
if v, ok := d.GetOk("description"); ok {
133+
input.Description = aws.String(v.(string))
134+
}
135+
136+
_, err := conn.UpdateConfiguration(input)
121137

122-
return resourceConfigurationUpdate(d, meta)
138+
if err != nil {
139+
return fmt.Errorf("updating MQ Configuration (%s): %w", d.Id(), err)
140+
}
141+
}
142+
143+
return resourceConfigurationRead(d, meta)
123144
}
124145

125146
func resourceConfigurationRead(d *schema.ResourceData, meta interface{}) error {
126147
conn := meta.(*conns.AWSClient).MQConn
127148
defaultTagsConfig := meta.(*conns.AWSClient).DefaultTagsConfig
128149
ignoreTagsConfig := meta.(*conns.AWSClient).IgnoreTagsConfig
129150

130-
log.Printf("[INFO] Reading MQ Configuration %s", d.Id())
131-
out, err := conn.DescribeConfiguration(&mq.DescribeConfigurationInput{
132-
ConfigurationId: aws.String(d.Id()),
133-
})
151+
configuration, err := FindConfigurationByID(conn, d.Id())
152+
153+
if !d.IsNewResource() && tfresource.NotFound(err) {
154+
log.Printf("[WARN] MQ Configuration (%s) not found, removing from state", d.Id())
155+
d.SetId("")
156+
return nil
157+
}
158+
134159
if err != nil {
135-
if tfawserr.ErrCodeEquals(err, mq.ErrCodeNotFoundException) {
136-
log.Printf("[WARN] MQ Configuration %q not found, removing from state", d.Id())
137-
d.SetId("")
138-
return nil
139-
}
140-
return err
160+
return fmt.Errorf("reading MQ Configuration (%s): %w", d.Id(), err)
141161
}
142162

143-
d.Set("arn", out.Arn)
144-
d.Set("authentication_strategy", out.AuthenticationStrategy)
145-
d.Set("description", out.LatestRevision.Description)
146-
d.Set("engine_type", out.EngineType)
147-
d.Set("engine_version", out.EngineVersion)
148-
d.Set("latest_revision", out.LatestRevision.Revision)
149-
d.Set("name", out.Name)
163+
d.Set("arn", configuration.Arn)
164+
d.Set("authentication_strategy", configuration.AuthenticationStrategy)
165+
d.Set("description", configuration.LatestRevision.Description)
166+
d.Set("engine_type", configuration.EngineType)
167+
d.Set("engine_version", configuration.EngineVersion)
168+
d.Set("latest_revision", configuration.LatestRevision.Revision)
169+
d.Set("name", configuration.Name)
150170

151-
rOut, err := conn.DescribeConfigurationRevision(&mq.DescribeConfigurationRevisionInput{
171+
revision := strconv.FormatInt(aws.Int64Value(configuration.LatestRevision.Revision), 10)
172+
configurationRevision, err := conn.DescribeConfigurationRevision(&mq.DescribeConfigurationRevisionInput{
152173
ConfigurationId: aws.String(d.Id()),
153-
ConfigurationRevision: aws.String(fmt.Sprintf("%d", *out.LatestRevision.Revision)),
174+
ConfigurationRevision: aws.String(revision),
154175
})
176+
155177
if err != nil {
156-
return err
178+
return fmt.Errorf("reading MQ Configuration (%s) revision (%s): %w", d.Id(), revision, err)
157179
}
158180

159-
b, err := base64.StdEncoding.DecodeString(*rOut.Data)
181+
data, err := base64.StdEncoding.DecodeString(aws.StringValue(configurationRevision.Data))
182+
160183
if err != nil {
161-
return err
184+
return fmt.Errorf("base64 decoding: %w", err)
162185
}
163186

164-
d.Set("data", string(b))
187+
d.Set("data", string(data))
165188

166-
tags := KeyValueTags(out.Tags).IgnoreAWS().IgnoreConfig(ignoreTagsConfig)
189+
tags := KeyValueTags(configuration.Tags).IgnoreAWS().IgnoreConfig(ignoreTagsConfig)
167190

168191
//lintignore:AWSR002
169192
if err := d.Set("tags", tags.RemoveDefaultConfig(defaultTagsConfig).Map()); err != nil {
170-
return fmt.Errorf("error setting tags: %w", err)
193+
return fmt.Errorf("setting tags: %w", err)
171194
}
172195

173196
if err := d.Set("tags_all", tags.Map()); err != nil {
174-
return fmt.Errorf("error setting tags_all: %w", err)
197+
return fmt.Errorf("setting tags_all: %w", err)
175198
}
176199

177200
return nil
@@ -181,35 +204,58 @@ func resourceConfigurationUpdate(d *schema.ResourceData, meta interface{}) error
181204
conn := meta.(*conns.AWSClient).MQConn
182205

183206
if d.HasChanges("data", "description") {
184-
rawData := d.Get("data").(string)
185-
data := base64.StdEncoding.EncodeToString([]byte(rawData))
186-
187-
input := mq.UpdateConfigurationRequest{
207+
input := &mq.UpdateConfigurationRequest{
188208
ConfigurationId: aws.String(d.Id()),
189-
Data: aws.String(data),
209+
Data: aws.String(base64.StdEncoding.EncodeToString([]byte(d.Get("data").(string)))),
190210
}
211+
191212
if v, ok := d.GetOk("description"); ok {
192213
input.Description = aws.String(v.(string))
193214
}
194215

195-
log.Printf("[INFO] Updating MQ Configuration %s: %s", d.Id(), input)
196-
_, err := conn.UpdateConfiguration(&input)
216+
_, err := conn.UpdateConfiguration(input)
217+
197218
if err != nil {
198-
return err
219+
return fmt.Errorf("updating MQ Configuration (%s): %w", d.Id(), err)
199220
}
200221
}
201222

202223
if d.HasChange("tags_all") {
203224
o, n := d.GetChange("tags_all")
204225

205226
if err := UpdateTags(conn, d.Get("arn").(string), o, n); err != nil {
206-
return fmt.Errorf("error updating MQ Broker (%s) tags: %s", d.Get("arn").(string), err)
227+
return fmt.Errorf("updating MQ Configuration (%s) tags: %w", d.Get("arn").(string), err)
207228
}
208229
}
209230

210231
return resourceConfigurationRead(d, meta)
211232
}
212233

234+
func FindConfigurationByID(conn *mq.MQ, id string) (*mq.DescribeConfigurationOutput, error) {
235+
input := &mq.DescribeConfigurationInput{
236+
ConfigurationId: aws.String(id),
237+
}
238+
239+
output, err := conn.DescribeConfiguration(input)
240+
241+
if tfawserr.ErrCodeEquals(err, mq.ErrCodeNotFoundException) {
242+
return nil, &resource.NotFoundError{
243+
LastError: err,
244+
LastRequest: input,
245+
}
246+
}
247+
248+
if err != nil {
249+
return nil, err
250+
}
251+
252+
if output == nil {
253+
return nil, tfresource.NewEmptyResultError(input)
254+
}
255+
256+
return output, nil
257+
}
258+
213259
func suppressXMLEquivalentConfig(k, old, new string, d *schema.ResourceData) bool {
214260
os, err := CanonicalXML(old)
215261
if err != nil {

0 commit comments

Comments
 (0)