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

🐛 (explorer) merge configs correctly #4091

Merged
merged 1 commit into from
Nov 6, 2024

Conversation

sophiamersmann
Copy link
Member

@sophiamersmann sophiamersmann commented Oct 29, 2024

Problem

Explorers incorrectly merge (partial) Grapher configs with explorer-level Grapher settings.

We naively merge configs like this

{
   ...partialGrapherConfig,
   ...explorerProgram.grapherConfigOnlyGrapherProps
}

where partialGrapherConfig is the indicator config (of type GrapherInterface), but explorerProgram.grapherConfigOnlyGrapherProps is of type ExplorerGrapherInterface that includes explorer-flavoured flat config fields, like yAxisMin. Overwriting the y-axis min of the partial Grapher config, which is given as yAxis.min, thus won't work.

Bug

I don't know of an example in the wild where this currently leads to a problem, but you can fabricate a bug locally by following these steps:

Set yAxis.min of an indicator that is used in the conflict explorer by running

update chart_configs cc
join variables v on cc.id = v.grapherConfigIdETL
set
  cc.patch = JSON_MERGE_PATCH(cc.patch, '{"yAxis":{"min": 1}}'),
  cc.full = JSON_MERGE_PATCH(cc.full, '{"yAxis":{"min": 1}}')
where v.id = 985431

against your local database.

Navigate to this view of the conflict explorer. Note that

// the partial grapher config sets y-axis min to 1
explorer.partialGrapherConfigsByVariableId.get(985431).yAxis.min // = 1

// the explorer overwrites this by setting yAxis.min to 0
explorer.explorerProgram.grapherConfig.yAxisMin // = 0

// the y-axis min being used in Grapher is 1, but should be 0
// i.e. the explorer settings didn't successfully overwrite the indicator settings
grapher.yAxis.min // = 1, but should be 0

I ran the same query against the database on staging. You'll see that on staging Grapher's y-axis min is correctly set to 0 (staging).

Solution

Before the explorer's Grapher config gets merged with the partial config, we translate explorer-specific fields to valid GrapherInterface fields, e.g. yAxisMin is translated to { yAxis: { min: ... } }. This is defined by the toGrapherObject function of an explorer cell definition.

The toGrapherObject function is conceptually similar to the parse function. Alternatively, I could have reworked the parse function so that the given key/value pair is always parsed as a valid GrapherInterface object. Maybe that would have been the cleaner solution? I'm not sure. In the end, I went with the toGrapherObject function because I thought it would be useful to keep both Grapher row representations around:

  • explorerGrapherConfig: explorer-flavoured settings that directly map to a Grapher row
  • grapherConfig: corresponding chart config that is guaranteed to be a valid GrapherInterface

Testing

Since I don't know of any bugs in the wild (doesn't mean they don't exist though), these changes should not result in any visual changes.

@owidbot
Copy link
Contributor

owidbot commented Oct 30, 2024

Quick links (staging server):

Site Admin Wizard

Login: ssh owid@staging-site-fix-explorer-config-merge

SVG tester:

Number of differences (default views): 0 ✅
Number of differences (all views): 0 ✅

Edited: 2024-10-30 12:03:55 UTC
Execution time: 1.15 seconds

@sophiamersmann sophiamersmann force-pushed the fix-explorer-config-merge branch 5 times, most recently from c6b0715 to 3597b31 Compare October 30, 2024 15:54
@sophiamersmann sophiamersmann force-pushed the fix-explorer-config-merge branch 5 times, most recently from 7d455e6 to adf0264 Compare October 31, 2024 16:12
@sophiamersmann sophiamersmann changed the base branch from master to log-explorer-views October 31, 2024 16:12
@sophiamersmann sophiamersmann force-pushed the fix-explorer-config-merge branch from adf0264 to a3b1e38 Compare October 31, 2024 16:13
@sophiamersmann sophiamersmann force-pushed the fix-explorer-config-merge branch from a3b1e38 to fce4f27 Compare November 1, 2024 10:11
@sophiamersmann sophiamersmann marked this pull request as ready for review November 1, 2024 10:12
@sophiamersmann sophiamersmann changed the base branch from log-explorer-views to graphite-base/4091 November 1, 2024 15:19
@sophiamersmann sophiamersmann force-pushed the fix-explorer-config-merge branch from fce4f27 to 26ae780 Compare November 4, 2024 14:38
@sophiamersmann sophiamersmann changed the base branch from graphite-base/4091 to master November 4, 2024 14:38
Copy link
Member

@marcelgerber marcelgerber left a comment

Choose a reason for hiding this comment

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

Nice, well spotted and good work!

@sophiamersmann sophiamersmann force-pushed the fix-explorer-config-merge branch from 26ae780 to cc4dcf3 Compare November 6, 2024 12:59
@sophiamersmann sophiamersmann merged commit 93b2635 into master Nov 6, 2024
15 of 17 checks passed
@sophiamersmann sophiamersmann deleted the fix-explorer-config-merge branch November 6, 2024 15:26
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.

3 participants