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

fix: order of widgets on page matters #2531

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

ilakhtenkov
Copy link

@ilakhtenkov ilakhtenkov commented Jan 8, 2024

Description

Fixing issue: Order of widgets in page of newrelic_one_dashboard matters.
Before change: change of order of widgets in page {} block creating terraform diff and resources recreation.
After change: Reorder of widgets in page {} block detected by terraform and not producing diff.

Important!
This change is WIP, currently it is only implemented for widget_markdown. For other widgets default parameters and hash functions should be adopted. As this work requested large amount of work. I want to hear contributors feedback first if they found this change useful and it could be potentially integrated.

Fixes #1720, #1452

Type of change

Please delete options that are not relevant.

  • 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). TODO: Need to be tested.
  • This change requires a documentation update

Checklist:

Please delete options that are not relevant.

  • My commit message follows conventional commits
  • My code is formatted to Go standards
  • I have performed a self-review of my own code
  • I have made corresponding changes to the documentation
  • I have added tests that prove my fix is effective or that my feature works
  • New and existing unit tests pass locally with my changes. Go here for instructions on running tests locally.

How to test this change?

TODO: Run tests for all widgets, Run tests for providers update
Test Terraform code:

locals {
  iteration_map = {
    0 = {
      text = "first element"
    }
    1 = {
      text = "second element"
    }
  }
}

resource "newrelic_one_dashboard" "exampledash" {
  name        = "New Relic Terraform Diff Test"
  permissions = "public_read_only"

  page {
    name = "New Relic Terraform Example"
    dynamic "widget_markdown" {
      for_each = local.iteration_map
      content {
        title  = "1-${widget_markdown.key} Dashboard Note"
          column = 1
          width  = 3
          height = 3
          row    = 1 + widget_markdown.key
          text = "This is awesome text for: ${widget_markdown.value["text"]}"
      }
    }
    dynamic "widget_markdown" {
      for_each = local.iteration_map
      content {
        title  = "2-${widget_markdown.key} Dashboard Note"
          column = 4
          width  = 3
          height = 3
          row    = 1 + widget_markdown.key
          text = "This is another awesome text for: ${widget_markdown.value["text"]}"
      }
    }

  }
}

Steps:

  1. Apply terraform code
  2. Run terraform plan and ensure that there is no diff
  3. Change one element of iteration_map
  4. Run terraform plan and ensure that only widgets related to the changed map element are producing diff.
  5. Apply changes and make sure that applied without errors.

@CLAassistant
Copy link

CLAassistant commented Jan 8, 2024

CLA assistant check
All committers have signed the CLA.

@pranav-new-relic
Copy link
Member

pranav-new-relic commented Jan 8, 2024

Hi @ilakhtenkov - thank you for contributing code towards this issue! This has been around for quite some time now; while we had briefly explored the path you've tried (converting lists into sets and subsequent changes), we haven't been able to take it up completely owing to subsequent blockers we'd seen and time constraints to get them fixed, as we were (and are currently) juggling a couple of features, maintenance, EOLs and more.

However, this can mostly get it working, so I'd suggest you to continue contributing to this further, after which I can have myself and the team review this PR; I'm certain we can get it integrated, unless this has any unexpected repercussions or causes newer issues. To be sure about this (as one of the ways to test your code changes) I'd recommend you to try making regular changes to your Terraform configuration (not relating to this issue) after the first terraform apply, such as, changing the values of arguments, e.g. row, and then trying a terraform plan to make sure these changes do not lead to any unforeseen drift.

Looking forward to your full-fledged contribution. Thank you!

@sanderblue sanderblue force-pushed the main branch 2 times, most recently from 23a73db to 4f7b20e Compare May 7, 2024 14:29
@FlareLine
Copy link

FlareLine commented Dec 12, 2024

Hey team,

Just wondering if this PR is still in the works? This is directly affecting our use of the provider and there is currently no workaround for our use case.

We generate pages and widget dynamically based on a custom variable model (so that not everything is defined in a single file) and there is currently no way to maintain the order of widgets returned from API calls from the provider.

It also doesn't look like the API is returning widgets in row/column order either, as it'll randomly order rows in the JSON it returns.

@ilakhtenkov if you're not looking to take up this PR anymore I'm happy to take a look and try to implement the changes myself.

@ilakhtenkov
Copy link
Author

Hey team,

Just wondering if this PR is still in the works? This is directly affecting our use of the provider and there is currently no workaround for our use case.

We generate pages and widget dynamically based on a custom variable model (so that not everything is defined in a single file) and there is currently no way to maintain the order of widgets returned from API calls from the provider.

It also doesn't look like the API is returning widgets in row/column order either, as it'll randomly order rows in the JSON it returns.

@ilakhtenkov if you're not looking to take up this PR anymore I'm happy to take a look and try to implement the changes myself.

Hi @FlareLine. This issue is still affecting my team. Unfortunately I have not had time to finish this up. Basically was done and working as expected I just need to rebase. The large part is unit tests that I will try to come to during xmass holidays. Manual testing of provider after I would push the final version of the code would be a really great help.

@ilakhtenkov ilakhtenkov marked this pull request as ready for review December 27, 2024 14:56
@ilakhtenkov
Copy link
Author

Hi @FlareLine I was looking at the issue today and it is not reproducable for me in version 3.53.0. Could you please confirm that this is still issue for you on the latest version.

@FlareLine
Copy link

Hey @ilakhtenkov, I'll have a look when I'm back at work - currently on holidays so I'll shoot through some results when I can 😁

@toddmbcrowley
Copy link

Using provider newrelic/newrelic v3.53.0 and dynamic widget_billboard blocks, there is constant change drift in terraform plan. The dashboard in terraform state appears to be ordered by row number. This is inconsistent with the dynamic terraform blocks in the dashboard resource.

Given the following redacted dynamic blocks:

    dynamic "widget_billboard" {
      for_each = local.sla_dashboard
      content {
        title  = "title1 - ${widget_billboard.key}"
        row    = index(keys(local.sla_dashboard), widget_billboard.key) + 1
        column = 1
        width  = 3
        height = 3
        nrql_query {
          query = ""
        }
      }
    }

    dynamic "widget_billboard" {
      for_each = local.sla_dashboard
      content {
        title  = "title2 - ${widget_billboard.key}"
        row    = index(keys(local.sla_dashboard), widget_billboard.key) + 1
        column = 4
        width  = 3
        height = 3
        nrql_query {
          query = ""
        }
      }
    }

    dynamic "widget_line" {
      for_each = local.sla_dashboard
      content {
        title  = "title - ${widget_line.key}"
        row    = index(keys(local.sla_dashboard), widget_line.key) + 1
        column           = 7
        width            = 6
        height           = 3
        y_axis_left_zero = false
        nrql_query {
          query = ""
        }
      }
    }

The terraform state for the widget_billboard blocks is stored as:

        widget_billboard {
            column                  = 1
            height                  = 3
            row                     = 1
            width                   = 3
            title                   = "title1 - key1"
        }
        widget_billboard {
            column                  = 4
            height                  = 3
            row                     = 1
            width                   = 3
            title                   = "title2 - key1"
        }
        widget_billboard {
            column                  = 1
            height                  = 3
            row                     = 2
            width                   = 3
            title                   = "title1 - key2"
        }
        widget_billboard {
            column                  = 4
            height                  = 3
            row                     = 2
            width                   = 3
            title                   = "title2 - key2"
        }
        widget_billboard {
            column                  = 1
            height                  = 3
            width                   = 3
            row                     = 3
            title                   = "title1 - key3"
        }
        widget_billboard {
            column                  = 4
            height                  = 3
            row                     = 3
            width                   = 3
            title                   = "title2 - key3"
        }

To match state the expected widget order would be:

"title1 - key1"
"title1 - key2"
"title1 - key3"
"title2 - key1"
"title2 - key2"
"title2 - key3"

This staggers each dynamic widget_billboard resource, causing the state to always be out of sync with what terraform computes at plan or apply.

This is not an issue for the dynamic widget_line resource, assuming because there is only one widget_line block defined.

@FlareLine
Copy link

@ilakhtenkov it looks like this issue is still occurring for me, even on the latest 3.54.0 version of the provider. Is this still something you're running into, or have the issue you were seeing disappeared?

@toddmbcrowley
Copy link

Confirmed the issue posted in #2531 (comment) is still occuring in v3.54.0

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.

Dynamic blocks do not fix the order in which listings are processed
5 participants