Skip to content

GoObjectToTerraformString: JSON encode without HTML escaping #239

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

Closed
wants to merge 8 commits into from

Conversation

Eyal-Shalev
Copy link
Contributor

@Eyal-Shalev Eyal-Shalev commented Apr 8, 2025

Description

What - GoObjectToTerraformString: JSON encode without HTML escaping
Why - URL encoding of > and < symbols cause "inconsistent result after apply" error #222
How - Replace json.Marshal with a json.Encoder and configure SetEscapeHTML to false.

Type of change

Please leave one option from the following and delete the rest:

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • Non-breaking change (fix of existing functionality that will not change current behavior)
  • Documentation (added/updated documentation)

@Eyal-Shalev Eyal-Shalev requested a review from erikzaadi April 8, 2025 08:52
@Eyal-Shalev Eyal-Shalev self-assigned this Apr 8, 2025
Copy link

github-actions bot commented Apr 8, 2025

TestsPassed ☑️SkippedFailed ❌️Time ⏱
JUnit Test Report146 ran144 ✅0 ⚠️2 ❌26m 22s 480ms
TestResultTime ⏱
JUnit Test Report
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nil_map
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nil_*map
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nil_array
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nil_chan
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nil_*chan
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nil_slice
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nil_*slice
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nil_*string
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nested_map
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/nested_slice
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/html_unsafe_characters
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString/html_unsafe_characters_(double_escape)
com/port-labs/terraform-provider-port-labs/v2/internal/utils.TestGoObjectToTerraformString
com/port-labs/terraform-provider-port-labs/v2/port/action-permissions.TestAccPortActionPermissionsImportState18s 550ms
com/port-labs/terraform-provider-port-labs/v2/port/action-permissions.TestAccPortActionPermissionsUpdate17s 120ms
com/port-labs/terraform-provider-port-labs/v2/port/action-permissions.TestAccPortActionPermissionsWithPolicy17s 450ms
com/port-labs/terraform-provider-port-labs/v2/port/action-permissions.TestAccPortActionPermissionsBasic9s 270ms
com/port-labs/terraform-provider-port-labs/v2/port/action-permissions.TestAccPortActionWithEmptyFieldsExpectDefaultsToApply12s 890ms
com/port-labs/terraform-provider-port-labs/v2/port/action-permissions.TestAccPortActionPermissionsWithPolicyUpdate21s 550ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionObjectUserPropertiesConditional10s 690ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionJqDefault4s 140ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionKafkaInvocation13s 900ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionStringUserPropertiesConditional5s 300ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestRequiredApprovalAll11s 890ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionImport13s 830ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionOrderProperties4s 40ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionWebhookInvocation7s 790ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAutomationAnyEntityChange14s 540ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionArrayUserPropertiesConditional12s 210ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAutomationRunCreated4s 570ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionGithubInvocation6s 920ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionAzureInvocation5s 590ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionEnum10s 40ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionEnumJqQuery8s 840ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionVisibility11s 280ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestRequiredApprovalAny7s 120ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionUpdateIdentifier6s 840ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAction11s 120ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAutomationAnyRunChange17s
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionWebhookSyncInvocation10s 590ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionAdvancedFormConfigurations21s 580ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAutomationEntityDeleted6s 280ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionNoUserPropertiesConditional4s 140ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionNumberUserPropertiesConditional3s 370ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionStringGitlabMethodSetConditionally3s 670ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionRequiredFalseAndNull3s 290ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestPortActionFalseRequiredPropShouldNotWork140ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionUpsertEntityWithoutMappingIdentifier4s 730ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionStepsConflictWithOrder140ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionEncryption3s 220ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionUpsertEntityInvocationWithJqTeams3s 760ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionRequiredConflictsWithRequiredJQ5s 640ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionUpdate5s 570ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortEmailApproval3s 140ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAutomationEntityCreated12s 390ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionGitlabInvocation4s 400ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionSort11s 310ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionConditionalTrigger16s 950ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAutomationTimerPropertyExpired8s 860ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionSteps25s 130ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionUpsertEntityInvocation7s 550ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortWebhookApproval23s 890ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionBoolUserPropertiesConditional5s 50ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionBasic8s 420ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAutomationRunUpdated5s 220ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortAutomationEntityUpdated5s 440ms
com/port-labs/terraform-provider-port-labs/v2/port/aggregation-properties.TestAccPortCreateBlueprintWithAggregationByPropertyWithFilter10s 830ms
com/port-labs/terraform-provider-port-labs/v2/port/aggregation-properties.TestAccCreateAggregationPropertyAverageEntities24s 420ms
com/port-labs/terraform-provider-port-labs/v2/port/aggregation-properties.TestAccPortCreateAggregationAverageProperties21s 850ms
com/port-labs/terraform-provider-port-labs/v2/port/aggregation-properties.TestAccPortAggregationPropertyWithCycleRelation22s 420ms
com/port-labs/terraform-provider-port-labs/v2/port/aggregation-properties.TestAccMultipleAggregationPropertiesForBlueprintCreate7s 480ms
com/port-labs/terraform-provider-port-labs/v2/port/aggregation-properties.TestAccPortCreateAggregationPropertyAggregateByProperty43s 420ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint-permissions.TestAccPortBlueprintPermissionsWithInvalidProperties290ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint-permissions.TestAccPortBlueprintPermissionsBasic12s 310ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint-permissions.TestAccPortBlueprintPermissionsWithProperties12s 210ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint-permissions.TestAccPortBlueprintPermissionsWithRelations24s 180ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintCatalogPageCreation/CatalogPageCreationTrue14s 880ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintCatalogPageCreation/CatalogPageCreationFalse15s 30ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintCatalogPageCreation29s 910ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintObjectProperty4s 560ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintArrayProperty4s 990ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintOwnership14s 710ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortUpdateBlueprintIdentifier8s 430ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintBooleanProperty4s 820ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintStringProperty3s 900ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortDestroyDeleteAllEntities19s 250ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintWithCalculationProperty6s 950ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintWithChangelogDestination6s 430ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintWithRelation8s 630ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintNumberProperty11s 870ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintWithSpecification9s 420ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintWithMirrorProperty16s 970ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintBasic9s 560ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintUpdateRelation12s 760ms
com/port-labs/terraform-provider-port-labs/v2/port/blueprint.TestAccPortBlueprintImport4s 790ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityWithManyRelation16s 750ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityUpdateIdentifier19s 630ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityUpdateBlueprintIdentifier15s 320ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityWithEmptyRelation20s 690ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityWithRelation25s 140ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityWithNulls8s 380ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityWithMissingRelation20s 200ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityWithDefaultArrayProp29s 200ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntity11s 690ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityUpdateProp13s 70ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityImport11s 310ms
com/port-labs/terraform-provider-port-labs/v2/port/folder.TestAccPortFolderResourceUpdateFolder12s 80ms
com/port-labs/terraform-provider-port-labs/v2/port/folder.TestAccPortFolderResourceBasicBetaDisabled140ms
com/port-labs/terraform-provider-port-labs/v2/port/folder.TestAccPortFolderResourceBasicBetaEnabled3s 540ms
com/port-labs/terraform-provider-port-labs/v2/port/folder.TestAccPortFolderResourceImport4s 140ms
com/port-labs/terraform-provider-port-labs/v2/port/folder.TestAccPortFolderResourceCreateFolderWithParent9s 30ms
com/port-labs/terraform-provider-port-labs/v2/port/integration.TestPortIntegrationImport5s 610ms
com/port-labs/terraform-provider-port-labs/v2/port/integration.TestPortIntegrationBasic7s 650ms
com/port-labs/terraform-provider-port-labs/v2/port/integration.TestPortIntegrationPatchTitleNull6s 880ms
com/port-labs/terraform-provider-port-labs/v2/port/integration.TestPortIntegrationWithWebhook6s 810ms
com/port-labs/terraform-provider-port-labs/v2/port/page-permissions.TestAccPortPagePermissionsBasic11s 210ms
com/port-labs/terraform-provider-port-labs/v2/port/page-permissions.TestAccPortPagePermissionsImport5s 620ms
com/port-labs/terraform-provider-port-labs/v2/port/page-permissions.TestAccPortPagePermissionsUpdateWithUsers15s 150ms
com/port-labs/terraform-provider-port-labs/v2/port/page.TestAccPortPageResourceCreatePageAfterPage11s 480ms
com/port-labs/terraform-provider-port-labs/v2/port/page.TestAccPortPageResourceBasicBetaEnabled6s 730ms
com/port-labs/terraform-provider-port-labs/v2/port/page.TestAccPortPageResourceBasicBetaDisabled140ms
com/port-labs/terraform-provider-port-labs/v2/port/page.TestAccPortPageResourceCreateDashboardPage5s 920ms
com/port-labs/terraform-provider-port-labs/v2/port/scorecard.TestAccPortScorecard❌ failure2s 680ms
com/port-labs/terraform-provider-port-labs/v2/port/scorecard.TestAccPortScorecardUpdate❌ failure18s 790ms
com/port-labs/terraform-provider-port-labs/v2/port/scorecard.TestAccPortScorecardImport7s 940ms
com/port-labs/terraform-provider-port-labs/v2/port/scorecard.TestAccPortScorecardBasic7s 980ms
com/port-labs/terraform-provider-port-labs/v2/port/scorecard.TestAccPortScorecardUpdateIdentifier21s 700ms
com/port-labs/terraform-provider-port-labs/v2/port/search.TestAccPortEntityWithEmptyRelation38s 700ms
com/port-labs/terraform-provider-port-labs/v2/port/search.TestAccPortEntityWithNulls33s 430ms
com/port-labs/terraform-provider-port-labs/v2/port/search.TestAccPortEntityWithRelation1m 650ms
com/port-labs/terraform-provider-port-labs/v2/port/search.TestAccPortEntity10s 390ms
com/port-labs/terraform-provider-port-labs/v2/port/search.TestAccPortEntityUpdateProp24s 180ms
com/port-labs/terraform-provider-port-labs/v2/port/search.TestAccPortEntityWithManyRelation51s 40ms
com/port-labs/terraform-provider-port-labs/v2/port/system_blueprint.TestAccPortSystemBlueprintMirrorProperties10s 310ms
com/port-labs/terraform-provider-port-labs/v2/port/system_blueprint.TestAccPortSystemBlueprintBasic3s 980ms
com/port-labs/terraform-provider-port-labs/v2/port/system_blueprint.TestAccPortSystemBlueprintProperties5s 620ms
com/port-labs/terraform-provider-port-labs/v2/port/system_blueprint.TestAccPortSystemBlueprintRelations5s 580ms
com/port-labs/terraform-provider-port-labs/v2/port/team.TestAccPortTeam8s 880ms
com/port-labs/terraform-provider-port-labs/v2/port/team.TestAccPortTeamImport7s 210ms
com/port-labs/terraform-provider-port-labs/v2/port/team.TestAccPortTeamUpdate10s 650ms
com/port-labs/terraform-provider-port-labs/v2/port/team.TestAccPortTeamEmptyDescription20s 720ms
com/port-labs/terraform-provider-port-labs/v2/port/webhook.TestAccPortWebhookImport11s 360ms
com/port-labs/terraform-provider-port-labs/v2/port/webhook.TestAccPortWebhook5s 520ms
com/port-labs/terraform-provider-port-labs/v2/port/webhook.TestAccPortWebhookBasic7s 670ms
com/port-labs/terraform-provider-port-labs/v2/port/webhook.TestAccPortWebhookUpdateIdentifier9s 750ms
com/port-labs/terraform-provider-port-labs/v2/port/webhook.TestAccPortWebhookWithAllOperationOptions8s 620ms
TestRetriesTime ⏱
JUnit Test Report
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionObjectUserPropertiesConditional110s 690ms
com/port-labs/terraform-provider-port-labs/v2/port/action.TestAccPortActionJqDefault14s 140ms
com/port-labs/terraform-provider-port-labs/v2/port/entity.TestAccPortEntityWithManyRelation116s 750ms
com/port-labs/terraform-provider-port-labs/v2/port/team.TestAccPortTeam18s 880ms

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant