Ref,
readonly,
reactive,
- defineComponent
+ defineComponent,
+ hasInjectionContext
} from '../src/index'
-import { render, nodeOps, serialize } from '@vue/runtime-test'
+import { render, nodeOps, serialize, createApp } from '@vue/runtime-test'
// reference: https://vue-composition-api-rfc.netlify.com/api.html#provide-inject
describe('api: provide/inject', () => {
render(h(Comp), root)
expect(serialize(root)).toBe(`<div><!----></div>`)
})
+
+ describe('hasInjectionContext', () => {
+ it('should be false outside of setup', () => {
+ expect(hasInjectionContext()).toBe(false)
+ })
+
+ it('should be true within setup', () => {
+ expect.assertions(1)
+ const Comp = {
+ setup() {
+ expect(hasInjectionContext()).toBe(true)
+ return () => null
+ }
+ }
+
+ const root = nodeOps.createElement('div')
+ render(h(Comp), root)
+ })
+
+ it('should be true within app.runWithContext()', () => {
+ expect.assertions(1)
+ createApp({}).runWithContext(() => {
+ expect(hasInjectionContext()).toBe(true)
+ })
+ })
+ })
})
warn(`inject() can only be used inside setup() or functional components.`)
}
}
+
+/**
+ * Returns true if `inject()` can be used without warning about being called in the wrong place (e.g. outside of
+ * setup()). This is used by libraries that want to use `inject()` internally without triggering a warning to the end
+ * user. One example is `useRoute()` in `vue-router`.
+ */
+export function hasInjectionContext(): boolean {
+ return !!(currentInstance || currentRenderingInstance || currentApp)
+}
onErrorCaptured,
onServerPrefetch
} from './apiLifecycle'
-export { provide, inject } from './apiInject'
+export { provide, inject, hasInjectionContext } from './apiInject'
export { nextTick } from './scheduler'
export { defineComponent } from './apiDefineComponent'
export { defineAsyncComponent } from './apiAsyncComponent'