diff --git a/addon-test-support/create.js b/addon-test-support/create.js index 73f4eb0a..045378b9 100644 --- a/addon-test-support/create.js +++ b/addon-test-support/create.js @@ -1,4 +1,5 @@ import Ceibo from 'ceibo'; +import { deprecate } from '@ember/application/deprecations'; import { render, setContext, removeContext } from './-private/context'; import { assign, getPageObjectDefinition, isPageObject, storePageObjectDefinition } from './-private/helpers'; import { visitable } from './properties/visitable'; @@ -63,7 +64,7 @@ function buildObject(node, blueprintKey, blueprint, defaultBuilder) { definition = getPageObjectDefinition(blueprint); } else { Object.getOwnPropertyNames(blueprint).forEach((key) => { - const { get } = Object.getOwnPropertyDescriptor(blueprint, key); + const { get, value } = Object.getOwnPropertyDescriptor(blueprint, key); if (typeof get === 'function') { Object.defineProperty(blueprint, key, { @@ -72,6 +73,14 @@ function buildObject(node, blueprintKey, blueprint, defaultBuilder) { get } }); + } else { + deprecate('do not use string values on definitions', + typeof value !== 'string' || ['scope', 'testContainer'].includes(key), { + id: 'ember-cli-page-object.string-properties-on-definition', + until: "2.0.0", + url: 'https://ember-cli-page-object.js.org/docs/v1.17.x/deprecations/#string-properties-on-definition', + } + ) } }); diff --git a/guides/deprecations.md b/guides/deprecations.md index 97552149..6f7c205d 100644 --- a/guides/deprecations.md +++ b/guides/deprecations.md @@ -5,6 +5,46 @@ title: Deprecations This is a list of deprecations introduced in 1.x cycle: +## String properties on definition + +**ID**: ember-cli-page-object.string-properties-on-definition + +**Until**: 2.0.0 + +In v2 any strings inside definitions, other than `scope` and `testContainer`, would be treated as a `scope`. + +Please make sure you don't have plain strings embedded into your definitions. + +Bad: + +```js +import { create, is } from 'ember-cli-page-object'; + +const page = create({ + scope: 'input', + + propertyName: 'I will become a nested component scope' +}); +``` + +If you really need your definition to keep a string, use getter instead: + +Good: + +```js +import { create, is } from 'ember-cli-page-object'; + +const page = create({ + scope: 'input', + + get propertyName() { + return 'I will not become a scope :('; + } +}); +``` + + + ## Is property **ID**: ember-cli-page-object.is-property diff --git a/tests/integration/deprecations/string-properties-test.js b/tests/integration/deprecations/string-properties-test.js new file mode 100644 index 00000000..6ff8e31c --- /dev/null +++ b/tests/integration/deprecations/string-properties-test.js @@ -0,0 +1,41 @@ +import { module, test } from 'qunit'; +import { create } from 'ember-cli-page-object'; +import require from 'require'; + +if (require.has('@ember/test-helpers')) { + module('Deprecation | string-properties', function() { + test('works at top-level', function(assert) { + this.page = create({ + stringProp: '' + }); + + assert.expectDeprecation() + }); + + test('works for nested definitions', function(assert) { + this.page = create({ + nested: { + stringProp: '' + } + }); + + assert.expectDeprecation() + }); + + test('allows scope', function(assert) { + this.page = create({ + scope: '' + }); + + assert.expectNoDeprecation() + }); + + test('allows testContainer', function(assert) { + this.page = create({ + testContainer: '' + }); + + assert.expectNoDeprecation() + }); + }); +}