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

internal/plugintest pkg (formerly terraform-plugin-test) #578

Merged
merged 4 commits into from
Sep 30, 2020
Merged

Conversation

kmoe
Copy link
Member

@kmoe kmoe commented Sep 11, 2020

Include terraform-plugin-test as an internal package, called internal/plugintest. After this is merged I will import relevant issues and PRs from the tftest repository and archive or transfer it.

Remove the Require* versions of the Terraform functions, as these are not necessary.

internal/plugintest/plugin.go Outdated Show resolved Hide resolved
helper/resource/testing_new.go Outdated Show resolved Hide resolved
@kmoe kmoe requested review from paddycarver and a team September 14, 2020 10:31
Copy link
Contributor

@paddycarver paddycarver left a comment

Choose a reason for hiding this comment

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

LGTM, let's do it!

@paddycarver
Copy link
Contributor

Ugh, I messed up the branch by resolving conflicts, oops, one sec. Going to try to fix it.

We don't actually use this helper anywhere, and it was incompatible with
v1.5.0 of go-getter, for reasons.
@paddycarver
Copy link
Contributor

@kmoe I fixed, and it's merge-ready. I had to drop the symlinkAuxiliaryProviders helper in internal/plugintest/helper.go, because it wasn't compatible with go-getter v1.5.0, which we need for a security fix. I couldn't find any instance of us using it, and it was internal and unexported, so I considered it dead code. Please let me know if I've done a wrong thing. Otherwise, feel free to hit the merge button if my changes look good to you. :)

@kmoe kmoe merged commit 651b26a into master Sep 30, 2020
@kmoe kmoe deleted the plugintest-pkg branch September 30, 2020 15:00
bflad added a commit to bflad/terraform-plugin-sdk that referenced this pull request Oct 3, 2020
Reference: hashicorp#578
Reference: hashicorp#604

Restores v2.0.3 behavior and renames the function slightly for additional clarity on its intent.

Previously with consistently failing provider check:

```
=== CONT  TestAccAWSDmsReplicationTask_basic
TestAccAWSDmsReplicationTask_basic: resource_aws_dms_replication_task_test.go:18: Step 1/3 error: After applying this test step, the plan was not empty.
stdout:
{"format_version":"0.1","terraform_version":"0.12.29","planned_values":{"root_module":{"resources":[{"address":"aws_dms_endpoint.dms_endpoint_source","mode":"managed","type":"aws_dms_endpoint","name":"dms_endpoint_source","provider_name":"aws","schema_version":0,"values":{"certificate_arn":"","database_name":"tf-test-dms-db","elasticsearch_settings":[],"endpoint_arn":"arn:aws:dms:us-west-2:*******:endpoint:JIH35DGCIVAHLVA4L3H7S2QJKNIMW5K2X7LDSAY","endpoint_id":"tf-test-dms-endpoint-source-0qkeppvm","endpoint_type":"source","engine_name":"aurora","extra_connection_attributes":"","id":"tf-test-dms-endpoint-source-0qkeppvm","kafka_settings":[],"kinesis_settings":[],"kms_key_arn":"arn:aws:kms:us-west-2:*******:key/f5709827-76e0-4544-b2ec-9d09d1138bb1","mongodb_settings":[],"password":"tftest","port":3306,"s3_settings":[],"server_name":"tf-test-cluster.cluster-xxxxxxx.us-west-2.rds.amazonaws.com","service_access_role":null,"ssl_mode":"none","tags":null,"username":"tftest"}},{"address":"aws_dms_endpoint.dms_endpoint_target","mode":"managed","type":"aws_dms_endpoint","name":"dms_endpoint_target","provider_name":"aws","schema_version":0,"values":{"certificate_arn":"","database_name":"tf-test-dms-db","elasticsearch_settings":[],"endpoint_arn":"arn:...........
```

Now with local Go Module replace directive:

```
=== CONT  TestAccAWSDmsReplicationTask_basic
    resource_aws_dms_replication_task_test.go:18: Step 1/3 error: After applying this test step, the plan was not empty.
        stdout:

        An execution plan has been generated and is shown below.
        Resource actions are indicated with the following symbols:
          ~ update in-place

        Terraform will perform the following actions:

          # aws_dms_replication_task.dms_replication_task will be updated in-place
          ~ resource "aws_dms_replication_task" "dms_replication_task" {
                id                        = "tf-test-dms-replication-task-qsk63z02"
                migration_type            = "full-load"
                replication_instance_arn  = "arn:aws:dms:us-west-2:--OMITTED--:rep:AZCTZFYYTBQUNMNFP3LDR3A5RAC44QTLT36UC4I"
                replication_task_arn      = "arn:aws:dms:us-west-2:--OMITTED--:task:YS3DREABEI2X4KW46QHESNSZIBOAZXU4WLIPH5I"
                replication_task_id       = "tf-test-dms-replication-task-qsk63z02"
              ~ replication_task_settings = jsonencode(
                  ~ {
```
paddycarver pushed a commit that referenced this pull request Oct 6, 2020
Reference: #578
Reference: #604

Restores v2.0.3 behavior and renames the function slightly for additional clarity on its intent.

Previously with consistently failing provider check:

```
=== CONT  TestAccAWSDmsReplicationTask_basic
TestAccAWSDmsReplicationTask_basic: resource_aws_dms_replication_task_test.go:18: Step 1/3 error: After applying this test step, the plan was not empty.
stdout:
{"format_version":"0.1","terraform_version":"0.12.29","planned_values":{"root_module":{"resources":[{"address":"aws_dms_endpoint.dms_endpoint_source","mode":"managed","type":"aws_dms_endpoint","name":"dms_endpoint_source","provider_name":"aws","schema_version":0,"values":{"certificate_arn":"","database_name":"tf-test-dms-db","elasticsearch_settings":[],"endpoint_arn":"arn:aws:dms:us-west-2:*******:endpoint:JIH35DGCIVAHLVA4L3H7S2QJKNIMW5K2X7LDSAY","endpoint_id":"tf-test-dms-endpoint-source-0qkeppvm","endpoint_type":"source","engine_name":"aurora","extra_connection_attributes":"","id":"tf-test-dms-endpoint-source-0qkeppvm","kafka_settings":[],"kinesis_settings":[],"kms_key_arn":"arn:aws:kms:us-west-2:*******:key/f5709827-76e0-4544-b2ec-9d09d1138bb1","mongodb_settings":[],"password":"tftest","port":3306,"s3_settings":[],"server_name":"tf-test-cluster.cluster-xxxxxxx.us-west-2.rds.amazonaws.com","service_access_role":null,"ssl_mode":"none","tags":null,"username":"tftest"}},{"address":"aws_dms_endpoint.dms_endpoint_target","mode":"managed","type":"aws_dms_endpoint","name":"dms_endpoint_target","provider_name":"aws","schema_version":0,"values":{"certificate_arn":"","database_name":"tf-test-dms-db","elasticsearch_settings":[],"endpoint_arn":"arn:...........
```

Now with local Go Module replace directive:

```
=== CONT  TestAccAWSDmsReplicationTask_basic
    resource_aws_dms_replication_task_test.go:18: Step 1/3 error: After applying this test step, the plan was not empty.
        stdout:

        An execution plan has been generated and is shown below.
        Resource actions are indicated with the following symbols:
          ~ update in-place

        Terraform will perform the following actions:

          # aws_dms_replication_task.dms_replication_task will be updated in-place
          ~ resource "aws_dms_replication_task" "dms_replication_task" {
                id                        = "tf-test-dms-replication-task-qsk63z02"
                migration_type            = "full-load"
                replication_instance_arn  = "arn:aws:dms:us-west-2:--OMITTED--:rep:AZCTZFYYTBQUNMNFP3LDR3A5RAC44QTLT36UC4I"
                replication_task_arn      = "arn:aws:dms:us-west-2:--OMITTED--:task:YS3DREABEI2X4KW46QHESNSZIBOAZXU4WLIPH5I"
                replication_task_id       = "tf-test-dms-replication-task-qsk63z02"
              ~ replication_task_settings = jsonencode(
                  ~ {
```
@ghost
Copy link

ghost commented Oct 31, 2020

I'm going to lock this issue 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 similar to this, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further.

@ghost ghost locked as resolved and limited conversation to collaborators Oct 31, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants