# es/no-promise-prototype-finally

disallow the Promise.prototype.finally method

  • ✅ The following configurations enable this rule: plugin:es/no-new-in-es2018, plugin:es/restrict-to-es3, plugin:es/restrict-to-es5, plugin:es/restrict-to-es2015, plugin:es/restrict-to-es2016, and plugin:es/restrict-to-es2017

This rule reports ES2018 Promise.prototype.finally method (opens new window) as errors.

This rule is silent by default because it's hard to know types. You need to configure the aggressive mode or TypeScript in order to enable this rule.

# 💡 Examples

⛔ Examples of incorrect code for this rule:

/*eslint es/no-promise-prototype-finally: [error, { aggressive: true }] */ doSomethingAsync().finally(dispose)
Now loading...

# 🔧 Options

This rule has an option.

rules:
  es/no-promise-prototype-finally: [error, { aggressive: false }]

# aggressive: boolean

Configure the aggressive mode for only this rule. This is prior to the settings.es.aggressive setting.

# 📚 References