From c7f2b8f2a7f8857469294585577902c1a56afc02 Mon Sep 17 00:00:00 2001 From: Tobias Bieniek Date: Thu, 9 Nov 2017 15:45:03 +0100 Subject: [PATCH 1/5] Enable HBS transforms for Ember 1.13.0 and below again --- index.js | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/index.js b/index.js index fe5bea28..fe3d559b 100644 --- a/index.js +++ b/index.js @@ -55,13 +55,9 @@ module.exports = { let host = this._findHost(); this._assignOptions(host); - let emberChecker = new VersionChecker(app).forEmber(); - - if (emberChecker.isAbove('1.13.0')) { - // we can't use the setupPreprocessorRegistry() hook as it is called to - // early and we do not have reliable access to `app.tests` there yet - this._setupPreprocessorRegistry(app.registry); - } + // we can't use the setupPreprocessorRegistry() hook as it is called to + // early and we do not have reliable access to `app.tests` there yet + this._setupPreprocessorRegistry(app.registry); // add the StripDataTestPropertiesPlugin to the list of plugins used by // the `ember-cli-babel` addon From 778fbbc991f7306315cc05b7188f524fd69d812d Mon Sep 17 00:00:00 2001 From: Tobias Bieniek Date: Thu, 9 Nov 2017 15:47:54 +0100 Subject: [PATCH 2/5] Fix HBS transforms for AST difference in Ember 1.11/1.12 --- strip-test-selectors.js | 4 ++++ transform-test-selector-params-to-hash-pairs.js | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/strip-test-selectors.js b/strip-test-selectors.js index 28e94ec4..f6aeea2a 100644 --- a/strip-test-selectors.js +++ b/strip-test-selectors.js @@ -21,6 +21,10 @@ StripTestSelectorsTransform.prototype.transform = function(ast) { return !isTestSelector(attribute.name); }); } else if (node.type === 'MustacheStatement' || node.type === 'BlockStatement') { + if ('sexpr' in node) { + node = node.sexpr; + } + node.params = node.params.filter(function(param) { return !isTestSelector(param.original); }); diff --git a/transform-test-selector-params-to-hash-pairs.js b/transform-test-selector-params-to-hash-pairs.js index fbe743aa..9d9d3ae6 100644 --- a/transform-test-selector-params-to-hash-pairs.js +++ b/transform-test-selector-params-to-hash-pairs.js @@ -19,6 +19,10 @@ TransformTestSelectorParamsToHashPairs.prototype.transform = function(ast) { walker.visit(ast, function(node) { if (node.type === 'MustacheStatement' || node.type === 'BlockStatement') { + if ('sexpr' in node) { + node = node.sexpr; + } + let testSelectorParams = []; let otherParams = []; From 44e296472ba4c30412f80bd554e45fd2289b1d08 Mon Sep 17 00:00:00 2001 From: Tobias Bieniek Date: Thu, 9 Nov 2017 16:03:12 +0100 Subject: [PATCH 3/5] Extract Ember version checks into separate module --- tests/dummy/app/version-checks.js | 15 +++++++++++++++ ...-data-test-attributes-from-components-test.js | 16 +--------------- 2 files changed, 16 insertions(+), 15 deletions(-) create mode 100644 tests/dummy/app/version-checks.js diff --git a/tests/dummy/app/version-checks.js b/tests/dummy/app/version-checks.js new file mode 100644 index 00000000..2246e738 --- /dev/null +++ b/tests/dummy/app/version-checks.js @@ -0,0 +1,15 @@ +import Ember from 'ember'; + +const { VERSION } = Ember; + +const EMBERS_WITHOUT_RELIABLE_POSITIONAL_PARAMS = [ + '2.2', + '2.1', + '2.0', + '1.13', + '1.12', + '1.11', +]; + +export const hasReliablePositionalParams = !EMBERS_WITHOUT_RELIABLE_POSITIONAL_PARAMS + .some(version => VERSION.indexOf(`${version}.`) === 0); diff --git a/tests/integration/strip-data-test-attributes-from-components-test.js b/tests/integration/strip-data-test-attributes-from-components-test.js index c01e2432..786582a0 100644 --- a/tests/integration/strip-data-test-attributes-from-components-test.js +++ b/tests/integration/strip-data-test-attributes-from-components-test.js @@ -1,27 +1,13 @@ import { moduleForComponent, test, skip } from 'ember-qunit'; -import Ember from 'ember'; import hbs from 'htmlbars-inline-precompile'; import config from 'dummy/config/environment'; +import { hasReliablePositionalParams } from 'dummy/version-checks'; moduleForComponent('print-test-attributes', 'StripTestSelectorsTransform plugin', { integration: true }); -const { VERSION } = Ember; - -const EMBERS_WITHOUT_RELIABLE_POSITIONAL_PARAMS = [ - '2.2', - '2.1', - '2.0', - '1.13', - '1.12', - '1.11', -]; - -const hasReliablePositionalParams = !EMBERS_WITHOUT_RELIABLE_POSITIONAL_PARAMS - .some(version => VERSION.indexOf(`${version}.`) === 0); - if (config.stripTestSelectors) { (hasReliablePositionalParams ? test : skip)('it strips data-test-* attributes from components with single positional params', function(assert) { From c4cf674df8649b19485c556593024d22f5522fb1 Mon Sep 17 00:00:00 2001 From: Tobias Bieniek Date: Thu, 9 Nov 2017 16:03:55 +0100 Subject: [PATCH 4/5] Reenable most positional param to hash pair tests --- ...data-test-attributes-in-components-test.js | 37 +++++++++---------- tests/dummy/app/controllers/bind-test.js | 4 +- tests/dummy/app/templates/bind-test.hbs | 10 ++--- tests/dummy/app/version-checks.js | 8 ++++ 4 files changed, 32 insertions(+), 27 deletions(-) diff --git a/tests/acceptance/bind-data-test-attributes-in-components-test.js b/tests/acceptance/bind-data-test-attributes-in-components-test.js index 2ff12cd3..07bc60bb 100644 --- a/tests/acceptance/bind-data-test-attributes-in-components-test.js +++ b/tests/acceptance/bind-data-test-attributes-in-components-test.js @@ -1,9 +1,8 @@ -import { test } from 'qunit'; +import { test, skip } from 'qunit'; import moduleForAcceptance from '../../tests/helpers/module-for-acceptance'; import config from 'dummy/config/environment'; - -import { GTE_EMBER_1_13 } from 'ember-compatibility-helpers'; +import { hasPositionalParams } from 'dummy/version-checks'; if (!config.stripTestSelectors) { @@ -49,25 +48,23 @@ if (!config.stripTestSelectors) { assert.equal(find('.test6').find('div[data-non-test]').length, 0, 'data-non-test does not exists'); }); - if (GTE_EMBER_1_13) { - test('it binds data-test-* attributes with boolean values on components', function(assert) { - assert.equal(find('.test7').find('div[data-test-with-boolean-value]').length, 1, 'data-test-with-boolean-value exists'); - }); + test('it binds data-test-* attributes with boolean values on components', function(assert) { + assert.equal(find('.test7').find('div[data-test-with-boolean-value]').length, 1, 'data-test-with-boolean-value exists'); + }); - test('it binds data-test-* attributes without values on components', function(assert) { - assert.equal(find('.test8').find('div[data-test-without-value]').length, 1, 'data-test-without-value exists'); - }); + test('it binds data-test-* attributes without values on components', function(assert) { + assert.equal(find('.test8').find('div[data-test-without-value]').length, 1, 'data-test-without-value exists'); + }); - test('it binds data-test-* attributes without values on block components', function(assert) { - assert.equal(find('.test9').find('div[data-test-without-value]').length, 1, 'data-test-without-value exists'); - }); + test('it binds data-test-* attributes without values on block components', function(assert) { + assert.equal(find('.test9').find('div[data-test-without-value]').length, 1, 'data-test-without-value exists'); + }); - test('it leaves data-test attribute without value untouched on components', function(assert) { - assert.equal(find('.test10').find('div[data-test]').length, 0, 'data-test does not exists'); - }); + (hasPositionalParams ? test : skip)('it leaves data-test attribute without value untouched on components', function(assert) { + assert.equal(find('.test10').find('div[data-test]').length, 0, 'data-test does not exists'); + }); - test('it transforms data-test params to hash pairs on components', function(assert) { - assert.equal(find('.test11').find('div[data-test-something]').length, 1, 'data-test-something exists'); - }); - } + test('it transforms data-test params to hash pairs on components', function(assert) { + assert.equal(find('.test11').find('div[data-test-something]').length, 1, 'data-test-something exists'); + }); } diff --git a/tests/dummy/app/controllers/bind-test.js b/tests/dummy/app/controllers/bind-test.js index 698f0311..eccfa039 100644 --- a/tests/dummy/app/controllers/bind-test.js +++ b/tests/dummy/app/controllers/bind-test.js @@ -1,8 +1,8 @@ import Ember from 'ember'; -import { GTE_EMBER_1_13 } from 'ember-compatibility-helpers'; +import { hasPositionalParams } from 'dummy/version-checks'; const { Controller } = Ember; export default Controller.extend({ - shouldRenderParamTests: GTE_EMBER_1_13 + hasPositionalParams, }); diff --git a/tests/dummy/app/templates/bind-test.hbs b/tests/dummy/app/templates/bind-test.hbs index b033067d..684f582c 100644 --- a/tests/dummy/app/templates/bind-test.hbs +++ b/tests/dummy/app/templates/bind-test.hbs @@ -12,12 +12,12 @@
{{data-test-component data-test-with-boolean-value=true}}
-{{#if shouldRenderParamTests}} -
{{data-test-component data-test-without-value}}
+
{{data-test-component data-test-without-value}}
-
{{#data-test-component data-test-without-value}}foo{{/data-test-component}}
+
{{#data-test-component data-test-without-value}}foo{{/data-test-component}}
+{{#if hasPositionalParams}}
{{data-test-component data-test}}
- -
{{data-test-component data-test-something some-prop="prop"}}
{{/if}} + +
{{data-test-component data-test-something some-prop="prop"}}
diff --git a/tests/dummy/app/version-checks.js b/tests/dummy/app/version-checks.js index 2246e738..6bae6564 100644 --- a/tests/dummy/app/version-checks.js +++ b/tests/dummy/app/version-checks.js @@ -2,6 +2,11 @@ import Ember from 'ember'; const { VERSION } = Ember; +const EMBERS_WITHOUT_POSITIONAL_PARAMS = [ + '1.12', + '1.11', +]; + const EMBERS_WITHOUT_RELIABLE_POSITIONAL_PARAMS = [ '2.2', '2.1', @@ -11,5 +16,8 @@ const EMBERS_WITHOUT_RELIABLE_POSITIONAL_PARAMS = [ '1.11', ]; +export const hasPositionalParams = !EMBERS_WITHOUT_POSITIONAL_PARAMS + .some(version => VERSION.indexOf(`${version}.`) === 0); + export const hasReliablePositionalParams = !EMBERS_WITHOUT_RELIABLE_POSITIONAL_PARAMS .some(version => VERSION.indexOf(`${version}.`) === 0); From 0116bbe449fe61edcecfdba16cac8d3e5dc1c986 Mon Sep 17 00:00:00 2001 From: Tobias Bieniek Date: Thu, 9 Nov 2017 16:05:34 +0100 Subject: [PATCH 5/5] Remove unused `ember-compatibility-helpers` dependency --- package.json | 1 - yarn.lock | 12 ------------ 2 files changed, 13 deletions(-) diff --git a/package.json b/package.json index 74d2ec67..d263d29f 100644 --- a/package.json +++ b/package.json @@ -37,7 +37,6 @@ "ember-cli-inject-live-reload": "^1.6.1", "ember-cli-qunit": "^4.0.0", "ember-cli-shims": "^1.1.0", - "ember-compatibility-helpers": "^0.1.2", "ember-disable-prototype-extensions": "^1.1.2", "ember-load-initializers": "^1.0.0", "ember-resolver": "^4.3.0", diff --git a/yarn.lock b/yarn.lock index 5cdba2de..ea7de91c 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1969,14 +1969,6 @@ ember-cli@~2.16.1: walk-sync "^0.3.0" yam "0.0.22" -ember-compatibility-helpers@^0.1.2: - version "0.1.2" - resolved "https://registry.yarnpkg.com/ember-compatibility-helpers/-/ember-compatibility-helpers-0.1.2.tgz#8eb1769ad761db273fd40242b1170d9f3841d0f0" - dependencies: - babel-plugin-debug-macros "^0.1.11" - ember-cli-version-checker "^2.0.0" - semver "^5.4.1" - ember-disable-prototype-extensions@^1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/ember-disable-prototype-extensions/-/ember-disable-prototype-extensions-1.1.2.tgz#261cccaf6bf8fbb1836be7bdfe4278f9ab92b873" @@ -4362,10 +4354,6 @@ semver@^5.1.0, semver@^5.1.1, semver@^5.3.0: version "5.3.0" resolved "https://registry.yarnpkg.com/semver/-/semver-5.3.0.tgz#9b2ce5d3de02d17c6012ad326aa6b4d0cf54f94f" -semver@^5.4.1: - version "5.4.1" - resolved "https://registry.yarnpkg.com/semver/-/semver-5.4.1.tgz#e059c09d8571f0540823733433505d3a2f00b18e" - send@0.15.3: version "0.15.3" resolved "https://registry.yarnpkg.com/send/-/send-0.15.3.tgz#5013f9f99023df50d1bd9892c19e3defd1d53309"