Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

appmesh: added missing nil checks on rewrite configuration properties #26012

Merged
merged 2 commits into from
Jul 28, 2022

Conversation

julada
Copy link
Contributor

@julada julada commented Jul 27, 2022

fixes the following error when using the app mesh rewrite configuration:

Stack trace from the terraform-provider-aws_v4.23.0_x5 plugin:

panic: runtime error: index out of range [0] with length 0

goroutine 403 [running]:
github.com/hashicorp/terraform-provider-aws/internal/service/appmesh.expandHTTPGatewayRouteRewrite({0xc0033f4ae0, 0xc002f78bc0, 0xa5dbe7c})
        github.com/hashicorp/terraform-provider-aws/internal/service/appmesh/gateway_route.go:783 +0x3c9
github.com/hashicorp/terraform-provider-aws/internal/service/appmesh.expandHTTPGatewayRoute({0xc0033f4a40, 0xc002f751d0, 0xa5e66c8})
        github.com/hashicorp/terraform-provider-aws/internal/service/appmesh/gateway_route.go:854 +0x195
github.com/hashicorp/terraform-provider-aws/internal/service/appmesh.expandGatewayRouteSpec({0xc0033f4a10, 0xa5d6340, 0xb78d2c0})
        github.com/hashicorp/terraform-provider-aws/internal/service/appmesh/gateway_route.go:709 +0x165
github.com/hashicorp/terraform-provider-aws/internal/service/appmesh.resourceGatewayRouteCreate(0x0, {0x90c5fc0, 0xc000f92000})
        github.com/hashicorp/terraform-provider-aws/internal/service/appmesh/gateway_route.go:498 +0x1bc
github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema.(*Resource).create(0xb78d2c0, {0xb78d2c0, 0xc0024972f0}, 0xd, {0x90c5fc0, 0xc000f92000})
        github.com/hashicorp/terraform-plugin-sdk/[email protected]/helper/schema/resource.go:695 +0x178
github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema.(*Resource).Apply(0xc000bf80e0, {0xb78d2c0, 0xc0024972f0}, 0xc003378820, 0xc00323ff00, {0x90c5fc0, 0xc000f92000})
        github.com/hashicorp/terraform-plugin-sdk/[email protected]/helper/schema/resource.go:837 +0xc29
github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema.(*GRPCProviderServer).ApplyResourceChange(0xc00020c138, {0xb78d2c0, 0xc002497170}, 0xc00327dc20)
        github.com/hashicorp/terraform-plugin-sdk/[email protected]/helper/schema/grpc_provider.go:1021 +0xe3c
github.com/hashicorp/terraform-plugin-mux/tf5muxserver.muxServer.ApplyResourceChange({0xc001b7dc80, 0xc001b7dce0, {0xc002836ee0, 0x2, 0x2}, 0xc001b7dcb0, 0xc001bac9a0, 0xc0023fb1a0, 0xc001b7dd10}, {0xb78d2c0, ...}, ...)
        github.com/hashicorp/[email protected]/tf5muxserver/mux_server_ApplyResourceChange.go:27 +0x142
github.com/hashicorp/terraform-plugin-go/tfprotov5/tf5server.(*server).ApplyResourceChange(0xc0015adcc0, {0xb78d2c0, 0xc002496510}, 0xc003339ea0)
        github.com/hashicorp/[email protected]/tfprotov5/tf5server/server.go:813 +0x551
github.com/hashicorp/terraform-plugin-go/tfprotov5/internal/tfplugin5._Provider_ApplyResourceChange_Handler({0xa31ec40, 0xc0015adcc0}, {0xb78d2c0, 0xc002496510}, 0xc003339e30, 0x0)
        github.com/hashicorp/[email protected]/tfprotov5/internal/tfplugin5/tfplugin5_grpc.pb.go:385 +0x170
google.golang.org/grpc.(*Server).processUnaryRPC(0xc00288e1c0, {0xb89f1b0, 0xc00289c680}, 0xc0033659e0, 0xc002887a10, 0x11781500, 0x0)
        google.golang.org/[email protected]/server.go:1295 +0xb03
google.golang.org/grpc.(*Server).handleStream(0xc00288e1c0, {0xb89f1b0, 0xc00289c680}, 0xc0033659e0, 0x0)
        google.golang.org/[email protected]/server.go:1636 +0xa2a
google.golang.org/grpc.(*Server).serveStreams.func1.2()
        google.golang.org/[email protected]/server.go:932 +0x98
created by google.golang.org/grpc.(*Server).serveStreams.func1
        google.golang.org/[email protected]/server.go:930 +0x294

Error: The terraform-provider-aws_v4.23.0_x5 plugin crashed!

i missed some nil checks in my last PR causing the crash on a configuration with only one of hostname rewrite or path rewrite explicitly defined like

resource "aws_appmesh_gateway_route" "test" {
  name                 = %[1]q
  mesh_name            = aws_appmesh_mesh.test.name
  virtual_gateway_name = aws_appmesh_virtual_gateway.test.name

  spec {
    http_route {
      action {
        target {
          virtual_service {
            virtual_service_name = aws_appmesh_virtual_service.test[0].name
          }
        }
        rewrite {
          hostname {
            default_target_hostname = "DISABLED"
          }
        }
      }

      match {
        prefix = "/"
      }
    }
  }
}

or

resource "aws_appmesh_gateway_route" "test" {
  name                 = %[1]q
  mesh_name            = aws_appmesh_mesh.test.name
  virtual_gateway_name = aws_appmesh_virtual_gateway.test.name

  spec {
    http_route {
      action {
        target {
          virtual_service {
            virtual_service_name = aws_appmesh_virtual_service.test[0].name
          }
        }
        rewrite {
          prefix {
            default_prefix = "DISABLED"
          }
        }
      }

      match {
        prefix = "/"
      }
    }
  }
}

explicitly set them both works without any issues in the current version

resource "aws_appmesh_gateway_route" "test" {
  name                 = %[1]q
  mesh_name            = aws_appmesh_mesh.test.name
  virtual_gateway_name = aws_appmesh_virtual_gateway.test.name

  spec {
    http_route {
      action {
        target {
          virtual_service {
            virtual_service_name = aws_appmesh_virtual_service.test[0].name
          }
        }
        rewrite {
          hostname {
            default_target_hostname = "ENABLED"
          }
          prefix {
            default_prefix = "DISABLED"
          }
        }
      }

      match {
        prefix = "/"
      }
    }
  }
}

Community Note

  • Please vote on this pull request by adding a 👍 reaction to the original pull request comment to help the community and maintainers prioritize this request
  • Please do not leave "+1" or other comments that do not add relevant new information or questions, they generate extra noise for pull request followers and do not help prioritize the request

Relates #20272

Output from acceptance testing:

TF_ACC=1 go test ./internal/service/appmesh/... -v -count 1 -parallel 20 -run='TestAccAppMesh_serial/GatewayRoute'  -timeout 180m
=== RUN   TestAccAppMesh_serial
=== RUN   TestAccAppMesh_serial/GatewayRoute
=== RUN   TestAccAppMesh_serial/GatewayRoute/http2Route
=== RUN   TestAccAppMesh_serial/GatewayRoute/tags
=== RUN   TestAccAppMesh_serial/GatewayRoute/basic
=== RUN   TestAccAppMesh_serial/GatewayRoute/disappears
=== RUN   TestAccAppMesh_serial/GatewayRoute/grpcRoute
=== RUN   TestAccAppMesh_serial/GatewayRoute/httpRoute
--- PASS: TestAccAppMesh_serial (159.89s)
    --- PASS: TestAccAppMesh_serial/GatewayRoute (159.89s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/http2Route (40.39s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/tags (31.45s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/basic (12.78s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/disappears (12.62s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/grpcRoute (23.35s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/httpRoute (39.30s)
PASS
ok      github.com/hashicorp/terraform-provider-aws/internal/service/appmesh    162.322s

...

@github-actions github-actions bot added needs-triage Waiting for first response or review from a maintainer. size/XS Managed by automation to categorize the size of a PR. service/appmesh Issues and PRs that pertain to the appmesh service. labels Jul 27, 2022
@julada julada force-pushed the bugfix/appmesh/gateway-route-rewrite branch from 4fd1807 to d24459e Compare July 28, 2022 08:23
@ewbankkit ewbankkit added bug Addresses a defect in current functionality. crash Results from or addresses a Terraform crash or kernel panic. and removed needs-triage Waiting for first response or review from a maintainer. labels Jul 28, 2022
Copy link
Contributor

@ewbankkit ewbankkit left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM 🚀.

% make testacc TESTARGS='-run=TestAccAppMesh_serial/GatewayRoute' PKG=appmesh ACCTEST_PARALLELISM=2
==> Checking that code complies with gofmt requirements...
TF_ACC=1 go test ./internal/service/appmesh/... -v -count 1 -parallel 2  -run=TestAccAppMesh_serial/GatewayRoute -timeout 180m
=== RUN   TestAccAppMesh_serial
=== RUN   TestAccAppMesh_serial/GatewayRoute
=== RUN   TestAccAppMesh_serial/GatewayRoute/http2Route
=== RUN   TestAccAppMesh_serial/GatewayRoute/tags
=== RUN   TestAccAppMesh_serial/GatewayRoute/basic
=== RUN   TestAccAppMesh_serial/GatewayRoute/disappears
=== RUN   TestAccAppMesh_serial/GatewayRoute/grpcRoute
=== RUN   TestAccAppMesh_serial/GatewayRoute/httpRoute
--- PASS: TestAccAppMesh_serial (313.75s)
    --- PASS: TestAccAppMesh_serial/GatewayRoute (313.75s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/http2Route (74.53s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/tags (59.77s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/basic (27.96s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/disappears (22.04s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/grpcRoute (46.13s)
        --- PASS: TestAccAppMesh_serial/GatewayRoute/httpRoute (83.32s)
PASS
ok  	github.com/hashicorp/terraform-provider-aws/internal/service/appmesh	317.909s

@ewbankkit
Copy link
Contributor

@julada Thanks for the contribution 🎉 👏.

@ewbankkit ewbankkit merged commit 6e1dbb1 into hashicorp:main Jul 28, 2022
@github-actions github-actions bot added this to the v4.24.0 milestone Jul 28, 2022
@github-actions
Copy link

github-actions bot commented Aug 3, 2022

This functionality has been released in v4.24.0 of the Terraform AWS Provider. Please see the Terraform documentation on provider versioning or reach out if you need any assistance upgrading.

For further feature requests or bug reports with this functionality, please create a new GitHub issue following the template. Thank you!

@github-actions
Copy link

github-actions bot commented Sep 3, 2022

I'm going to lock this pull request because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues.
If you have found a problem that seems related to this change, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Sep 3, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
bug Addresses a defect in current functionality. crash Results from or addresses a Terraform crash or kernel panic. service/appmesh Issues and PRs that pertain to the appmesh service. size/XS Managed by automation to categorize the size of a PR.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants