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

[Index Patterns] Use deprecation api for scripted fields #100781

Merged

Conversation

Dosant
Copy link
Contributor

@Dosant Dosant commented May 27, 2021

Summary

Close #97947
Scripted fields are deprecated. Runtime fields should be used instead. This pr adds information about this to the upgrade assistant. It hasn't been decided when scripted fields will be removed yet, hence keeping this as warning.

Screen Shot 2021-05-28 at 15 54 09
Screen Shot 2021-05-28 at 15 54 13

Release notes

Add scripted fields depreciation information to upgrade assistant

Checklist

For maintainers

How to test

I viewed upgrade assistant UI by tweaking the condition in the code

if (isReadOnlyMode) {
return <ComingSoonPrompt />;
}
. Current functional test doesn't test the UI #100781 (comment), but it calls upgrade assistant API and checks that there is a part about scripted fields

@Dosant Dosant added Feature:Data Views Data Views code and UI - index patterns before 8.0 Feature:Scripted Fields Scripted fields features release_note:deprecation Team:AppServices v7.14.0 v8.0.0 labels May 27, 2021
if (indexPatternsWithScriptedFields.length > 0) {
// no need to look up all index patterns since we've found at least one that has scripted fields
await finder.close();
break;
Copy link
Contributor Author

Choose a reason for hiding this comment

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

I intentionally don't fetch all index patterns to make this function cheaper. This is reflected in the wording of the message below: You have **at least** <n> index patterns...

Copy link
Contributor

Choose a reason for hiding this comment

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

I think we should show a full list of index patterns that need updating as some setups may have a large number of index patterns and only a few might have scripted fields. We need a way to deliminate the index patterns as they can have commas in them. Could we link directly to the index patterns?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Could we link directly to the index patterns?

Nope, as I understand we can only use plain text.

At this moment this pr shows at max 3 index pattern titles as a hint.

  1. Do you think we should show more out from the page? (e.g. in the current implementation we can remove that .slice(0,3) where I prepare the message
  2. Or do you think we should fetch all the index patterns and show the whole list no matter how long it is?

In the current implementation user can:

  1. Take a look at a message, see up to 3 index pattern titles that need to be fixed
  2. Fix them
  3. If there are more to fix, see another 3 index pattern titles and fix them

Not ideal, but not sure we want to fetch all the index patterns?

Copy link
Contributor Author

@Dosant Dosant May 28, 2021

Choose a reason for hiding this comment

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

I updated so in the main message we show just up to 3 index pattern titles, but then when you open dialog with details we list all of them!

correctiveActions: {
manualSteps: [
'Navigate to Stack Management > Kibana > Index Patterns.',
`Update index patterns that have scripted fields (${indexPatternsTitlesHelp}...) to use runtime fields instead. In most cases, to migrate existing scripts, changing "return <value>;" to "emit(<value>);" would be enough.`,
Copy link
Contributor Author

Choose a reason for hiding this comment

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

Might need some help with wording

Copy link
Contributor

Choose a reason for hiding this comment

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

There's going to be a blog post about this shortly, lets update this text once its available

@Dosant Dosant marked this pull request as ready for review May 27, 2021 15:02
@Dosant Dosant requested a review from a team as a code owner May 27, 2021 15:02
@elasticmachine
Copy link
Contributor

Pinging @elastic/kibana-app-services (Team:AppServices)

@Dosant Dosant requested review from mattkime and a team May 27, 2021 15:02
correctiveActions: {
manualSteps: [
'Navigate to Stack Management > Kibana > Index Patterns.',
`Update index patterns that have scripted fields (${indexPatternsTitlesHelp}...) to use runtime fields instead. In most cases, to migrate existing scripts, changing "return <value>;" to "emit(<value>);" would be enough.`,
Copy link
Contributor

Choose a reason for hiding this comment

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

There's going to be a blog post about this shortly, lets update this text once its available

if (indexPatternsWithScriptedFields.length > 0) {
// no need to look up all index patterns since we've found at least one that has scripted fields
await finder.close();
break;
Copy link
Contributor

Choose a reason for hiding this comment

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

I think we should show a full list of index patterns that need updating as some setups may have a large number of index patterns and only a few might have scripted fields. We need a way to deliminate the index patterns as they can have commas in them. Could we link directly to the index patterns?

@mattkime
Copy link
Contributor

'data' is using a deprecated feature is an odd statement to show the user. Are we able to change this? Did core create this API? Would be nice if this could be improved.

Comment on lines 23 to 29
const finder = context.savedObjectsClient.createPointInTimeFinder<IndexPatternAttributesWithFields>(
{
type: 'index-pattern',
perPage: 100,
fields: ['title', 'fields'],
}
);
Copy link
Contributor

Choose a reason for hiding this comment

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

@Bamieh do you think we should introduce some kind of caching in the deprecation service? atm everytime the /api/deprecations route is called, all the deprecation providers are executed, and I wonder if this will be alright when we'll have a lot that are performing ES requests like this one. wdyt?

Copy link
Contributor Author

@Dosant Dosant May 28, 2021

Choose a reason for hiding this comment

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

If we do, not sure how it will work exactly? It is likely that with the cashing in place the use case I expressed in e2e testtest/api_integration/apis/index_patterns/deprecations/scripted_fields.ts might break?

Copy link
Contributor Author

@Dosant Dosant May 28, 2021

Choose a reason for hiding this comment

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

Also @pgayvallet, I think having so many index patterns is more of an edge case and inside the app we simply currently do

const so = await this.savedObjectsClient.find<IndexPatternSavedObjectAttrs>({
type: 'index-pattern',
fields: ['title'],
perPage: 10000,
});

Copy link
Contributor

Choose a reason for hiding this comment

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

@Dosant this should not impact this PR, I was more wondering about long-term performances.

Copy link
Member

@Bamieh Bamieh Jun 1, 2021

Choose a reason for hiding this comment

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

Initially i had caching in place for the service but it didnt make sense to keep it. The API is called only at the user's request when they open the UA or explicitly via the API. Generic caching wont work since we do not want to return already resolved deprecations from the api. We always want the latest state of the deprecations.

For performance it might make sense to introduce pagination rather than caching. The service would paginate the kibana deprecations so we dont have to loop over all deprecations every time. Since the deprecations are registered at setup in an array we can guarantee the order and create basic pagination from the public contract.

I agree with @pgayvallet this doesnt impact the PR. I'll open a separate issue to continue the discussion there.

@Dosant
Copy link
Contributor Author

Dosant commented May 28, 2021

@mattkime: 'data' is using a deprecated feature is an odd statement to show the user. Are we able to change this? Did core create this API? Would be nice if this could be improved.

I think we can't change this atm

Dosant added 2 commits May 28, 2021 15:08
…cation-api-for-index-pattern

# Conflicts:
#	test/api_integration/apis/index_patterns/index.js
@Dosant Dosant requested a review from mattkime May 28, 2021 14:04
@mattkime
Copy link
Contributor

mattkime commented May 28, 2021

I'm talking to @alisonelizabeth to see how this could be tested by QA. The UI for the deprecation service might not be available until 7.15. Considering how to proceed.


Looks good and works well, waiting to hear from Alison about how we want this to go through QA.

@Bamieh
Copy link
Member

Bamieh commented Jun 1, 2021

'data' is using a deprecated feature is an odd statement to show the user. Are we able to change this? Did core create this API? Would be nice if this could be improved.

@mattkime we have this issue to improve this #99625

Looks good and works well, waiting to hear from Alison about how we want this to go through QA.

I'm trying to address this as well (context: #99043 (comment))

The service provided by core is testable although we do need UA to provide some tools to allow teams to run functional tests for their deprecations in the UA UI

@mattkime
Copy link
Contributor

mattkime commented Jun 7, 2021

@elasticmachine merge upstream

kibanamachine and others added 4 commits June 7, 2021 10:38
…cation-api-for-index-pattern

# Conflicts:
#	test/api_integration/apis/index_patterns/index.js
…m:Dosant/kibana into dev/use-deprecation-api-for-index-pattern
@mattkime
Copy link
Contributor

@elasticmachine merge upstream

@mattkime
Copy link
Contributor

@Dosant Do you know where we are on getting this merged? I know we were waiting for a flag to be able to test this without recompiling.

@spalger spalger added v7.15.0 and removed v7.14.0 labels Jun 30, 2021
@mattkime
Copy link
Contributor

mattkime commented Jul 5, 2021

@elasticmachine merge upstream

@Dosant
Copy link
Contributor Author

Dosant commented Jul 7, 2021

@elasticmachine merge upstream

@kibanamachine
Copy link
Contributor

💚 Build Succeeded

Metrics [docs]

✅ unchanged

History

To update your PR or re-run it, just comment with:
@elasticmachine merge upstream

@Dosant Dosant added the auto-backport Deprecated - use backport:version if exact versions are needed label Jul 7, 2021
@Dosant Dosant merged commit 44d4d23 into elastic:master Jul 7, 2021
kibanamachine pushed a commit to kibanamachine/kibana that referenced this pull request Jul 7, 2021
@kibanamachine
Copy link
Contributor

💚 Backport successful

Status Branch Result
7.x

This backport PR will be merged automatically after passing CI.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
auto-backport Deprecated - use backport:version if exact versions are needed Feature:Data Views Data Views code and UI - index patterns before 8.0 Feature:Scripted Fields Scripted fields features release_note:deprecation v7.15.0 v8.0.0
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Index patterns / scripted fields - use deprecation api
7 participants