From 733c1be7f5983cdd9e8089a8088b235ba21a4dee Mon Sep 17 00:00:00 2001 From: Hiroki Osame Date: Thu, 8 Mar 2018 06:15:35 -1000 Subject: [PATCH] fix(inject): use hasOwn instead of 'in' for provideKey check (#7460) fix #7284 * fix(Injection with Symbol polyfill): hasOwn instead of 'in' Symbol polyfill adds a setter on the Object prototype so the 'in' check evaluated to true on every object * test(Injected properties): Ensures prototype properties aren't injected Prototype properties were being injected, so injecting 'constructor' would have hit the first provide-layer and not yield expected results. --- src/core/instance/inject.js | 3 ++- test/unit/features/options/inject.spec.js | 12 ++++++++++++ 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/src/core/instance/inject.js b/src/core/instance/inject.js index 019026479e..cb14cfeb05 100644 --- a/src/core/instance/inject.js +++ b/src/core/instance/inject.js @@ -3,6 +3,7 @@ import { warn } from '../util/index' import { hasSymbol } from 'core/util/env' import { defineReactive, observerState } from '../observer/index' +import { hasOwn } from 'shared/util' export function initProvide (vm: Component) { const provide = vm.$options.provide @@ -52,7 +53,7 @@ export function resolveInject (inject: any, vm: Component): ?Object { const provideKey = inject[key].from let source = vm while (source) { - if (source._provided && provideKey in source._provided) { + if (source._provided && hasOwn(source._provided, provideKey)) { result[key] = source._provided[provideKey] break } diff --git a/test/unit/features/options/inject.spec.js b/test/unit/features/options/inject.spec.js index cd5c7097f3..53f55e1ecf 100644 --- a/test/unit/features/options/inject.spec.js +++ b/test/unit/features/options/inject.spec.js @@ -635,4 +635,16 @@ describe('Options provide/inject', () => { expect(injected).toEqual('foo') }) + + // #7284 + it('should not inject prototype properties', () => { + const vm = new Vue({ + provide: {} + }) + new Vue({ + parent: vm, + inject: ['constructor'] + }) + expect(`Injection "constructor" not found`).toHaveBeenWarned() + }) })