From 55ccfbf6a0cfbfef737002a09dac9813cc4dd428 Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Thu, 2 Mar 2017 16:28:48 +0100 Subject: [PATCH 01/24] Respect older versions in invert map --- .../babel-preset-env/data/built-ins.json | 54 +++++++++++++-- .../babel-preset-env/data/plugins.json | 4 ++ .../babel-preset-env/scripts/build-data.js | 67 ++++++++++--------- 3 files changed, 90 insertions(+), 35 deletions(-) diff --git a/experimental/babel-preset-env/data/built-ins.json b/experimental/babel-preset-env/data/built-ins.json index 5a5b2dfc8d..2fd11ddcb2 100644 --- a/experimental/babel-preset-env/data/built-ins.json +++ b/experimental/babel-preset-env/data/built-ins.json @@ -36,6 +36,7 @@ "firefox": 4, "safari": 6, "node": 0.12, + "android": 4.4, "ios": 7 }, "es6.typed.int16-array": { @@ -118,6 +119,7 @@ "chrome": 51, "firefox": 53, "safari": 9, + "node": 6.5, "ios": 9, "opera": 38 }, @@ -126,6 +128,7 @@ "edge": 15, "firefox": 53, "safari": 9, + "node": 6.5, "ios": 9, "opera": 38 }, @@ -134,6 +137,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -142,6 +146,7 @@ "edge": 13, "firefox": 45, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -150,6 +155,7 @@ "edge": 13, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -158,6 +164,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -166,6 +173,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -174,6 +182,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -182,6 +191,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -190,6 +200,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -198,6 +209,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -206,6 +218,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -214,6 +227,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -222,6 +236,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -230,6 +245,7 @@ "edge": 12, "firefox": 42, "safari": 10, + "node": 6, "ios": 10, "opera": 36 }, @@ -246,6 +262,7 @@ "chrome": 51, "firefox": 51, "safari": 10, + "node": 6.5, "ios": 10, "opera": 38 }, @@ -273,6 +290,7 @@ "safari": 9, "node": 0.12, "ie": 11, + "android": 5, "ios": 9, "opera": 21 }, @@ -351,6 +369,7 @@ "chrome": 49, "firefox": 37, "safari": 9, + "node": 6, "ios": 9, "opera": 36 }, @@ -400,7 +419,7 @@ "edge": 12, "firefox": 25, "safari": 9, - "node": 4, + "node": 6, "ios": 9, "opera": 32 }, @@ -418,7 +437,7 @@ "edge": 12, "firefox": 25, "safari": 8, - "node": 4, + "node": 6, "ios": 9, "opera": 32 }, @@ -427,7 +446,7 @@ "edge": 12, "firefox": 25, "safari": 8, - "node": 4, + "node": 6, "ios": 9, "opera": 32 }, @@ -436,7 +455,7 @@ "edge": 12, "firefox": 31, "safari": 8, - "node": 4, + "node": 6, "ios": 9, "opera": 32 }, @@ -446,6 +465,7 @@ "firefox": 28, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -464,6 +484,7 @@ "firefox": 16, "safari": 9, "node": 0.12, + "android": 5, "ios": 9, "opera": 21 }, @@ -473,6 +494,7 @@ "firefox": 32, "safari": 9, "node": 0.12, + "android": 5, "ios": 9, "opera": 21 }, @@ -491,6 +513,7 @@ "firefox": 25, "safari": 9, "node": 0.12, + "android": 5, "ios": 9, "opera": 21 }, @@ -500,6 +523,7 @@ "firefox": 31, "safari": 9, "node": 0.12, + "android": 5, "ios": 9, "opera": 21 }, @@ -509,6 +533,7 @@ "firefox": 31, "safari": 9, "node": 0.12, + "android": 5, "ios": 9, "opera": 21 }, @@ -518,6 +543,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -527,6 +553,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -536,6 +563,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -545,6 +573,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -554,6 +583,7 @@ "firefox": 31, "safari": 9, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -563,6 +593,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -572,6 +603,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -581,6 +613,7 @@ "firefox": 26, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -590,6 +623,7 @@ "firefox": 27, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -609,6 +643,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -618,6 +653,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -627,6 +663,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -636,6 +673,7 @@ "firefox": 25, "safari": 9, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -645,6 +683,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -654,6 +693,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -663,6 +703,7 @@ "firefox": 25, "safari": 8, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -671,6 +712,7 @@ "edge": 14, "firefox": 43, "safari": 10, + "node": 6, "ios": 10, "opera": 34 }, @@ -678,6 +720,7 @@ "chrome": 54, "edge": 14, "firefox": 47, + "safari": 10.1, "node": 7, "opera": 41 }, @@ -685,6 +728,7 @@ "chrome": 54, "edge": 14, "firefox": 47, + "safari": 10.1, "node": 7, "opera": 41 }, @@ -692,7 +736,7 @@ "chrome": 54, "edge": 15, "firefox": 50, - "safari": 10, + "safari": 10.1, "node": 7, "opera": 41 }, diff --git a/experimental/babel-preset-env/data/plugins.json b/experimental/babel-preset-env/data/plugins.json index 8397e84a86..bce48fad12 100644 --- a/experimental/babel-preset-env/data/plugins.json +++ b/experimental/babel-preset-env/data/plugins.json @@ -146,6 +146,7 @@ "firefox": 36, "safari": 9, "node": 0.12, + "android": 5.1, "ios": 9, "opera": 25 }, @@ -171,11 +172,14 @@ "chrome": 52, "edge": 14, "firefox": 52, + "safari": 10.1, + "node": 7, "opera": 39 }, "transform-async-to-generator": { "chrome": 55, "firefox": 52, + "safari": 10.1, "node": 7.6, "opera": 42 }, diff --git a/experimental/babel-preset-env/scripts/build-data.js b/experimental/babel-preset-env/scripts/build-data.js index 2bd017cdc6..bef972b907 100644 --- a/experimental/babel-preset-env/scripts/build-data.js +++ b/experimental/babel-preset-env/scripts/build-data.js @@ -16,36 +16,6 @@ const es6Data = require("compat-table/data-es6"); const es6PlusData = require("compat-table/data-es2016plus"); const envs = require("compat-table/environments"); -const invertedEqualsEnv = Object.keys(envs) - .filter((b) => envs[b].equals) - .reduce((a, b) => { - if (!a[envs[b].equals]) { - a[envs[b].equals] = [b]; - } else { - a[envs[b].equals].push(b); - } - return a; - }, {}); - -invertedEqualsEnv.safari5 = ["ios6"]; -if (Array.isArray(invertedEqualsEnv.safari6)) { - invertedEqualsEnv.safari6.push("ios7"); -} else { - invertedEqualsEnv.safari6 = ["ios7"]; -} -invertedEqualsEnv.safari8 = ["ios9"]; - -const compatibilityTests = flattenDeep([ - es6Data, - es6PlusData, -].map((data) => - data.tests.map((test) => { - return test.subtests ? - [test, renameTests(test.subtests, (name) => test.name + " / " + name)] : - test; - }) -)); - const environments = [ "chrome", "opera", @@ -62,6 +32,7 @@ const environments = [ const envMap = { safari51: "safari5", safari71_8: "safari8", + safari10_1: "safari10.1", firefox3_5: "firefox3", firefox3_6: "firefox3", node010: "node0.10", @@ -80,6 +51,42 @@ const envMap = { ios51: "ios5.1", }; +const invertedEqualsEnv = Object.keys(envs) + .filter((b) => envs[b].equals) + .reduce((a, b) => { + const checkEnv = envMap[envs[b].equals] || envs[b].equals; + environments.some((env) => { + const version = parseInt(checkEnv.replace(env, ""), 10); + if (!isNaN(version)) { + Object.keys(envs).forEach((equals) => { + const equalsVersion = parseInt(equals.replace(env, ""), 10); + if (equalsVersion <= version) { + if (!a[equals]) a[equals] = []; + a[equals].push(b); + } + }); + return true; + } + }); + + return a; + }, {}); + +invertedEqualsEnv.safari8 = ["ios9"]; + +const compatibilityTests = flattenDeep([ + es6Data, + es6PlusData, +].map((data) => + data.tests.map((test) => { + return test.subtests ? + [test, renameTests(test.subtests, (name) => test.name + " / " + name)] : + test; + }) +)); + +console.log(invertedEqualsEnv); + const getLowestImplementedVersion = ({ features }, env) => { const tests = flatten(compatibilityTests .filter((test) => { From c468d68cb85975de5c51f63f43e7ad598bc7a77c Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Thu, 2 Mar 2017 16:31:39 +0100 Subject: [PATCH 02/24] Remove console.log --- experimental/babel-preset-env/scripts/build-data.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/experimental/babel-preset-env/scripts/build-data.js b/experimental/babel-preset-env/scripts/build-data.js index bef972b907..7d3df88703 100644 --- a/experimental/babel-preset-env/scripts/build-data.js +++ b/experimental/babel-preset-env/scripts/build-data.js @@ -85,8 +85,6 @@ const compatibilityTests = flattenDeep([ }) )); -console.log(invertedEqualsEnv); - const getLowestImplementedVersion = ({ features }, env) => { const tests = flatten(compatibilityTests .filter((test) => { From 984df9c96a9e7582da11d029500faf9c80f64695 Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Thu, 2 Mar 2017 21:58:09 +0100 Subject: [PATCH 03/24] Fix node 4 --- experimental/babel-preset-env/data/built-ins.json | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/experimental/babel-preset-env/data/built-ins.json b/experimental/babel-preset-env/data/built-ins.json index 2fd11ddcb2..9f65626cca 100644 --- a/experimental/babel-preset-env/data/built-ins.json +++ b/experimental/babel-preset-env/data/built-ins.json @@ -419,7 +419,7 @@ "edge": 12, "firefox": 25, "safari": 9, - "node": 6, + "node": 4, "ios": 9, "opera": 32 }, @@ -437,7 +437,7 @@ "edge": 12, "firefox": 25, "safari": 8, - "node": 6, + "node": 4, "ios": 9, "opera": 32 }, @@ -446,7 +446,7 @@ "edge": 12, "firefox": 25, "safari": 8, - "node": 6, + "node": 4, "ios": 9, "opera": 32 }, @@ -455,7 +455,7 @@ "edge": 12, "firefox": 31, "safari": 8, - "node": 6, + "node": 4, "ios": 9, "opera": 32 }, From 09c84a379f4dd43a3b25e4746aab058f3e63fcff Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Thu, 2 Mar 2017 22:24:46 +0100 Subject: [PATCH 04/24] Fix tests --- .../test/debug-fixtures/built-ins/stdout.txt | 32 +++++++++---------- .../debug-fixtures/plugins-only/stdout.txt | 3 +- 2 files changed, 17 insertions(+), 18 deletions(-) diff --git a/experimental/babel-preset-env/test/debug-fixtures/built-ins/stdout.txt b/experimental/babel-preset-env/test/debug-fixtures/built-ins/stdout.txt index 9d85e62916..c25134be0a 100644 --- a/experimental/babel-preset-env/test/debug-fixtures/built-ins/stdout.txt +++ b/experimental/babel-preset-env/test/debug-fixtures/built-ins/stdout.txt @@ -39,19 +39,19 @@ Using polyfills: es6.set {"ie":10,"node":6} es6.weak-map {"ie":10,"node":6} es6.weak-set {"ie":10,"node":6} - es6.reflect.apply {"ie":10,"node":6} - es6.reflect.construct {"ie":10,"node":6} - es6.reflect.define-property {"ie":10,"node":6} - es6.reflect.delete-property {"ie":10,"node":6} - es6.reflect.get {"ie":10,"node":6} - es6.reflect.get-own-property-descriptor {"ie":10,"node":6} - es6.reflect.get-prototype-of {"ie":10,"node":6} - es6.reflect.has {"ie":10,"node":6} - es6.reflect.is-extensible {"ie":10,"node":6} - es6.reflect.own-keys {"ie":10,"node":6} - es6.reflect.prevent-extensions {"ie":10,"node":6} - es6.reflect.set {"ie":10,"node":6} - es6.reflect.set-prototype-of {"ie":10,"node":6} + es6.reflect.apply {"ie":10} + es6.reflect.construct {"ie":10} + es6.reflect.define-property {"ie":10} + es6.reflect.delete-property {"ie":10} + es6.reflect.get {"ie":10} + es6.reflect.get-own-property-descriptor {"ie":10} + es6.reflect.get-prototype-of {"ie":10} + es6.reflect.has {"ie":10} + es6.reflect.is-extensible {"ie":10} + es6.reflect.own-keys {"ie":10} + es6.reflect.prevent-extensions {"ie":10} + es6.reflect.set {"ie":10} + es6.reflect.set-prototype-of {"ie":10} es6.promise {"ie":10,"node":6} es6.symbol {"ie":10,"node":6} es6.object.assign {"ie":10} @@ -65,7 +65,7 @@ Using polyfills: es6.string.starts-with {"ie":10} es6.string.ends-with {"ie":10} es6.string.includes {"ie":10} - es6.regexp.flags {"ie":10,"node":6} + es6.regexp.flags {"ie":10} es6.regexp.match {"ie":10} es6.regexp.replace {"ie":10} es6.regexp.split {"ie":10} @@ -101,7 +101,7 @@ Using polyfills: es6.math.sinh {"ie":10} es6.math.tanh {"ie":10} es6.math.trunc {"ie":10} - es7.array.includes {"ie":10,"node":6} + es7.array.includes {"ie":10} es7.object.values {"ie":10,"node":6} es7.object.entries {"ie":10,"node":6} es7.object.get-own-property-descriptors {"ie":10,"node":6} @@ -110,4 +110,4 @@ Using polyfills: web.timers {"chrome":54,"ie":10,"node":6} web.immediate {"chrome":54,"ie":10,"node":6} web.dom.iterable {"chrome":54,"ie":10,"node":6} -src/in.js -> lib/in.js \ No newline at end of file +src/in.js -> lib/in.js diff --git a/experimental/babel-preset-env/test/debug-fixtures/plugins-only/stdout.txt b/experimental/babel-preset-env/test/debug-fixtures/plugins-only/stdout.txt index ec43e49e9f..5263ed559f 100644 --- a/experimental/babel-preset-env/test/debug-fixtures/plugins-only/stdout.txt +++ b/experimental/babel-preset-env/test/debug-fixtures/plugins-only/stdout.txt @@ -13,6 +13,5 @@ Using plugins: transform-es2015-for-of {"firefox":52} transform-es2015-function-name {"firefox":52} transform-es2015-literals {"firefox":52} - transform-exponentiation-operator {"node":7.4} syntax-trailing-function-commas {"node":7.4} -src/in.js -> lib/in.js \ No newline at end of file +src/in.js -> lib/in.js From 8d96bd2378159ffba1518d83452fc9d38348fbf9 Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Thu, 2 Mar 2017 22:29:49 +0100 Subject: [PATCH 05/24] Secure script --- experimental/babel-preset-env/scripts/build-data.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/experimental/babel-preset-env/scripts/build-data.js b/experimental/babel-preset-env/scripts/build-data.js index 7d3df88703..a3f52b987e 100644 --- a/experimental/babel-preset-env/scripts/build-data.js +++ b/experimental/babel-preset-env/scripts/build-data.js @@ -60,7 +60,7 @@ const invertedEqualsEnv = Object.keys(envs) if (!isNaN(version)) { Object.keys(envs).forEach((equals) => { const equalsVersion = parseInt(equals.replace(env, ""), 10); - if (equalsVersion <= version) { + if (!isNaN(equalsVersion) && equalsVersion <= version) { if (!a[equals]) a[equals] = []; a[equals].push(b); } From c2c96995a16513fac3ef4f14d62ca752cace0f24 Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Thu, 2 Mar 2017 22:33:03 +0100 Subject: [PATCH 06/24] Add comments --- experimental/babel-preset-env/scripts/build-data.js | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/experimental/babel-preset-env/scripts/build-data.js b/experimental/babel-preset-env/scripts/build-data.js index a3f52b987e..f7958ed699 100644 --- a/experimental/babel-preset-env/scripts/build-data.js +++ b/experimental/babel-preset-env/scripts/build-data.js @@ -56,10 +56,16 @@ const invertedEqualsEnv = Object.keys(envs) .reduce((a, b) => { const checkEnv = envMap[envs[b].equals] || envs[b].equals; environments.some((env) => { + // go through all environment names to find the the current one + // and try to get the version as integer const version = parseInt(checkEnv.replace(env, ""), 10); if (!isNaN(version)) { Object.keys(envs).forEach((equals) => { + // Go through all envs from compat-table and get int version const equalsVersion = parseInt(equals.replace(env, ""), 10); + // If the current version is smaller than the version that was mentioned + // in `equals` we can add an entry, as older versions should include features + // that newer ones have if (!isNaN(equalsVersion) && equalsVersion <= version) { if (!a[equals]) a[equals] = []; a[equals].push(b); From b5af93f348c436ed0576f2b0a3c435cffaa83949 Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Fri, 3 Mar 2017 17:15:26 +0100 Subject: [PATCH 07/24] Update compat-table to include ndoe4 and ios8 fixes --- experimental/babel-preset-env/package.json | 2 +- experimental/babel-preset-env/yarn.lock | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/experimental/babel-preset-env/package.json b/experimental/babel-preset-env/package.json index 9286df8635..92f6aa7d8d 100644 --- a/experimental/babel-preset-env/package.json +++ b/experimental/babel-preset-env/package.json @@ -58,7 +58,7 @@ "babel-preset-es2015": "^6.14.0", "babel-register": "^6.14.0", "chai": "^3.0.0", - "compat-table": "kangax/compat-table#291c758ac618fff6bf5bb2113a5aa046189f93e2", + "compat-table": "kangax/compat-table#c38f039b8ea7fadf347d3e300fec3611645e31e9", "eslint": "^3.13.1", "eslint-config-babel": "^5.0.0", "eslint-plugin-flowtype": "^2.29.1", diff --git a/experimental/babel-preset-env/yarn.lock b/experimental/babel-preset-env/yarn.lock index caf3cede67..61f4c3d5e0 100644 --- a/experimental/babel-preset-env/yarn.lock +++ b/experimental/babel-preset-env/yarn.lock @@ -1067,9 +1067,9 @@ commoner@^0.10.1: q "^1.1.2" recast "^0.11.17" -compat-table@kangax/compat-table#291c758ac618fff6bf5bb2113a5aa046189f93e2: +compat-table@kangax/compat-table#c38f039b8ea7fadf347d3e300fec3611645e31e9: version "0.0.0" - resolved "https://codeload.github.com/kangax/compat-table/tar.gz/291c758ac618fff6bf5bb2113a5aa046189f93e2" + resolved "https://codeload.github.com/kangax/compat-table/tar.gz/c38f039b8ea7fadf347d3e300fec3611645e31e9" dependencies: babel-core latest babel-polyfill latest From 6edae49d4d9f32da04ff160439cc7a7db49c7f5c Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Fri, 3 Mar 2017 17:24:01 +0100 Subject: [PATCH 08/24] Version can be float and correctly lookup envMap --- .../babel-preset-env/data/built-ins.json | 36 +++++++++---------- .../babel-preset-env/data/plugins.json | 2 +- .../babel-preset-env/scripts/build-data.js | 9 +++-- 3 files changed, 23 insertions(+), 24 deletions(-) diff --git a/experimental/babel-preset-env/data/built-ins.json b/experimental/babel-preset-env/data/built-ins.json index 9f65626cca..4901b8f1f6 100644 --- a/experimental/babel-preset-env/data/built-ins.json +++ b/experimental/babel-preset-env/data/built-ins.json @@ -438,7 +438,7 @@ "firefox": 25, "safari": 8, "node": 4, - "ios": 9, + "ios": 8, "opera": 32 }, "es6.array.find-index": { @@ -447,7 +447,7 @@ "firefox": 25, "safari": 8, "node": 4, - "ios": 9, + "ios": 8, "opera": 32 }, "es6.array.fill": { @@ -456,7 +456,7 @@ "firefox": 31, "safari": 8, "node": 4, - "ios": 9, + "ios": 8, "opera": 32 }, "es6.array.iterator": { @@ -466,7 +466,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.number.is-finite": { @@ -544,7 +544,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.asinh": { @@ -554,7 +554,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.atanh": { @@ -564,7 +564,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.cbrt": { @@ -574,7 +574,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.clz32": { @@ -594,7 +594,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.expm1": { @@ -604,7 +604,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.fround": { @@ -614,7 +614,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.hypot": { @@ -624,7 +624,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.imul": { @@ -644,7 +644,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.log10": { @@ -654,7 +654,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.log2": { @@ -664,7 +664,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.sign": { @@ -684,7 +684,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.tanh": { @@ -694,7 +694,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es6.math.trunc": { @@ -704,7 +704,7 @@ "safari": 8, "node": 0.12, "android": 5.1, - "ios": 9, + "ios": 8, "opera": 25 }, "es7.array.includes": { diff --git a/experimental/babel-preset-env/data/plugins.json b/experimental/babel-preset-env/data/plugins.json index bce48fad12..6630092e3a 100644 --- a/experimental/babel-preset-env/data/plugins.json +++ b/experimental/babel-preset-env/data/plugins.json @@ -40,7 +40,7 @@ "firefox": 34, "safari": 8, "node": 4, - "ios": 9, + "ios": 8, "opera": 31 }, "check-es2015-constants": { diff --git a/experimental/babel-preset-env/scripts/build-data.js b/experimental/babel-preset-env/scripts/build-data.js index f7958ed699..deba362443 100644 --- a/experimental/babel-preset-env/scripts/build-data.js +++ b/experimental/babel-preset-env/scripts/build-data.js @@ -58,11 +58,12 @@ const invertedEqualsEnv = Object.keys(envs) environments.some((env) => { // go through all environment names to find the the current one // and try to get the version as integer - const version = parseInt(checkEnv.replace(env, ""), 10); + const version = parseFloat(checkEnv.replace(env, "")); if (!isNaN(version)) { Object.keys(envs).forEach((equals) => { + equals = envMap[equals] || equals; // Go through all envs from compat-table and get int version - const equalsVersion = parseInt(equals.replace(env, ""), 10); + const equalsVersion = parseFloat(equals.replace(env, "")); // If the current version is smaller than the version that was mentioned // in `equals` we can add an entry, as older versions should include features // that newer ones have @@ -78,8 +79,6 @@ const invertedEqualsEnv = Object.keys(envs) return a; }, {}); -invertedEqualsEnv.safari8 = ["ios9"]; - const compatibilityTests = flattenDeep([ es6Data, es6PlusData, @@ -141,7 +140,7 @@ const getLowestImplementedVersion = ({ features }, env) => { .filter((test) => tests[i].res[test] === true || tests[i].res[test] === "strict") // normalize some keys .map((test) => envMap[test] || test) - .filter((test) => !isNaN(parseInt(test.replace(env, "")))) + .filter((test) => !isNaN(parseFloat(test.replace(env, "")))) .shift(); }); From 7d00281b2bd1c7d91775ee97534f949a7bc0fa8f Mon Sep 17 00:00:00 2001 From: Daniel Tschinder Date: Fri, 3 Mar 2017 20:48:35 +0100 Subject: [PATCH 09/24] =?UTF-8?q?Don=E2=80=99t=20add=20duplicate=20entries?= =?UTF-8?q?=20to=20map?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- experimental/babel-preset-env/scripts/build-data.js | 1 + 1 file changed, 1 insertion(+) diff --git a/experimental/babel-preset-env/scripts/build-data.js b/experimental/babel-preset-env/scripts/build-data.js index deba362443..fd16232fd0 100644 --- a/experimental/babel-preset-env/scripts/build-data.js +++ b/experimental/babel-preset-env/scripts/build-data.js @@ -69,6 +69,7 @@ const invertedEqualsEnv = Object.keys(envs) // that newer ones have if (!isNaN(equalsVersion) && equalsVersion <= version) { if (!a[equals]) a[equals] = []; + if (a[equals].indexOf(b) >= 0) return; a[equals].push(b); } }); From 6a2b6fc0e0d11d840a753721712265958a2eebb6 Mon Sep 17 00:00:00 2001 From: Artem Yavorsky Date: Fri, 3 Mar 2017 23:36:54 +0200 Subject: [PATCH 10/24] Add uglify as a target (#178) --- experimental/babel-preset-env/README.md | 8 ++++ experimental/babel-preset-env/src/index.js | 42 ++++++++++++------- .../builtins-uglify/options.json | 13 ++++++ .../debug-fixtures/builtins-uglify/stdout.txt | 41 ++++++++++++++++++ .../{built-ins => builtins}/options.json | 0 .../{built-ins => builtins}/stdout.txt | 0 .../fixtures/preset-options/uglify/actual.js | 3 ++ .../preset-options/uglify/expected.js | 9 ++++ .../preset-options/uglify/options.json | 12 ++++++ .../babel-preset-env/test/index.spec.js | 34 +++++++++++++++ 10 files changed, 148 insertions(+), 14 deletions(-) create mode 100644 experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/options.json create mode 100644 experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/stdout.txt rename experimental/babel-preset-env/test/debug-fixtures/{built-ins => builtins}/options.json (100%) rename experimental/babel-preset-env/test/debug-fixtures/{built-ins => builtins}/stdout.txt (100%) create mode 100644 experimental/babel-preset-env/test/fixtures/preset-options/uglify/actual.js create mode 100644 experimental/babel-preset-env/test/fixtures/preset-options/uglify/expected.js create mode 100644 experimental/babel-preset-env/test/fixtures/preset-options/uglify/options.json diff --git a/experimental/babel-preset-env/README.md b/experimental/babel-preset-env/README.md index bea0910d8e..743ce450d1 100644 --- a/experimental/babel-preset-env/README.md +++ b/experimental/babel-preset-env/README.md @@ -122,6 +122,14 @@ A query to select browsers (ex: last 2 versions, > 5%) using [browserslist](http Note, browsers' results are overridden by explicit items from `targets`. +### `targets.uglify` + +`number | true` + +If you are using UglifyJS to minify your code, then targeting later browsers will throw a syntax error. + +To prevent this - specify the uglify option, which will enable all plugins and, as a result, fully compile your code to ES5. Note, that useBuiltIns will work as before, and only include the polyfills that your target(s) need. + ### `loose` `boolean`, defaults to `false`. diff --git a/experimental/babel-preset-env/src/index.js b/experimental/babel-preset-env/src/index.js index da60629526..634435fc29 100644 --- a/experimental/babel-preset-env/src/index.js +++ b/experimental/babel-preset-env/src/index.js @@ -94,29 +94,33 @@ const _extends = Object.assign || function (target) { export const getTargets = (targets = {}) => { - const targetOps = _extends({}, targets); + const targetOpts = _extends({}, targets); - if (targetOps.node === true || targetOps.node === "current") { - targetOps.node = getCurrentNodeVersion(); + if (targetOpts.node === true || targetOpts.node === "current") { + targetOpts.node = getCurrentNodeVersion(); + } + + if (targetOpts.hasOwnProperty("uglify") && !targetOpts.uglify) { + delete targetOpts.uglify; } // Replace Electron target with its Chrome equivalent - if (targetOps.electron) { - const electronChromeVersion = getElectronChromeVersion(targetOps.electron); + if (targetOpts.electron) { + const electronChromeVersion = getElectronChromeVersion(targetOpts.electron); - targetOps.chrome = targetOps.chrome - ? Math.min(targetOps.chrome, electronChromeVersion) + targetOpts.chrome = targetOpts.chrome + ? Math.min(targetOpts.chrome, electronChromeVersion) : electronChromeVersion; - delete targetOps.electron; + delete targetOpts.electron; } - const browserOpts = targetOps.browsers; + const browserOpts = targetOpts.browsers; if (isBrowsersQueryValid(browserOpts)) { const queryBrowsers = getLowestVersions(browserslist(browserOpts)); - return mergeBrowsers(queryBrowsers, targetOps); + return mergeBrowsers(queryBrowsers, targetOpts); } - return targetOps; + return targetOpts; }; let hasBeenLogged = false; @@ -143,6 +147,14 @@ const filterItem = (targets, exclusions, list, item) => { return isRequired && notExcluded; }; +const getBuiltInTargets = (targets) => { + const builtInTargets = _extends({}, targets); + if (builtInTargets.uglify != null) { + delete builtInTargets.uglify; + } + return builtInTargets; +}; + export const transformIncludesAndExcludes = (opts) => ({ all: opts, plugins: opts.filter((opt) => !opt.match(/^(es\d+|web)\./)), @@ -157,15 +169,17 @@ export default function buildPreset(context, opts = {}) { const include = transformIncludesAndExcludes(validatedOptions.include); const exclude = transformIncludesAndExcludes(validatedOptions.exclude); + const filterPlugins = filterItem.bind(null, targets, exclude.plugins, pluginList); const transformations = Object.keys(pluginList) .filter(filterPlugins) .concat(include.plugins); let polyfills; + let polyfillTargets; if (useBuiltIns) { - const filterBuiltIns = filterItem.bind(null, targets, exclude.builtIns, builtInsList); - + polyfillTargets = getBuiltInTargets(targets); + const filterBuiltIns = filterItem.bind(null, polyfillTargets, exclude.builtIns, builtInsList); polyfills = Object.keys(builtInsList) .concat(defaultInclude) .filter(filterBuiltIns) @@ -185,7 +199,7 @@ export default function buildPreset(context, opts = {}) { if (useBuiltIns && polyfills.length) { console.log("\nUsing polyfills:"); polyfills.forEach((polyfill) => { - logPlugin(polyfill, targets, builtInsList); + logPlugin(polyfill, polyfillTargets, builtInsList); }); } } diff --git a/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/options.json b/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/options.json new file mode 100644 index 0000000000..9a5b6d27ba --- /dev/null +++ b/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/options.json @@ -0,0 +1,13 @@ +{ + "presets": [ + ["../../lib", { + "debug": true, + "targets": { + "chrome": 55, + "uglify": true + }, + "useBuiltIns": true, + "modules": false + }] + ] +} diff --git a/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/stdout.txt b/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/stdout.txt new file mode 100644 index 0000000000..0cfe3cc487 --- /dev/null +++ b/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/stdout.txt @@ -0,0 +1,41 @@ +babel-preset-env: `DEBUG` option + +Using targets: +{ + "chrome": 55, + "uglify": true +} + +Modules transform: false + +Using plugins: + transform-es2015-arrow-functions {"uglify":true} + transform-es2015-block-scoped-functions {"uglify":true} + transform-es2015-block-scoping {"uglify":true} + transform-es2015-classes {"uglify":true} + transform-es2015-computed-properties {"uglify":true} + check-es2015-constants {"uglify":true} + transform-es2015-destructuring {"uglify":true} + transform-es2015-for-of {"uglify":true} + transform-es2015-function-name {"uglify":true} + transform-es2015-literals {"uglify":true} + transform-es2015-object-super {"uglify":true} + transform-es2015-parameters {"uglify":true} + transform-es2015-shorthand-properties {"uglify":true} + transform-es2015-spread {"uglify":true} + transform-es2015-sticky-regex {"uglify":true} + transform-es2015-template-literals {"uglify":true} + transform-es2015-typeof-symbol {"uglify":true} + transform-es2015-unicode-regex {"uglify":true} + transform-regenerator {"uglify":true} + transform-exponentiation-operator {"uglify":true} + transform-async-to-generator {"uglify":true} + syntax-trailing-function-commas {"chrome":55,"uglify":true} + +Using polyfills: + es7.string.pad-start {"chrome":55} + es7.string.pad-end {"chrome":55} + web.timers {"chrome":55} + web.immediate {"chrome":55} + web.dom.iterable {"chrome":55} +src/in.js -> lib/in.js \ No newline at end of file diff --git a/experimental/babel-preset-env/test/debug-fixtures/built-ins/options.json b/experimental/babel-preset-env/test/debug-fixtures/builtins/options.json similarity index 100% rename from experimental/babel-preset-env/test/debug-fixtures/built-ins/options.json rename to experimental/babel-preset-env/test/debug-fixtures/builtins/options.json diff --git a/experimental/babel-preset-env/test/debug-fixtures/built-ins/stdout.txt b/experimental/babel-preset-env/test/debug-fixtures/builtins/stdout.txt similarity index 100% rename from experimental/babel-preset-env/test/debug-fixtures/built-ins/stdout.txt rename to experimental/babel-preset-env/test/debug-fixtures/builtins/stdout.txt diff --git a/experimental/babel-preset-env/test/fixtures/preset-options/uglify/actual.js b/experimental/babel-preset-env/test/fixtures/preset-options/uglify/actual.js new file mode 100644 index 0000000000..6ce39f1020 --- /dev/null +++ b/experimental/babel-preset-env/test/fixtures/preset-options/uglify/actual.js @@ -0,0 +1,3 @@ +import "babel-polyfill"; + +const a = 1; diff --git a/experimental/babel-preset-env/test/fixtures/preset-options/uglify/expected.js b/experimental/babel-preset-env/test/fixtures/preset-options/uglify/expected.js new file mode 100644 index 0000000000..1b6f966662 --- /dev/null +++ b/experimental/babel-preset-env/test/fixtures/preset-options/uglify/expected.js @@ -0,0 +1,9 @@ +import "core-js/modules/es7.string.pad-start"; +import "core-js/modules/es7.string.pad-end"; +import "core-js/modules/web.timers"; +import "core-js/modules/web.immediate"; +import "core-js/modules/web.dom.iterable"; +import "regenerator-runtime/runtime"; + + +var a = 1; diff --git a/experimental/babel-preset-env/test/fixtures/preset-options/uglify/options.json b/experimental/babel-preset-env/test/fixtures/preset-options/uglify/options.json new file mode 100644 index 0000000000..dd788b3dc2 --- /dev/null +++ b/experimental/babel-preset-env/test/fixtures/preset-options/uglify/options.json @@ -0,0 +1,12 @@ +{ + "presets": [ + ["../../../../lib", { + "targets": { + "chrome": 55, + "uglify": true + }, + "modules": false, + "useBuiltIns": true + }] + ] +} diff --git a/experimental/babel-preset-env/test/index.spec.js b/experimental/babel-preset-env/test/index.spec.js index 997d8ed50e..f3b82ddc6c 100644 --- a/experimental/babel-preset-env/test/index.spec.js +++ b/experimental/babel-preset-env/test/index.spec.js @@ -85,6 +85,28 @@ describe("babel-preset-env", () => { }); }); + describe("getTargets + uglify", () => { + it("should work with `true`", function() { + assert.deepEqual(babelPresetEnv.getTargets({ + uglify: true + }), { + uglify: true + }); + }); + + it("should ignore `false`", function() { + assert.deepEqual(babelPresetEnv.getTargets({ + uglify: false + }), {}); + }); + + it("should ignore `null`", function() { + assert.deepEqual(babelPresetEnv.getTargets({ + uglify: null + }), {}); + }); + }); + describe("isPluginRequired", () => { it("returns true if no targets are specified", () => { const isRequired = babelPresetEnv.isPluginRequired({}, {}); @@ -173,6 +195,18 @@ describe("babel-preset-env", () => { assert(babelPresetEnv.isPluginRequired(targets, plugin) === true); }); + it("returns true if uglify is specified as a target", () => { + const plugin = { + chrome: 50 + }; + const targets = { + chrome: 55, + uglify: true + }; + + assert(babelPresetEnv.isPluginRequired(targets, plugin) === true); + }); + it("doesn't throw when specifying a decimal for node", () => { const plugin = { node: 6 From a68d98d1a5ea1d847f805405b7123c5599cce0a5 Mon Sep 17 00:00:00 2001 From: Brian Ng Date: Fri, 3 Mar 2017 16:50:57 -0600 Subject: [PATCH 11/24] 1.2.0 --- experimental/babel-preset-env/package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/experimental/babel-preset-env/package.json b/experimental/babel-preset-env/package.json index 92f6aa7d8d..f94d332deb 100644 --- a/experimental/babel-preset-env/package.json +++ b/experimental/babel-preset-env/package.json @@ -1,6 +1,6 @@ { "name": "babel-preset-env", - "version": "1.1.11", + "version": "1.2.0", "description": "A Babel preset for each environment.", "author": "Henry Zhu ", "homepage": "https://babeljs.io/", From 496654400254cb8d2b9e99f13e972f96aa8b58a5 Mon Sep 17 00:00:00 2001 From: Brian Ng Date: Fri, 3 Mar 2017 17:03:58 -0600 Subject: [PATCH 12/24] v1.2.0 changelog [skip ci] --- experimental/babel-preset-env/CHANGELOG.md | 31 +++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) diff --git a/experimental/babel-preset-env/CHANGELOG.md b/experimental/babel-preset-env/CHANGELOG.md index 3cfb25cf07..3ac5330942 100644 --- a/experimental/babel-preset-env/CHANGELOG.md +++ b/experimental/babel-preset-env/CHANGELOG.md @@ -1,6 +1,35 @@ # Changelog -## v.1.1.11 (2017-03-01) +## v1.2.0 (2017-03-03) + +### :rocket: New Feature + +- Add uglify as a target ([#178](https://github.com/babel/babel-preset-env/pull/178)) (@yavorsky) + +Support for `uglify` as a target is now available! This will enable all plugins and, as a result, fully compiles your code to ES5. Note, that useBuiltIns will work as before, and only the polyfills that your other target(s) need will be included. + +```json +{ + "presets": [ + ["env", { + "targets": { + "chrome": 55, + "uglify": true + }, + "useBuiltIns": true, + "modules": false + }] + ] +} +``` + +### :bug: Bug Fix + +- Respect older versions in invert equals map ([#180](https://github.com/babel/babel-preset-env/pull/180)) (@danez) + +Fixes a number of bugs that caused some incorrect and/or missing environment data when parsing `compat-table`. + +## v1.1.11 (2017-03-01) This release primarily upgrades `compat-table`, which adds support for async on Node 7.6! From 6ee5b0c5ac39bd0f0aa7af6911f77eab80468b9b Mon Sep 17 00:00:00 2001 From: Mike Greiling Date: Mon, 6 Mar 2017 14:37:51 -0600 Subject: [PATCH 13/24] Clarify reasons for the uglify option in README.md (#188) --- experimental/babel-preset-env/README.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/experimental/babel-preset-env/README.md b/experimental/babel-preset-env/README.md index 743ce450d1..bea51410e5 100644 --- a/experimental/babel-preset-env/README.md +++ b/experimental/babel-preset-env/README.md @@ -126,9 +126,11 @@ Note, browsers' results are overridden by explicit items from `targets`. `number | true` -If you are using UglifyJS to minify your code, then targeting later browsers will throw a syntax error. +UglifyJS does not currently support any ES6 syntax, so if you are using Uglify to minify your code, targeting later browsers may cause Uglify to throw syntax errors. -To prevent this - specify the uglify option, which will enable all plugins and, as a result, fully compile your code to ES5. Note, that useBuiltIns will work as before, and only include the polyfills that your target(s) need. +To prevent these errors - specify the uglify option, which will enable all plugins and, as a result, fully compile your code to ES5. However, the `useBuiltIns` option will still work as before, and only include the polyfills that your target(s) need. + +> NOTE: Uglify has a work-in-progress "Harmony" branch to address the lack of ES6 support, but it is not yet stable. You can follow its progress in [UglifyJS2 issue #448](https://github.com/mishoo/UglifyJS2/issues/448). If you require an alternative minifier which _does_ support ES6 syntax, we recommend using [Babili](https://github.com/babel/babili). ### `loose` From cd0c019b24b604185ac51135fca75a8f60c28a74 Mon Sep 17 00:00:00 2001 From: Brian Ng Date: Mon, 6 Mar 2017 14:55:34 -0600 Subject: [PATCH 14/24] Add transform-duplicate-keys mapping (#192) --- experimental/babel-preset-env/.travis.yml | 2 +- experimental/babel-preset-env/data/plugin-features.js | 5 +++++ experimental/babel-preset-env/data/plugins.json | 9 +++++++++ .../test/debug-fixtures/builtins-uglify/stdout.txt | 1 + .../test/debug-fixtures/builtins/stdout.txt | 3 ++- .../test/debug-fixtures/plugins-only/stdout.txt | 2 +- .../test/debug-fixtures/specific-targets/stdout.txt | 1 + .../preset-options/transform-duplicate-keys/actual.js | 1 + .../preset-options/transform-duplicate-keys/expected.js | 3 +++ .../preset-options/transform-duplicate-keys/options.json | 7 +++++++ 10 files changed, 31 insertions(+), 3 deletions(-) create mode 100644 experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/actual.js create mode 100644 experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/expected.js create mode 100644 experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/options.json diff --git a/experimental/babel-preset-env/.travis.yml b/experimental/babel-preset-env/.travis.yml index 4312dc6dd9..e29bd24054 100644 --- a/experimental/babel-preset-env/.travis.yml +++ b/experimental/babel-preset-env/.travis.yml @@ -19,7 +19,7 @@ before_install: - nvm use $TRAVIS_NODE_VERSION - npm set loglevel error - npm set progress false - - 'if [ $PKG_CMD = "yarn" ]; then npm i -g yarn@0.18.2 ; fi' + - 'if [ $PKG_CMD = "yarn" ]; then npm i -g yarn@0.22.0 ; fi' install: - $PKG_CMD install script: diff --git a/experimental/babel-preset-env/data/plugin-features.js b/experimental/babel-preset-env/data/plugin-features.js index bd87fd411f..82d0e9df87 100644 --- a/experimental/babel-preset-env/data/plugin-features.js +++ b/experimental/babel-preset-env/data/plugin-features.js @@ -39,6 +39,11 @@ module.exports = { "destructuring, parameters", ], }, + "transform-es2015-duplicate-keys": { + features: [ + "miscellaneous / duplicate property names in strict mode", + ], + }, "transform-es2015-for-of": { features: [ "for..of loops", diff --git a/experimental/babel-preset-env/data/plugins.json b/experimental/babel-preset-env/data/plugins.json index 6630092e3a..bf3a87789e 100644 --- a/experimental/babel-preset-env/data/plugins.json +++ b/experimental/babel-preset-env/data/plugins.json @@ -34,6 +34,15 @@ "ios": 10, "opera": 33 }, + "transform-es2015-duplicate-keys": { + "chrome": 42, + "edge": 12, + "firefox": 34, + "safari": 9, + "node": 4, + "ios": 9, + "opera": 29 + }, "transform-es2015-computed-properties": { "chrome": 44, "edge": 12, diff --git a/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/stdout.txt b/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/stdout.txt index 0cfe3cc487..1ce53032fe 100644 --- a/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/stdout.txt +++ b/experimental/babel-preset-env/test/debug-fixtures/builtins-uglify/stdout.txt @@ -13,6 +13,7 @@ Using plugins: transform-es2015-block-scoped-functions {"uglify":true} transform-es2015-block-scoping {"uglify":true} transform-es2015-classes {"uglify":true} + transform-es2015-duplicate-keys {"uglify":true} transform-es2015-computed-properties {"uglify":true} check-es2015-constants {"uglify":true} transform-es2015-destructuring {"uglify":true} diff --git a/experimental/babel-preset-env/test/debug-fixtures/builtins/stdout.txt b/experimental/babel-preset-env/test/debug-fixtures/builtins/stdout.txt index c25134be0a..1104283685 100644 --- a/experimental/babel-preset-env/test/debug-fixtures/builtins/stdout.txt +++ b/experimental/babel-preset-env/test/debug-fixtures/builtins/stdout.txt @@ -14,6 +14,7 @@ Using plugins: transform-es2015-block-scoped-functions {"ie":10} transform-es2015-block-scoping {"ie":10} transform-es2015-classes {"ie":10} + transform-es2015-duplicate-keys {"ie":10} transform-es2015-computed-properties {"ie":10} check-es2015-constants {"ie":10} transform-es2015-destructuring {"ie":10,"node":6} @@ -110,4 +111,4 @@ Using polyfills: web.timers {"chrome":54,"ie":10,"node":6} web.immediate {"chrome":54,"ie":10,"node":6} web.dom.iterable {"chrome":54,"ie":10,"node":6} -src/in.js -> lib/in.js +src/in.js -> lib/in.js \ No newline at end of file diff --git a/experimental/babel-preset-env/test/debug-fixtures/plugins-only/stdout.txt b/experimental/babel-preset-env/test/debug-fixtures/plugins-only/stdout.txt index 5263ed559f..a2ccd28beb 100644 --- a/experimental/babel-preset-env/test/debug-fixtures/plugins-only/stdout.txt +++ b/experimental/babel-preset-env/test/debug-fixtures/plugins-only/stdout.txt @@ -14,4 +14,4 @@ Using plugins: transform-es2015-function-name {"firefox":52} transform-es2015-literals {"firefox":52} syntax-trailing-function-commas {"node":7.4} -src/in.js -> lib/in.js +src/in.js -> lib/in.js \ No newline at end of file diff --git a/experimental/babel-preset-env/test/debug-fixtures/specific-targets/stdout.txt b/experimental/babel-preset-env/test/debug-fixtures/specific-targets/stdout.txt index 3300cba223..9372c273aa 100644 --- a/experimental/babel-preset-env/test/debug-fixtures/specific-targets/stdout.txt +++ b/experimental/babel-preset-env/test/debug-fixtures/specific-targets/stdout.txt @@ -17,6 +17,7 @@ Using plugins: transform-es2015-block-scoped-functions {"edge":13,"ie":10,"ios":9,"safari":7} transform-es2015-block-scoping {"edge":13,"firefox":49,"ie":10,"ios":9,"safari":7} transform-es2015-classes {"ie":10,"ios":9,"safari":7} + transform-es2015-duplicate-keys {"ie":10,"safari":7} transform-es2015-computed-properties {"ie":10,"safari":7} check-es2015-constants {"edge":13,"firefox":49,"ie":10,"ios":9,"safari":7} transform-es2015-destructuring {"edge":13,"firefox":49,"ie":10,"ios":9,"safari":7} diff --git a/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/actual.js b/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/actual.js new file mode 100644 index 0000000000..d7bc7a47fb --- /dev/null +++ b/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/actual.js @@ -0,0 +1 @@ +var a = { b:1, b: 2}; diff --git a/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/expected.js b/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/expected.js new file mode 100644 index 0000000000..5f92666585 --- /dev/null +++ b/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/expected.js @@ -0,0 +1,3 @@ +function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } + +var a = _defineProperty({ b: 1 }, "b", 2); \ No newline at end of file diff --git a/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/options.json b/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/options.json new file mode 100644 index 0000000000..1f29c71c16 --- /dev/null +++ b/experimental/babel-preset-env/test/fixtures/preset-options/transform-duplicate-keys/options.json @@ -0,0 +1,7 @@ +{ + "presets": [ + ["../../../../lib", { + "modules": false + }] + ] +} From 0ede95a640c2d9400636c3676120623a6ed6a049 Mon Sep 17 00:00:00 2001 From: Brian Ng Date: Mon, 6 Mar 2017 14:56:23 -0600 Subject: [PATCH 15/24] 1.2.1 --- experimental/babel-preset-env/package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/experimental/babel-preset-env/package.json b/experimental/babel-preset-env/package.json index f94d332deb..d9dd27aab8 100644 --- a/experimental/babel-preset-env/package.json +++ b/experimental/babel-preset-env/package.json @@ -1,6 +1,6 @@ { "name": "babel-preset-env", - "version": "1.2.0", + "version": "1.2.1", "description": "A Babel preset for each environment.", "author": "Henry Zhu ", "homepage": "https://babeljs.io/", From 6c20876fd2c153d455ce543b88cd0b65688b028e Mon Sep 17 00:00:00 2001 From: Brian Ng Date: Mon, 6 Mar 2017 15:00:53 -0600 Subject: [PATCH 16/24] v1.2.1 changelog [skip ci] --- experimental/babel-preset-env/CHANGELOG.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/experimental/babel-preset-env/CHANGELOG.md b/experimental/babel-preset-env/CHANGELOG.md index 3ac5330942..cbef555505 100644 --- a/experimental/babel-preset-env/CHANGELOG.md +++ b/experimental/babel-preset-env/CHANGELOG.md @@ -1,5 +1,17 @@ # Changelog +## v1.2.1 (2017-03-06) + +### :bug: Bug Fix + +- Add transform-duplicate-keys mapping ([#192](https://github.com/babel/babel-preset-env/pull/192)) (@existentialism) + +Our plugin data was missing a mapping for the `transform-duplicate-keys` plugin which caused it to never be included. (s/o to @Timer for the report!) + +### :memo: Documentation + +- Clarify reasons for the uglify option in README.md ([#188](https://github.com/babel/babel-preset-env/pull/188)) (@mikegreiling) + ## v1.2.0 (2017-03-03) ### :rocket: New Feature From 8f0e70bad4d85030bbc644c762bdc38aedeaac32 Mon Sep 17 00:00:00 2001 From: Aaron Ang Date: Tue, 7 Mar 2017 20:17:38 -0800 Subject: [PATCH 17/24] Change CONTRIBUTING.md to use absolute paths [skip ci] --- experimental/babel-preset-env/CONTRIBUTING.md | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/experimental/babel-preset-env/CONTRIBUTING.md b/experimental/babel-preset-env/CONTRIBUTING.md index fad3b24823..e3c0b46aef 100644 --- a/experimental/babel-preset-env/CONTRIBUTING.md +++ b/experimental/babel-preset-env/CONTRIBUTING.md @@ -2,7 +2,7 @@ ### Adding a new plugin to support (when approved in the next ECMAScript version) -#### Update [`pluginFeatures.js`](/data/plugin-features.js) +#### Update [`pluginFeatures.js`](https://github.com/babel/babel-preset-env/blob/master/data/plugin-features.js) Example: @@ -12,7 +12,7 @@ Find the relevant entries on [compat-table](https://kangax.github.io/compat-tabl `exponentiation (**) operator` -Find the corresponding babel plugin: +Find the corresponding babel plugin: `transform-exponentiation-operator` @@ -26,8 +26,8 @@ Add add them in this structure: ], }, ``` - -#### Update [`plugins.json`](/data/plugins.json) + +#### Update [`plugins.json`](https://github.com/babel/babel-preset-env/blob/master/data/plugins.json) Until `compat-table` is a standalone npm module for data we are using the git url @@ -45,11 +45,11 @@ please read our [documentation on writing tests](https://github.com/babel/babel/ #### Testing the `debug` option -Testing debug output to `stdout` is similar. Under the `test/debug-fixtures`, +Testing debug output to `stdout` is similar. Under the `test/debug-fixtures`, create a folder with a descriptive name of your test, and add the following: -* Add a `options.json` file (just as the other tests, this is essentially a +* Add a `options.json` file (just as the other tests, this is essentially a `.babelrc`) with the desired test configuration (required) -* Add a `stdout.txt` file with the expected debug output. For added -convenience, if there is no `stdout.txt` present, the test runner will +* Add a `stdout.txt` file with the expected debug output. For added +convenience, if there is no `stdout.txt` present, the test runner will generate one for you. From 84d4b9de5d0e97c765af5c6d12e40d5725d4657b Mon Sep 17 00:00:00 2001 From: Artem Yavorsky Date: Wed, 8 Mar 2017 17:54:16 +0200 Subject: [PATCH 18/24] Add built-ins, better links, compat-table url, etc (#195) [skip ci] --- experimental/babel-preset-env/CONTRIBUTING.md | 36 +++++++++++++++---- 1 file changed, 30 insertions(+), 6 deletions(-) diff --git a/experimental/babel-preset-env/CONTRIBUTING.md b/experimental/babel-preset-env/CONTRIBUTING.md index e3c0b46aef..47de5fa6b3 100644 --- a/experimental/babel-preset-env/CONTRIBUTING.md +++ b/experimental/babel-preset-env/CONTRIBUTING.md @@ -2,13 +2,13 @@ ### Adding a new plugin to support (when approved in the next ECMAScript version) -#### Update [`pluginFeatures.js`](https://github.com/babel/babel-preset-env/blob/master/data/plugin-features.js) +#### Update [`plugin-features.js`](https://github.com/babel/babel-preset-env/blob/master/data/plugin-features.js) -Example: +*Example:* -In you were going to add `**` which is in ES2016: +If you were going to add `**` which is in ES2016: -Find the relevant entries on [compat-table](https://kangax.github.io/compat-table/): +Find the relevant entries on [compat-table](https://kangax.github.io/compat-table/es2016plus/#test-exponentiation_(**)_operator): `exponentiation (**) operator` @@ -16,7 +16,7 @@ Find the corresponding babel plugin: `transform-exponentiation-operator` -Add add them in this structure: +And add them in this structure: ```js // es2016 @@ -27,11 +27,35 @@ Add add them in this structure: }, ``` +#### Update [`built-in-features.js`](https://github.com/babel/babel-preset-env/blob/master/data/built-in-features.js) + +*Example:* + +In case you want to add `Object.values` which is in ES2017: + +Find the relevant feature and subfeature on [compat-table](https://kangax.github.io/compat-table/es2016plus/#test-Object_static_methods_Object.values) +and split it with `/`: + +`Object static methods / Object.values` + +Find the corresponding module on [core-js](https://github.com/zloirock/core-js/tree/master/modules): + +`es7.object.values.js` + +Find required ES version in [`built-in-features.js`](https://github.com/babel/babel-preset-env/blob/master/data/built-in-features.js) and add the new feature: + +```js +const es2017 = { + //... + "es7.object.values": "Object static methods / Object.values" +} +``` + #### Update [`plugins.json`](https://github.com/babel/babel-preset-env/blob/master/data/plugins.json) Until `compat-table` is a standalone npm module for data we are using the git url -`"compat-table": "github:kangax/compat-table#gh-pages",` +`"compat-table": "kangax/compat-table#[latest-commit-hash]"`, So we update and then run `npm run build-data`. If there are no changes, then `plugins.json` will be the same. From fe6a606c5810c96eb404ae168a6c84b3102e1a75 Mon Sep 17 00:00:00 2001 From: Joseph Rex Date: Fri, 10 Mar 2017 03:44:50 -0600 Subject: [PATCH 19/24] Changed word were to where in README --- experimental/babel-preset-env/README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/experimental/babel-preset-env/README.md b/experimental/babel-preset-env/README.md index bea51410e5..4795d4431a 100644 --- a/experimental/babel-preset-env/README.md +++ b/experimental/babel-preset-env/README.md @@ -44,7 +44,7 @@ Ref: [#7](https://github.com/babel/babel-preset-env/issues/7) > Currently located at [plugin-features.js](https://github.com/babel/babel-preset-env/blob/master/data/plugin-features.js). -This should be straightforward to do in most cases. There might be cases were plugins should be split up more or certain plugins aren't standalone enough (or impossible to do). +This should be straightforward to do in most cases. There might be cases where plugins should be split up more or certain plugins aren't standalone enough (or impossible to do). ### Support all plugins in Babel that are considered `latest` @@ -118,7 +118,7 @@ If you want to compile against the current node version, you can specify `"node" `Array | string` -A query to select browsers (ex: last 2 versions, > 5%) using [browserslist](https://github.com/ai/browserslist). +A query to select browsers (ex: last 2 versions, > 5%) using [browserslist](https://github.com/ai/browserslist). Note, browsers' results are overridden by explicit items from `targets`. From ded253f1ad3dbdba8ab92f5224d1815b6810885f Mon Sep 17 00:00:00 2001 From: Artem Yavorsky Date: Fri, 10 Mar 2017 14:17:18 +0200 Subject: [PATCH 20/24] Increase mocha timout to 10s. --- experimental/babel-preset-env/package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/experimental/babel-preset-env/package.json b/experimental/babel-preset-env/package.json index d9dd27aab8..ed0b82c013 100644 --- a/experimental/babel-preset-env/package.json +++ b/experimental/babel-preset-env/package.json @@ -15,7 +15,7 @@ "fix": "eslint . --fix", "ci": "npm run test", "changelog": "git log `git describe --tags --abbrev=0`..HEAD --pretty=format:' * %s (%an)' | grep -v 'Merge pull request'", - "test": "npm run build && mocha ./test --compilers js:babel-register -t 5000" + "test": "npm run build && mocha ./test --compilers js:babel-register -t 10000" }, "dependencies": { "babel-plugin-check-es2015-constants": "^6.3.13", From 4cf4ac6cbbce34c5f7e9bd185af41140a6b42cac Mon Sep 17 00:00:00 2001 From: Alex Kuzmenko Date: Fri, 10 Mar 2017 13:01:21 +0200 Subject: [PATCH 21/24] Enable code coverage --- experimental/babel-preset-env/.gitignore | 2 + experimental/babel-preset-env/codecov.yml | 4 + experimental/babel-preset-env/package.json | 5 +- experimental/babel-preset-env/yarn.lock | 599 ++++++++++++++++++++- 4 files changed, 589 insertions(+), 21 deletions(-) create mode 100644 experimental/babel-preset-env/codecov.yml diff --git a/experimental/babel-preset-env/.gitignore b/experimental/babel-preset-env/.gitignore index e746132e44..c632df2afb 100644 --- a/experimental/babel-preset-env/.gitignore +++ b/experimental/babel-preset-env/.gitignore @@ -1,6 +1,8 @@ node_modules +coverage lib test/tmp .DS_Store *.log .vscode +.nyc_output diff --git a/experimental/babel-preset-env/codecov.yml b/experimental/babel-preset-env/codecov.yml new file mode 100644 index 0000000000..3e31ee1814 --- /dev/null +++ b/experimental/babel-preset-env/codecov.yml @@ -0,0 +1,4 @@ +coverage: + parsers: + javascript: + enable_partials: yes diff --git a/experimental/babel-preset-env/package.json b/experimental/babel-preset-env/package.json index ed0b82c013..2d49ebd525 100644 --- a/experimental/babel-preset-env/package.json +++ b/experimental/babel-preset-env/package.json @@ -13,7 +13,8 @@ "dev": "babel -w src -d lib", "lint": "eslint .", "fix": "eslint . --fix", - "ci": "npm run test", + "cov": "nyc npm run test", + "ci": "nyc npm run test && nyc report --reporter=json && codecov -f coverage/coverage-final.json", "changelog": "git log `git describe --tags --abbrev=0`..HEAD --pretty=format:' * %s (%an)' | grep -v 'Merge pull request'", "test": "npm run build && mocha ./test --compilers js:babel-register -t 10000" }, @@ -58,6 +59,7 @@ "babel-preset-es2015": "^6.14.0", "babel-register": "^6.14.0", "chai": "^3.0.0", + "codecov": "^1.0.1", "compat-table": "kangax/compat-table#c38f039b8ea7fadf347d3e300fec3611645e31e9", "eslint": "^3.13.1", "eslint-config-babel": "^5.0.0", @@ -65,6 +67,7 @@ "fs-extra": "^2.0.0", "lodash": "^4.15.0", "mocha": "^3.0.2", + "nyc": "^10.1.2", "rimraf": "^2.5.4" }, "babel": { diff --git a/experimental/babel-preset-env/yarn.lock b/experimental/babel-preset-env/yarn.lock index 61f4c3d5e0..b690c65bd3 100644 --- a/experimental/babel-preset-env/yarn.lock +++ b/experimental/babel-preset-env/yarn.lock @@ -45,6 +45,14 @@ ajv@^4.7.0: co "^4.6.0" json-stable-stringify "^1.0.1" +align-text@^0.1.1, align-text@^0.1.3: + version "0.1.4" + resolved "https://registry.yarnpkg.com/align-text/-/align-text-0.1.4.tgz#0cd90a561093f35d0a99256c22b7069433fad117" + dependencies: + kind-of "^3.0.2" + longest "^1.0.1" + repeat-string "^1.5.2" + amdefine@>=0.0.4: version "1.0.1" resolved "https://registry.yarnpkg.com/amdefine/-/amdefine-1.0.1.tgz#4a5282ac164729e93619bcfd3ad151f817ce91f5" @@ -74,10 +82,20 @@ anymatch@^1.3.0: arrify "^1.0.0" micromatch "^2.1.5" +append-transform@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/append-transform/-/append-transform-0.4.0.tgz#d76ebf8ca94d276e247a36bad44a4b74ab611991" + dependencies: + default-require-extensions "^1.0.0" + aproba@^1.0.3: version "1.0.4" resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.0.4.tgz#2713680775e7614c8ba186c065d4e2e52d1072c0" +archy@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/archy/-/archy-1.0.0.tgz#f9c8c13757cc1dd7bc379ac77b2c62a5c2868c40" + are-we-there-yet@~1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-1.1.2.tgz#80e470e95a084794fe1899262c5667c6e88de1b3" @@ -91,6 +109,10 @@ argparse@^1.0.7: dependencies: sprintf-js "~1.0.2" +argv@>=0.0.2: + version "0.0.2" + resolved "https://registry.yarnpkg.com/argv/-/argv-0.0.2.tgz#ecbd16f8949b157183711b1bda334f37840185ab" + arr-diff@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-2.0.0.tgz#8f3b827f955a8bd669697e4a4256ac3ceae356cf" @@ -122,7 +144,7 @@ array-unique@^0.2.1: version "0.2.1" resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.2.1.tgz#a1d97ccafcbc2625cc70fadceb36a50c58b01a53" -arrify@^1.0.0: +arrify@^1.0.0, arrify@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/arrify/-/arrify-1.0.1.tgz#898508da2226f380df904728456849c1501a4b0d" @@ -154,6 +176,10 @@ async-each@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/async-each/-/async-each-1.0.1.tgz#19d386a1d9edc6e7c1c85d388aedbcc56d33602d" +async@^1.4.0, async@^1.4.2: + version "1.5.2" + resolved "https://registry.yarnpkg.com/async/-/async-1.5.2.tgz#ec6a61ae56480c0c3cb241c95618e20892f9672a" + asynckit@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" @@ -229,7 +255,7 @@ babel-eslint@^7.1.1: babylon "^6.13.0" lodash.pickby "^4.6.0" -babel-generator@^6.21.0: +babel-generator@^6.18.0, babel-generator@^6.21.0: version "6.21.0" resolved "https://registry.yarnpkg.com/babel-generator/-/babel-generator-6.21.0.tgz#605f1269c489a1c75deeca7ea16d43d4656c8494" dependencies: @@ -937,6 +963,18 @@ buffer-shims@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/buffer-shims/-/buffer-shims-1.0.0.tgz#9978ce317388c649ad8793028c3477ef044a8b51" +builtin-modules@^1.0.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-1.1.1.tgz#270f076c5a72c02f5b65a47df94c5fe3a278892f" + +caching-transform@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/caching-transform/-/caching-transform-1.0.1.tgz#6dbdb2f20f8d8fbce79f3e94e9d1742dcdf5c0a1" + dependencies: + md5-hex "^1.2.0" + mkdirp "^0.5.1" + write-file-atomic "^1.1.4" + caller-path@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/caller-path/-/caller-path-0.1.0.tgz#94085ef63581ecd3daa92444a8fe94e82577751f" @@ -947,6 +985,14 @@ callsites@^0.2.0: version "0.2.0" resolved "https://registry.yarnpkg.com/callsites/-/callsites-0.2.0.tgz#afab96262910a7f33c19a5775825c69f34e350ca" +camelcase@^1.0.2: + version "1.2.1" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-1.2.1.tgz#9bb5304d2e0b56698b2c758b08a3eaa9daa58a39" + +camelcase@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-3.0.0.tgz#32fc4b9fcdaf845fcdf7e73bb97cac2261f0ab0a" + caniuse-db@^1.0.30000601: version "1.0.30000602" resolved "https://registry.yarnpkg.com/caniuse-db/-/caniuse-db-1.0.30000602.tgz#06b2cbfb6c3aeef7ddb18cd588043549ad1a2d4e" @@ -955,6 +1001,13 @@ caseless@~0.11.0: version "0.11.0" resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.11.0.tgz#715b96ea9841593cc33067923f5ec60ebda4f7d7" +center-align@^0.1.1: + version "0.1.3" + resolved "https://registry.yarnpkg.com/center-align/-/center-align-0.1.3.tgz#aa0d32629b6ee972200411cbd4461c907bc2b7ad" + dependencies: + align-text "^0.1.3" + lazy-cache "^1.0.3" + chai@^3.0.0: version "3.5.0" resolved "https://registry.yarnpkg.com/chai/-/chai-3.5.0.tgz#4d02637b067fe958bdbfdd3a40ec56fef7373247" @@ -1021,6 +1074,22 @@ cli@~1.0.0: exit "0.1.2" glob "^7.1.1" +cliui@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-2.1.0.tgz#4b475760ff80264c762c3a1719032e91c7fea0d1" + dependencies: + center-align "^0.1.1" + right-align "^0.1.1" + wordwrap "0.0.2" + +cliui@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-3.2.0.tgz#120601537a916d29940f934da3b48d585a39213d" + dependencies: + string-width "^1.0.1" + strip-ansi "^3.0.1" + wrap-ansi "^2.0.0" + closurecompiler-externs@*: version "1.0.4" resolved "https://registry.yarnpkg.com/closurecompiler-externs/-/closurecompiler-externs-1.0.4.tgz#48ea3200b70a53d4681556c4a1706dec242537a3" @@ -1041,6 +1110,15 @@ code-point-at@^1.0.0: version "1.1.0" resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" +codecov@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/codecov/-/codecov-1.0.1.tgz#97260ceac0e96b8eda8d562006558a53a139dffd" + dependencies: + argv ">=0.0.2" + execSync "1.0.2" + request ">=2.42.0" + urlgrey ">=0.4.0" + combined-stream@^1.0.5, combined-stream@~1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.5.tgz#938370a57b4a51dea2c77c15d5c5fdf895164009" @@ -1053,6 +1131,10 @@ commander@2.9.0, commander@2.9.x, commander@^2.5.0, commander@^2.8.1, commander@ dependencies: graceful-readlink ">= 1.0.0" +commondir@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/commondir/-/commondir-1.0.1.tgz#ddd800da0c66127393cca5950ea968a3aaf1253b" + commoner@^0.10.1: version "0.10.8" resolved "https://registry.yarnpkg.com/commoner/-/commoner-0.10.8.tgz#34fc3672cd24393e8bb47e70caa0293811f4f2c5" @@ -1117,7 +1199,7 @@ console-control-strings@^1.0.0, console-control-strings@~1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" -convert-source-map@^1.1.0: +convert-source-map@^1.1.0, convert-source-map@^1.3.0: version "1.3.0" resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.3.0.tgz#e9f3e9c6e2728efc2676696a70eb382f73106a67" @@ -1129,6 +1211,13 @@ core-util-is@~1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" +cross-spawn@^4: + version "4.0.2" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-4.0.2.tgz#7b9247621c23adfdd3856004a823cbe397424d41" + dependencies: + lru-cache "^4.0.1" + which "^1.2.9" + cryptiles@2.x.x: version "2.0.5" resolved "https://registry.yarnpkg.com/cryptiles/-/cryptiles-2.0.5.tgz#3bdfecdc608147c1c67202fa291e7dca59eaa3b8" @@ -1174,12 +1263,20 @@ date-now@^0.1.4: version "0.1.4" resolved "https://registry.yarnpkg.com/date-now/-/date-now-0.1.4.tgz#eaf439fd4d4848ad74e5cc7dbef200672b9e345b" +debug-log@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/debug-log/-/debug-log-1.0.1.tgz#2307632d4c04382b8df8a32f70b895046d52745f" + debug@2.2.0, debug@^2.1.1, debug@^2.2.0, debug@~2.2.0: version "2.2.0" resolved "https://registry.yarnpkg.com/debug/-/debug-2.2.0.tgz#f87057e995b1a1f6ae6a4960664137bc56f039da" dependencies: ms "0.7.1" +decamelize@^1.0.0, decamelize@^1.1.1: + version "1.2.0" + resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" + deep-eql@^0.1.3: version "0.1.3" resolved "https://registry.yarnpkg.com/deep-eql/-/deep-eql-0.1.3.tgz#ef558acab8de25206cd713906d74e56930eb69f2" @@ -1194,6 +1291,12 @@ deep-is@~0.1.3: version "0.1.3" resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34" +default-require-extensions@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/default-require-extensions/-/default-require-extensions-1.0.0.tgz#f37ea15d3e13ffd9b437d33e1a75b5fb97874cb8" + dependencies: + strip-bom "^2.0.0" + define-properties@^1.0.1, define-properties@^1.1.2: version "1.1.2" resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.2.tgz#83a73f2fea569898fb737193c8f873caf6d45c94" @@ -1295,6 +1398,12 @@ entities@~1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/entities/-/entities-1.1.1.tgz#6e5c2d0a5621b5dadaecef80b90edfb5cd7772f0" +error-ex@^1.2.0: + version "1.3.1" + resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.1.tgz#f855a86ce61adc4e8621c3cda21e7a7612c3a8dc" + dependencies: + is-arrayish "^0.2.1" + es-abstract@^1.2.1, es-abstract@^1.4.3, es-abstract@^1.5.0, es-abstract@^1.5.1, es-abstract@^1.6.1: version "1.6.1" resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.6.1.tgz#bb8a2064120abcf928a086ea3d9043114285ec99" @@ -1532,6 +1641,12 @@ event-emitter@~0.3.4: d "~0.1.1" es5-ext "~0.10.7" +execSync@1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/execSync/-/execSync-1.0.2.tgz#1f42eda582225180053224ecdd3fd1960fdb3139" + dependencies: + temp "~0.5.1" + exit-hook@^1.0.0: version "1.1.1" resolved "https://registry.yarnpkg.com/exit-hook/-/exit-hook-1.1.1.tgz#f05ca233b48c05d54fff07765df8507e95c02ff8" @@ -1598,6 +1713,21 @@ fill-range@^2.1.0: repeat-element "^1.1.2" repeat-string "^1.5.2" +find-cache-dir@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-0.1.1.tgz#c8defae57c8a52a8a784f9e31c57c742e993a0b9" + dependencies: + commondir "^1.0.1" + mkdirp "^0.5.1" + pkg-dir "^1.0.0" + +find-up@^1.0.0, find-up@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-1.1.2.tgz#6b2e9822b1a2ce0a60ab64d610eccad53cb24d0f" + dependencies: + path-exists "^2.0.0" + pinkie-promise "^2.0.0" + flat-cache@^1.2.1: version "1.2.2" resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-1.2.2.tgz#fa86714e72c21db88601761ecf2f555d1abc6b96" @@ -1621,6 +1751,13 @@ foreach@^2.0.5: version "2.0.5" resolved "https://registry.yarnpkg.com/foreach/-/foreach-2.0.5.tgz#0bee005018aeb260d0a3af3ae658dd0136ec1b99" +foreground-child@^1.3.3, foreground-child@^1.5.3: + version "1.5.6" + resolved "https://registry.yarnpkg.com/foreground-child/-/foreground-child-1.5.6.tgz#4fd71ad2dfde96789b980a5c0a295937cb2f5ce9" + dependencies: + cross-spawn "^4" + signal-exit "^3.0.0" + forever-agent@~0.6.1: version "0.6.1" resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" @@ -1700,6 +1837,10 @@ generate-object-property@^1.1.0: dependencies: is-property "^1.0.0" +get-caller-file@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-1.0.2.tgz#f702e63127e7e231c160a80c1554acb70d5047e5" + getpass@^0.1.1: version "0.1.6" resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.6.tgz#283ffd9fc1256840875311c1b60e8c40187110e6" @@ -1740,7 +1881,7 @@ glob@7.0.5, glob@^7.0.0, glob@^7.0.3, glob@^7.0.5: once "^1.3.0" path-is-absolute "^1.0.0" -glob@^7.1.1: +glob@^7.0.6, glob@^7.1.1: version "7.1.1" resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.1.tgz#805211df04faaf1c63a3600306cdf5ade50b2ec8" dependencies: @@ -1766,10 +1907,14 @@ globby@^5.0.0: pify "^2.0.0" pinkie-promise "^2.0.0" -graceful-fs@^4.1.2, graceful-fs@^4.1.4, graceful-fs@^4.1.6: +graceful-fs@^4.1.11, graceful-fs@^4.1.2, graceful-fs@^4.1.4, graceful-fs@^4.1.6: version "4.1.11" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.1.11.tgz#0e8bdfe4d1ddb8854d64e04ea7c00e2a026e5658" +graceful-fs@~1: + version "1.2.3" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-1.2.3.tgz#15a4806a57547cb2d2dbf27f42e89a8c3451b364" + "graceful-readlink@>= 1.0.0": version "1.0.1" resolved "https://registry.yarnpkg.com/graceful-readlink/-/graceful-readlink-1.0.1.tgz#4cafad76bc62f02fa039b2f94e9a3dd3a391a725" @@ -1778,6 +1923,16 @@ growl@1.9.2: version "1.9.2" resolved "https://registry.yarnpkg.com/growl/-/growl-1.9.2.tgz#0ea7743715db8d8de2c5ede1775e1b45ac85c02f" +handlebars@^4.0.3: + version "4.0.6" + resolved "https://registry.yarnpkg.com/handlebars/-/handlebars-4.0.6.tgz#2ce4484850537f9c97a8026d5399b935c4ed4ed7" + dependencies: + async "^1.4.0" + optimist "^0.6.1" + source-map "^0.4.4" + optionalDependencies: + uglify-js "^2.6" + har-validator@~2.0.6: version "2.0.6" resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-2.0.6.tgz#cdcbc08188265ad119b6a5a7c8ab70eecfb5d27d" @@ -1827,6 +1982,10 @@ home-or-tmp@^2.0.0: os-homedir "^1.0.0" os-tmpdir "^1.0.1" +hosted-git-info@^2.1.4: + version "2.2.0" + resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.2.0.tgz#7a0d097863d886c0fabbdcd37bf1758d8becf8a5" + htmlparser2@3.8.x, htmlparser2@~3.8.1: version "3.8.3" resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-3.8.3.tgz#996c28b191516a8be86501a7d79757e5c70c1068" @@ -1900,6 +2059,14 @@ invariant@^2.2.0, invariant@^2.2.2: dependencies: loose-envify "^1.0.0" +invert-kv@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/invert-kv/-/invert-kv-1.0.0.tgz#104a8e4aaca6d3d8cd157a8ef8bfab2d7a3ffdb6" + +is-arrayish@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" + is-binary-path@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-1.0.1.tgz#75f16642b480f187a711c814161fd3a4a7655898" @@ -1910,6 +2077,12 @@ is-buffer@^1.0.2: version "1.1.4" resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.4.tgz#cfc86ccd5dc5a52fa80489111c6920c457e2d98b" +is-builtin-module@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-builtin-module/-/is-builtin-module-1.0.0.tgz#540572d34f7ac3119f8f76c30cbc1b1e037affbe" + dependencies: + builtin-modules "^1.0.0" + is-callable@^1.1.1, is-callable@^1.1.3: version "1.1.3" resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.1.3.tgz#86eb75392805ddc33af71c92a0eedf74ee7604b2" @@ -2019,6 +2192,10 @@ is-typedarray@~1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" +is-utf8@^0.2.0: + version "0.2.1" + resolved "https://registry.yarnpkg.com/is-utf8/-/is-utf8-0.2.1.tgz#4b0da1442104d1b336340e80797e865cf39f7d72" + isarray@0.0.1: version "0.0.1" resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" @@ -2027,6 +2204,10 @@ isarray@1.0.0, isarray@^1.0.0, isarray@~1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" +isexe@^1.1.1: + version "1.1.2" + resolved "https://registry.yarnpkg.com/isexe/-/isexe-1.1.2.tgz#36f3e22e60750920f5e7241a476a8c6a42275ad0" + isobject@^2.0.0: version "2.1.0" resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89" @@ -2037,6 +2218,54 @@ isstream@~0.1.2: version "0.1.2" resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" +istanbul-lib-coverage@^1.0.0, istanbul-lib-coverage@^1.0.0-alpha, istanbul-lib-coverage@^1.0.0-alpha.0, istanbul-lib-coverage@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-1.0.1.tgz#f263efb519c051c5f1f3343034fc40e7b43ff212" + +istanbul-lib-hook@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-hook/-/istanbul-lib-hook-1.0.0.tgz#fc5367ee27f59268e8f060b0c7aaf051d9c425c5" + dependencies: + append-transform "^0.4.0" + +istanbul-lib-instrument@^1.4.2: + version "1.4.2" + resolved "https://registry.yarnpkg.com/istanbul-lib-instrument/-/istanbul-lib-instrument-1.4.2.tgz#0e2fdfac93c1dabf2e31578637dc78a19089f43e" + dependencies: + babel-generator "^6.18.0" + babel-template "^6.16.0" + babel-traverse "^6.18.0" + babel-types "^6.18.0" + babylon "^6.13.0" + istanbul-lib-coverage "^1.0.0" + semver "^5.3.0" + +istanbul-lib-report@^1.0.0-alpha.3: + version "1.0.0-alpha.3" + resolved "https://registry.yarnpkg.com/istanbul-lib-report/-/istanbul-lib-report-1.0.0-alpha.3.tgz#32d5f6ec7f33ca3a602209e278b2e6ff143498af" + dependencies: + async "^1.4.2" + istanbul-lib-coverage "^1.0.0-alpha" + mkdirp "^0.5.1" + path-parse "^1.0.5" + rimraf "^2.4.3" + supports-color "^3.1.2" + +istanbul-lib-source-maps@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-source-maps/-/istanbul-lib-source-maps-1.1.0.tgz#9d429218f35b823560ea300a96ff0c3bbdab785f" + dependencies: + istanbul-lib-coverage "^1.0.0-alpha.0" + mkdirp "^0.5.1" + rimraf "^2.4.4" + source-map "^0.5.3" + +istanbul-reports@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/istanbul-reports/-/istanbul-reports-1.0.1.tgz#9a17176bc4a6cbebdae52b2f15961d52fa623fbc" + dependencies: + handlebars "^4.0.3" + jodid25519@^1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/jodid25519/-/jodid25519-1.0.2.tgz#06d4912255093419477d425633606e0e90782967" @@ -2163,6 +2392,16 @@ kind-of@^3.0.2: dependencies: is-buffer "^1.0.2" +lazy-cache@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/lazy-cache/-/lazy-cache-1.0.4.tgz#a1d78fc3a50474cb80845d3b3b6e1da49a446e8e" + +lcid@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/lcid/-/lcid-1.0.0.tgz#308accafa0bc483a3867b4b6f2b9506251d1b835" + dependencies: + invert-kv "^1.0.0" + levn@^0.3.0, levn@~0.3.0: version "0.3.0" resolved "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz#3b09924edf9f083c0490fdd4c0bc4421e04764ee" @@ -2170,6 +2409,16 @@ levn@^0.3.0, levn@~0.3.0: prelude-ls "~1.1.2" type-check "~0.3.2" +load-json-file@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/load-json-file/-/load-json-file-1.1.0.tgz#956905708d58b4bab4c2261b04f59f31c99374c0" + dependencies: + graceful-fs "^4.1.2" + parse-json "^2.2.0" + pify "^2.0.0" + pinkie-promise "^2.0.0" + strip-bom "^2.0.0" + lodash._baseassign@^3.0.0: version "3.2.0" resolved "https://registry.yarnpkg.com/lodash._baseassign/-/lodash._baseassign-3.2.0.tgz#8c38a099500f215ad09e59f1722fd0c52bfe0a4e" @@ -2229,13 +2478,40 @@ lodash@^4.0.0, lodash@^4.1.0, lodash@^4.15.0, lodash@^4.2.0, lodash@^4.3.0: version "4.17.4" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.4.tgz#78203a4d1c328ae1d86dca6460e369b57f4055ae" +longest@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/longest/-/longest-1.0.1.tgz#30a0b2da38f73770e8294a0d22e6625ed77d0097" + loose-envify@^1.0.0: version "1.3.0" resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.3.0.tgz#6b26248c42f6d4fa4b0d8542f78edfcde35642a8" dependencies: js-tokens "^2.0.0" -micromatch@^2.1.5: +lru-cache@^4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-4.0.2.tgz#1d17679c069cda5d040991a09dbc2c0db377e55e" + dependencies: + pseudomap "^1.0.1" + yallist "^2.0.0" + +md5-hex@^1.2.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/md5-hex/-/md5-hex-1.3.0.tgz#d2c4afe983c4370662179b8cad145219135046c4" + dependencies: + md5-o-matic "^0.1.1" + +md5-o-matic@^0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/md5-o-matic/-/md5-o-matic-0.1.1.tgz#822bccd65e117c514fab176b25945d54100a03c3" + +merge-source-map@^1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/merge-source-map/-/merge-source-map-1.0.3.tgz#da1415f2722a5119db07b14c4f973410863a2abf" + dependencies: + source-map "^0.5.3" + +micromatch@^2.1.5, micromatch@^2.3.11: version "2.3.11" resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-2.3.11.tgz#86677c97d1720b363431d04d0d15293bd38c1565" dependencies: @@ -2269,7 +2545,7 @@ mime-types@^2.1.12, mime-types@~2.1.7: dependencies: brace-expansion "^1.0.0" -minimist@0.0.8: +minimist@0.0.8, minimist@~0.0.1: version "0.0.8" resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.8.tgz#857fcabfc3397d2625b8228262e86aa7a011b05d" @@ -2335,6 +2611,15 @@ nopt@~3.0.6: dependencies: abbrev "1" +normalize-package-data@^2.3.2: + version "2.3.6" + resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.3.6.tgz#498fa420c96401f787402ba21e600def9f981fff" + dependencies: + hosted-git-info "^2.1.4" + is-builtin-module "^1.0.0" + semver "2 || 3 || 4 || 5" + validate-npm-package-license "^3.0.1" + normalize-path@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-2.0.1.tgz#47886ac1662760d4261b7d979d241709d3ce3f7a" @@ -2362,6 +2647,38 @@ number-is-nan@^1.0.0: version "1.3.9" resolved "https://registry.yarnpkg.com/nwmatcher/-/nwmatcher-1.3.9.tgz#8bab486ff7fa3dfd086656bbe8b17116d3692d2a" +nyc@^10.1.2: + version "10.1.2" + resolved "https://registry.yarnpkg.com/nyc/-/nyc-10.1.2.tgz#ea7acaa20a235210101604f4e7d56d28453b0274" + dependencies: + archy "^1.0.0" + arrify "^1.0.1" + caching-transform "^1.0.0" + convert-source-map "^1.3.0" + debug-log "^1.0.1" + default-require-extensions "^1.0.0" + find-cache-dir "^0.1.1" + find-up "^1.1.2" + foreground-child "^1.5.3" + glob "^7.0.6" + istanbul-lib-coverage "^1.0.1" + istanbul-lib-hook "^1.0.0" + istanbul-lib-instrument "^1.4.2" + istanbul-lib-report "^1.0.0-alpha.3" + istanbul-lib-source-maps "^1.1.0" + istanbul-reports "^1.0.0" + md5-hex "^1.2.0" + merge-source-map "^1.0.2" + micromatch "^2.3.11" + mkdirp "^0.5.0" + resolve-from "^2.0.0" + rimraf "^2.5.4" + signal-exit "^3.0.1" + spawn-wrap "1.2.4" + test-exclude "^3.3.0" + yargs "^6.6.0" + yargs-parser "^4.0.2" + oauth-sign@~0.8.1: version "0.8.2" resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.8.2.tgz#46a6ab7f0aead8deae9ec0565780b7d4efeb9d43" @@ -2434,6 +2751,13 @@ onetime@^1.0.0: version "1.1.0" resolved "https://registry.yarnpkg.com/onetime/-/onetime-1.1.0.tgz#a1f7838f8314c516f05ecefcbc4ccfe04b4ed789" +optimist@^0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/optimist/-/optimist-0.6.1.tgz#da3ea74686fa21a19a111c326e90eb15a0196686" + dependencies: + minimist "~0.0.1" + wordwrap "~0.0.2" + optionator@^0.8.1, optionator@^0.8.2: version "0.8.2" resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.8.2.tgz#364c5e409d3f4d6301d6c0b4c05bba50180aeb64" @@ -2445,10 +2769,16 @@ optionator@^0.8.1, optionator@^0.8.2: type-check "~0.3.2" wordwrap "~1.0.0" -os-homedir@^1.0.0: +os-homedir@^1.0.0, os-homedir@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/os-homedir/-/os-homedir-1.0.2.tgz#ffbc4988336e0e833de0c168c7ef152121aa7fb3" +os-locale@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/os-locale/-/os-locale-1.4.0.tgz#20f9f17ae29ed345e8bde583b13d2009803c14d9" + dependencies: + lcid "^1.0.0" + os-tmpdir@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" @@ -2470,10 +2800,22 @@ parse-glob@^3.0.4: is-extglob "^1.0.0" is-glob "^2.0.0" +parse-json@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-2.2.0.tgz#f480f40434ef80741f8469099f8dea18f55a4dc9" + dependencies: + error-ex "^1.2.0" + parse5@^1.5.1: version "1.5.1" resolved "https://registry.yarnpkg.com/parse5/-/parse5-1.5.1.tgz#9b7f3b0de32be78dc2401b17573ccaf0f6f59d94" +path-exists@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-2.1.0.tgz#0feb6c64f0fc518d9a754dd5efb62c7022761f4b" + dependencies: + pinkie-promise "^2.0.0" + path-is-absolute@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" @@ -2482,6 +2824,18 @@ path-is-inside@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/path-is-inside/-/path-is-inside-1.0.2.tgz#365417dede44430d1c11af61027facf074bdfc53" +path-parse@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.5.tgz#3c1adf871ea9cd6c9431b6ea2bd74a0ff055c4c1" + +path-type@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-1.1.0.tgz#59c44f7ee491da704da415da5a4070ba4f8fe441" + dependencies: + graceful-fs "^4.1.2" + pify "^2.0.0" + pinkie-promise "^2.0.0" + pify@^2.0.0: version "2.3.0" resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" @@ -2496,6 +2850,12 @@ pinkie@^2.0.0: version "2.0.4" resolved "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz#72556b80cfa0d48a974e80e77248e80ed4f7f870" +pkg-dir@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-1.0.0.tgz#7a4b508a8d5bb2d629d447056ff4e9c9314cf3d4" + dependencies: + find-up "^1.0.0" + pluralize@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/pluralize/-/pluralize-1.2.1.tgz#d1a21483fd22bb41e58a12fa3421823140897c45" @@ -2520,6 +2880,10 @@ progress@^1.1.8: version "1.1.8" resolved "https://registry.yarnpkg.com/progress/-/progress-1.1.8.tgz#e260c78f6161cdd9b0e56cc3e0a85de17c7a57be" +pseudomap@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3" + punycode@^1.4.1: version "1.4.1" resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" @@ -2548,6 +2912,21 @@ rc@~1.1.6: minimist "^1.2.0" strip-json-comments "~1.0.4" +read-pkg-up@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-1.0.1.tgz#9d63c13276c065918d57f002a57f40a1b643fb02" + dependencies: + find-up "^1.0.0" + read-pkg "^1.0.0" + +read-pkg@^1.0.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/read-pkg/-/read-pkg-1.1.0.tgz#f5ffaa5ecd29cb31c0474bca7d756b6bb29e3f28" + dependencies: + load-json-file "^1.0.0" + normalize-package-data "^2.3.2" + path-type "^1.0.0" + readable-stream@1.1: version "1.1.13" resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.1.13.tgz#f6eef764f514c89e2b9e23146a75ba106756d23e" @@ -2677,7 +3056,7 @@ repeating@^2.0.0: dependencies: is-finite "^1.0.0" -request@^2.55.0, request@^2.79.0: +request@>=2.42.0, request@^2.55.0, request@^2.79.0: version "2.79.0" resolved "https://registry.yarnpkg.com/request/-/request-2.79.0.tgz#4dfe5bf6be8b8cdc37fcf93e04b65577722710de" dependencies: @@ -2702,6 +3081,14 @@ request@^2.55.0, request@^2.79.0: tunnel-agent "~0.4.1" uuid "^3.0.0" +require-directory@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" + +require-main-filename@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-1.0.1.tgz#97f717b69d48784f5f526a6c5aa8ffdda055a4d1" + require-uncached@^1.0.2: version "1.0.3" resolved "https://registry.yarnpkg.com/require-uncached/-/require-uncached-1.0.3.tgz#4e0d56d6c9662fd31e43011c4b95aa49955421d3" @@ -2713,6 +3100,10 @@ resolve-from@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-1.0.1.tgz#26cbfe935d1aeeeabb29bc3fe5aeb01e93d44226" +resolve-from@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-2.0.0.tgz#9480ab20e94ffa1d9e80a804c7ea147611966b57" + resolve@^1.1.6: version "1.2.0" resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.2.0.tgz#9589c3f2f6149d1417a40becc1663db6ec6bc26c" @@ -2724,12 +3115,24 @@ restore-cursor@^1.0.1: exit-hook "^1.0.0" onetime "^1.0.0" -rimraf@2, rimraf@^2.2.8, rimraf@^2.5.4, rimraf@~2.5.1, rimraf@~2.5.4: +right-align@^0.1.1: + version "0.1.3" + resolved "https://registry.yarnpkg.com/right-align/-/right-align-0.1.3.tgz#61339b722fe6a3515689210d24e14c96148613ef" + dependencies: + align-text "^0.1.1" + +rimraf@2, rimraf@^2.2.8, rimraf@^2.3.3, rimraf@^2.4.3, rimraf@^2.4.4, rimraf@^2.5.4, rimraf@~2.5.1, rimraf@~2.5.4: version "2.5.4" resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.5.4.tgz#96800093cbf1a0c86bd95b4625467535c29dfa04" dependencies: glob "^7.0.5" +rimraf@~2.1.4: + version "2.1.4" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.1.4.tgz#5a6eb62eeda068f51ede50f29b3e5cd22f3d9bb2" + optionalDependencies: + graceful-fs "~1" + rsvp@^3.0.13: version "3.3.3" resolved "https://registry.yarnpkg.com/rsvp/-/rsvp-3.3.3.tgz#34633caaf8bc66ceff4be3c2e1dffd032538a813" @@ -2748,15 +3151,15 @@ sax@^1.1.4: version "1.2.1" resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.1.tgz#7b8e656190b228e81a66aea748480d828cd2d37a" +"semver@2 || 3 || 4 || 5", semver@^5.3.0, semver@~5.3.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-5.3.0.tgz#9b2ce5d3de02d17c6012ad326aa6b4d0cf54f94f" + semver@^4.3.3: version "4.3.6" resolved "https://registry.yarnpkg.com/semver/-/semver-4.3.6.tgz#300bc6e0e86374f7ba61068b5b1ecd57fc6532da" -semver@~5.3.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/semver/-/semver-5.3.0.tgz#9b2ce5d3de02d17c6012ad326aa6b4d0cf54f94f" - -set-blocking@~2.0.0: +set-blocking@^2.0.0, set-blocking@~2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" @@ -2776,7 +3179,11 @@ shelljs@^0.7.5: interpret "^1.0.0" rechoir "^0.6.2" -signal-exit@^3.0.0: +signal-exit@^2.0.0: + version "2.1.2" + resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-2.1.2.tgz#375879b1f92ebc3b334480d038dc546a6d558564" + +signal-exit@^3.0.0, signal-exit@^3.0.1: version "3.0.2" resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.2.tgz#b5fdc08f1287ea1178628e415e25132b73646c6d" @@ -2796,6 +3203,10 @@ slice-ansi@0.0.4: version "0.0.4" resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-0.0.4.tgz#edbf8903f66f7ce2f8eafd6ceed65e264c831b35" +slide@^1.1.5: + version "1.1.6" + resolved "https://registry.yarnpkg.com/slide/-/slide-1.1.6.tgz#56eb027d65b4d2dce6cb2e2d32c4d4afc9e1d707" + sntp@1.x.x: version "1.0.9" resolved "https://registry.yarnpkg.com/sntp/-/sntp-1.0.9.tgz#6541184cc90aeea6c6e7b35e2659082443c66198" @@ -2820,13 +3231,13 @@ source-map@0.1.32: dependencies: amdefine ">=0.0.4" -source-map@^0.4.2: +source-map@^0.4.2, source-map@^0.4.4: version "0.4.4" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.4.4.tgz#eba4f5da9c0dc999de68032d8b4f76173652036b" dependencies: amdefine ">=0.0.4" -source-map@^0.5.0, source-map@^0.5.3, source-map@~0.5.0: +source-map@^0.5.0, source-map@^0.5.3, source-map@~0.5.0, source-map@~0.5.1: version "0.5.6" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.6.tgz#75ce38f52bf0733c5a7f0c118d81334a2bb5f412" @@ -2836,6 +3247,31 @@ source-map@~0.2.0: dependencies: amdefine ">=0.0.4" +spawn-wrap@1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/spawn-wrap/-/spawn-wrap-1.2.4.tgz#920eb211a769c093eebfbd5b0e7a5d2e68ab2e40" + dependencies: + foreground-child "^1.3.3" + mkdirp "^0.5.0" + os-homedir "^1.0.1" + rimraf "^2.3.3" + signal-exit "^2.0.0" + which "^1.2.4" + +spdx-correct@~1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/spdx-correct/-/spdx-correct-1.0.2.tgz#4b3073d933ff51f3912f03ac5519498a4150db40" + dependencies: + spdx-license-ids "^1.0.2" + +spdx-expression-parse@~1.0.0: + version "1.0.4" + resolved "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz#9bdf2f20e1f40ed447fbe273266191fced51626c" + +spdx-license-ids@^1.0.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz#c9df7a3424594ade6bd11900d596696dc06bac57" + sprintf-js@~1.0.2: version "1.0.3" resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" @@ -2867,7 +3303,7 @@ string-at@^1.0.1: es-abstract "^1.2.1" function-bind "^1.0.2" -string-width@^1.0.1: +string-width@^1.0.1, string-width@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" dependencies: @@ -2934,6 +3370,12 @@ strip-ansi@^3.0.0, strip-ansi@^3.0.1: dependencies: ansi-regex "^2.0.0" +strip-bom@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-2.0.0.tgz#6219a85616520491f35788bdbf1447a99c7e6b0e" + dependencies: + is-utf8 "^0.2.0" + strip-bom@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" @@ -2946,7 +3388,7 @@ strip-json-comments@~2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" -supports-color@3.1.2: +supports-color@3.1.2, supports-color@^3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-3.1.2.tgz#72a262894d9d408b956ca05ff37b2ed8a6e2a2d5" dependencies: @@ -2996,6 +3438,22 @@ tar@~2.2.1: fstream "^1.0.2" inherits "2" +temp@~0.5.1: + version "0.5.1" + resolved "https://registry.yarnpkg.com/temp/-/temp-0.5.1.tgz#77ab19c79aa7b593cbe4fac2441768cad987b8df" + dependencies: + rimraf "~2.1.4" + +test-exclude@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/test-exclude/-/test-exclude-3.3.0.tgz#7a17ca1239988c98367b0621456dbb7d4bc38977" + dependencies: + arrify "^1.0.1" + micromatch "^2.3.11" + object-assign "^4.1.0" + read-pkg-up "^1.0.1" + require-main-filename "^1.0.1" + text-table@~0.2.0: version "0.2.0" resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" @@ -3066,10 +3524,26 @@ typescript@latest: version "2.1.4" resolved "https://registry.yarnpkg.com/typescript/-/typescript-2.1.4.tgz#b53b69fb841126acb1dd4b397d21daba87572251" +uglify-js@^2.6: + version "2.8.10" + resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.8.10.tgz#bd0be568369f7be8cad2a4161fa90ada118ef73a" + dependencies: + source-map "~0.5.1" + uglify-to-browserify "~1.0.0" + yargs "~3.10.0" + +uglify-to-browserify@~1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz#6e0924d6bda6b5afe349e39a6d632850a0f882b7" + uid-number@~0.0.6: version "0.0.6" resolved "https://registry.yarnpkg.com/uid-number/-/uid-number-0.0.6.tgz#0ea10e8035e8eb5b8e4449f06da1c730663baa81" +urlgrey@>=0.4.0: + version "0.4.4" + resolved "https://registry.yarnpkg.com/urlgrey/-/urlgrey-0.4.4.tgz#892fe95960805e85519f1cd4389f2cb4cbb7652f" + user-home@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/user-home/-/user-home-1.1.1.tgz#2b5be23a32b63a7c9deb8d0f28d485724a3df190" @@ -3094,6 +3568,13 @@ v8flags@^2.0.10: dependencies: user-home "^1.1.1" +validate-npm-package-license@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz#2804babe712ad3379459acfbe24746ab2c303fbc" + dependencies: + spdx-correct "~1.0.0" + spdx-expression-parse "~1.0.0" + verror@1.3.6: version "1.3.6" resolved "https://registry.yarnpkg.com/verror/-/verror-1.3.6.tgz#cff5df12946d297d2baaefaa2689e25be01c005c" @@ -3110,20 +3591,57 @@ whatwg-url-compat@~0.6.5: dependencies: tr46 "~0.0.1" +which-module@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/which-module/-/which-module-1.0.0.tgz#bba63ca861948994ff307736089e3b96026c2a4f" + +which@^1.2.4, which@^1.2.9: + version "1.2.12" + resolved "https://registry.yarnpkg.com/which/-/which-1.2.12.tgz#de67b5e450269f194909ef23ece4ebe416fa1192" + dependencies: + isexe "^1.1.1" + wide-align@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.0.tgz#40edde802a71fea1f070da3e62dcda2e7add96ad" dependencies: string-width "^1.0.1" +window-size@0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/window-size/-/window-size-0.1.0.tgz#5438cd2ea93b202efa3a19fe8887aee7c94f9c9d" + +wordwrap@0.0.2: + version "0.0.2" + resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.2.tgz#b79669bb42ecb409f83d583cad52ca17eaa1643f" + +wordwrap@~0.0.2: + version "0.0.3" + resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.3.tgz#a3d5da6cd5c0bc0008d37234bbaf1bed63059107" + wordwrap@~1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-1.0.0.tgz#27584810891456a4171c8d0226441ade90cbcaeb" +wrap-ansi@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-2.1.0.tgz#d8fc3d284dd05794fe84973caecdd1cf824fdd85" + dependencies: + string-width "^1.0.1" + strip-ansi "^3.0.1" + wrappy@1: version "1.0.2" resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" +write-file-atomic@^1.1.4: + version "1.3.1" + resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-1.3.1.tgz#7d45ba32316328dd1ec7d90f60ebc0d845bb759a" + dependencies: + graceful-fs "^4.1.11" + imurmurhash "^0.1.4" + slide "^1.1.5" + write@^0.2.1: version "0.2.1" resolved "https://registry.yarnpkg.com/write/-/write-0.2.1.tgz#5fc03828e264cea3fe91455476f7a3c566cb0757" @@ -3137,3 +3655,44 @@ write@^0.2.1: xtend@^4.0.0: version "4.0.1" resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.1.tgz#a5c6d532be656e23db820efb943a1f04998d63af" + +y18n@^3.2.1: + version "3.2.1" + resolved "https://registry.yarnpkg.com/y18n/-/y18n-3.2.1.tgz#6d15fba884c08679c0d77e88e7759e811e07fa41" + +yallist@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.0.0.tgz#306c543835f09ee1a4cb23b7bce9ab341c91cdd4" + +yargs-parser@^4.0.2, yargs-parser@^4.2.0: + version "4.2.1" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-4.2.1.tgz#29cceac0dc4f03c6c87b4a9f217dd18c9f74871c" + dependencies: + camelcase "^3.0.0" + +yargs@^6.6.0: + version "6.6.0" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-6.6.0.tgz#782ec21ef403345f830a808ca3d513af56065208" + dependencies: + camelcase "^3.0.0" + cliui "^3.2.0" + decamelize "^1.1.1" + get-caller-file "^1.0.1" + os-locale "^1.4.0" + read-pkg-up "^1.0.1" + require-directory "^2.1.1" + require-main-filename "^1.0.1" + set-blocking "^2.0.0" + string-width "^1.0.2" + which-module "^1.0.0" + y18n "^3.2.1" + yargs-parser "^4.2.0" + +yargs@~3.10.0: + version "3.10.0" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-3.10.0.tgz#f7ee7bd857dd7c1d2d38c0e74efbd681d1431fd1" + dependencies: + camelcase "^1.0.2" + cliui "^2.1.0" + decamelize "^1.0.0" + window-size "0.1.0" From 7d7f06c10e40d17c8c0966e49a46c74514e9b264 Mon Sep 17 00:00:00 2001 From: Alex Kuzmenko Date: Fri, 10 Mar 2017 15:33:19 +0200 Subject: [PATCH 22/24] Add codecov badge --- experimental/babel-preset-env/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/experimental/babel-preset-env/README.md b/experimental/babel-preset-env/README.md index 4795d4431a..88c8c0e098 100644 --- a/experimental/babel-preset-env/README.md +++ b/experimental/babel-preset-env/README.md @@ -1,4 +1,4 @@ -# babel-preset-env [![npm](https://img.shields.io/npm/v/babel-preset-env.svg)](https://www.npmjs.com/package/babel-preset-env) [![travis](https://img.shields.io/travis/babel/babel-preset-env/master.svg)](https://travis-ci.org/babel/babel-preset-env) [![npm-downloads](https://img.shields.io/npm/dm/babel-preset-env.svg)](https://www.npmjs.com/package/babel-preset-env) +# babel-preset-env [![npm](https://img.shields.io/npm/v/babel-preset-env.svg)](https://www.npmjs.com/package/babel-preset-env) [![travis](https://img.shields.io/travis/babel/babel-preset-env/master.svg)](https://travis-ci.org/babel/babel-preset-env) [![npm-downloads](https://img.shields.io/npm/dm/babel-preset-env.svg)](https://www.npmjs.com/package/babel-preset-env) [![codecov](https://img.shields.io/codecov/c/github/babel/babel-preset-env/master.svg?maxAge=43200)](https://codecov.io/github/babel/babel-preset-env) > A Babel preset that can automatically determine the Babel plugins and polyfills you need based on your supported environments. From 1738cb66905bee0e3db3b52393227e057d7ab7d6 Mon Sep 17 00:00:00 2001 From: Alex Kuzmenko Date: Fri, 10 Mar 2017 17:52:14 +0200 Subject: [PATCH 23/24] Add babel-plugin-istanbul --- experimental/babel-preset-env/package.json | 16 +++++-- experimental/babel-preset-env/yarn.lock | 49 +++++++++++++++++++++- 2 files changed, 60 insertions(+), 5 deletions(-) diff --git a/experimental/babel-preset-env/package.json b/experimental/babel-preset-env/package.json index 2d49ebd525..f2d61daea7 100644 --- a/experimental/babel-preset-env/package.json +++ b/experimental/babel-preset-env/package.json @@ -13,8 +13,8 @@ "dev": "babel -w src -d lib", "lint": "eslint .", "fix": "eslint . --fix", - "cov": "nyc npm run test", - "ci": "nyc npm run test && nyc report --reporter=json && codecov -f coverage/coverage-final.json", + "cov": "BABEL_ENV=test nyc npm run test", + "ci": "npm run cov && nyc report --reporter=json && codecov -f coverage/coverage-final.json", "changelog": "git log `git describe --tags --abbrev=0`..HEAD --pretty=format:' * %s (%an)' | grep -v 'Merge pull request'", "test": "npm run build && mocha ./test --compilers js:babel-register -t 10000" }, @@ -55,6 +55,7 @@ "babel-eslint": "^7.1.1", "babel-helper-fixtures": "^6.22.0", "babel-helper-plugin-test-runner": "^6.18.0", + "babel-plugin-istanbul": "^4.0.0", "babel-plugin-transform-flow-strip-types": "^6.8.0", "babel-preset-es2015": "^6.14.0", "babel-register": "^6.14.0", @@ -81,6 +82,15 @@ ], "plugins": [ "transform-flow-strip-types" - ] + ], + "env": { + "test": { + "plugins": ["istanbul"] + } + } + }, + "nyc": { + "all": true, + "include": ["src/*.js"] } } diff --git a/experimental/babel-preset-env/yarn.lock b/experimental/babel-preset-env/yarn.lock index b690c65bd3..ee2ab92880 100644 --- a/experimental/babel-preset-env/yarn.lock +++ b/experimental/babel-preset-env/yarn.lock @@ -425,6 +425,14 @@ babel-plugin-check-es2015-constants@^6.3.13: dependencies: babel-runtime "^6.0.0" +babel-plugin-istanbul@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/babel-plugin-istanbul/-/babel-plugin-istanbul-4.0.0.tgz#36bde8fbef4837e5ff0366531a2beabd7b1ffa10" + dependencies: + find-up "^2.1.0" + istanbul-lib-instrument "^1.4.2" + test-exclude "^4.0.0" + babel-plugin-syntax-async-functions@^6.8.0: version "6.13.0" resolved "https://registry.yarnpkg.com/babel-plugin-syntax-async-functions/-/babel-plugin-syntax-async-functions-6.13.0.tgz#cad9cad1191b5ad634bf30ae0872391e0647be95" @@ -1728,6 +1736,12 @@ find-up@^1.0.0, find-up@^1.1.2: path-exists "^2.0.0" pinkie-promise "^2.0.0" +find-up@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-2.1.0.tgz#45d1b7e506c717ddd482775a2b77920a3c0c57a7" + dependencies: + locate-path "^2.0.0" + flat-cache@^1.2.1: version "1.2.2" resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-1.2.2.tgz#fa86714e72c21db88601761ecf2f555d1abc6b96" @@ -1870,7 +1884,7 @@ glob@5.0.x, glob@^5.0.15, glob@^5.0.5: once "^1.3.0" path-is-absolute "^1.0.0" -glob@7.0.5, glob@^7.0.0, glob@^7.0.3, glob@^7.0.5: +glob@7.0.5, glob@^7.0.3: version "7.0.5" resolved "https://registry.yarnpkg.com/glob/-/glob-7.0.5.tgz#b4202a69099bbb4d292a7c1b95b6682b67ebdc95" dependencies: @@ -1881,7 +1895,7 @@ glob@7.0.5, glob@^7.0.0, glob@^7.0.3, glob@^7.0.5: once "^1.3.0" path-is-absolute "^1.0.0" -glob@^7.0.6, glob@^7.1.1: +glob@^7.0.0, glob@^7.0.5, glob@^7.0.6, glob@^7.1.1: version "7.1.1" resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.1.tgz#805211df04faaf1c63a3600306cdf5ade50b2ec8" dependencies: @@ -2419,6 +2433,13 @@ load-json-file@^1.0.0: pinkie-promise "^2.0.0" strip-bom "^2.0.0" +locate-path@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e" + dependencies: + p-locate "^2.0.0" + path-exists "^3.0.0" + lodash._baseassign@^3.0.0: version "3.2.0" resolved "https://registry.yarnpkg.com/lodash._baseassign/-/lodash._baseassign-3.2.0.tgz#8c38a099500f215ad09e59f1722fd0c52bfe0a4e" @@ -2791,6 +2812,16 @@ output-file-sync@^1.1.0: mkdirp "^0.5.1" object-assign "^4.1.0" +p-limit@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-1.1.0.tgz#b07ff2d9a5d88bec806035895a2bab66a27988bc" + +p-locate@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" + dependencies: + p-limit "^1.1.0" + parse-glob@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/parse-glob/-/parse-glob-3.0.4.tgz#b2c376cfb11f35513badd173ef0bb6e3a388391c" @@ -2816,6 +2847,10 @@ path-exists@^2.0.0: dependencies: pinkie-promise "^2.0.0" +path-exists@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" + path-is-absolute@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" @@ -3454,6 +3489,16 @@ test-exclude@^3.3.0: read-pkg-up "^1.0.1" require-main-filename "^1.0.1" +test-exclude@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/test-exclude/-/test-exclude-4.0.0.tgz#0ddc0100b8ae7e88b34eb4fd98a907e961991900" + dependencies: + arrify "^1.0.1" + micromatch "^2.3.11" + object-assign "^4.1.0" + read-pkg-up "^1.0.1" + require-main-filename "^1.0.1" + text-table@~0.2.0: version "0.2.0" resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" From 07e18669afbd6ec97384210d320ea812fcb35aaa Mon Sep 17 00:00:00 2001 From: Brian Ng Date: Fri, 10 Mar 2017 10:33:07 -0600 Subject: [PATCH 24/24] Tweak package scripts and travis config for code coverage --- experimental/babel-preset-env/.travis.yml | 11 +++++--- experimental/babel-preset-env/CONTRIBUTING.md | 26 ++++++++++++++----- experimental/babel-preset-env/package.json | 20 ++++++++------ 3 files changed, 40 insertions(+), 17 deletions(-) diff --git a/experimental/babel-preset-env/.travis.yml b/experimental/babel-preset-env/.travis.yml index e29bd24054..3a9555b132 100644 --- a/experimental/babel-preset-env/.travis.yml +++ b/experimental/babel-preset-env/.travis.yml @@ -13,8 +13,11 @@ node_js: - '0.12' - '0.10' env: - - PKG_CMD="npm" - - PKG_CMD="yarn" + global: + - BABEL_ENV=test + matrix: + - PKG_CMD="npm" + - PKG_CMD="yarn" before_install: - nvm use $TRAVIS_NODE_VERSION - npm set loglevel error @@ -24,7 +27,7 @@ install: - $PKG_CMD install script: - 'if [ -n "${LINT-}" ]; then $PKG_CMD run lint ; fi' - - 'if [ -z "${LINT-}" ]; then $PKG_CMD run ci ; fi' + - 'if [ -z "${LINT-}" ]; then $PKG_CMD run test-ci ; fi' matrix: fast_finish: true exclude: @@ -35,3 +38,5 @@ matrix: include: - node_js: "node" env: LINT=true PKG_CMD="npm" + +after_success: 'if [ -z "${LINT-}" ]; then npm run coverage-ci ; fi' diff --git a/experimental/babel-preset-env/CONTRIBUTING.md b/experimental/babel-preset-env/CONTRIBUTING.md index 47de5fa6b3..275636d026 100644 --- a/experimental/babel-preset-env/CONTRIBUTING.md +++ b/experimental/babel-preset-env/CONTRIBUTING.md @@ -1,8 +1,8 @@ -## Contributing +# Contributing -### Adding a new plugin to support (when approved in the next ECMAScript version) +## Adding a new plugin to support (when approved in the next ECMAScript version) -#### Update [`plugin-features.js`](https://github.com/babel/babel-preset-env/blob/master/data/plugin-features.js) +### Update [`plugin-features.js`](https://github.com/babel/babel-preset-env/blob/master/data/plugin-features.js) *Example:* @@ -27,7 +27,7 @@ And add them in this structure: }, ``` -#### Update [`built-in-features.js`](https://github.com/babel/babel-preset-env/blob/master/data/built-in-features.js) +### Update [`built-in-features.js`](https://github.com/babel/babel-preset-env/blob/master/data/built-in-features.js) *Example:* @@ -51,7 +51,7 @@ const es2017 = { } ``` -#### Update [`plugins.json`](https://github.com/babel/babel-preset-env/blob/master/data/plugins.json) +### Update [`plugins.json`](https://github.com/babel/babel-preset-env/blob/master/data/plugins.json) Until `compat-table` is a standalone npm module for data we are using the git url @@ -59,7 +59,21 @@ Until `compat-table` is a standalone npm module for data we are using the git ur So we update and then run `npm run build-data`. If there are no changes, then `plugins.json` will be the same. -### Writing Tests +## Tests + +### Running tests locally + +```bash +npm test +``` + +### Checking code coverage locally + +```bash +npm run coverage +``` + +### Writing tests #### General diff --git a/experimental/babel-preset-env/package.json b/experimental/babel-preset-env/package.json index f2d61daea7..2d2a50d296 100644 --- a/experimental/babel-preset-env/package.json +++ b/experimental/babel-preset-env/package.json @@ -10,13 +10,15 @@ "scripts": { "build": "rimraf lib && babel src -d lib", "build-data": "node ./scripts/build-data.js", - "dev": "babel -w src -d lib", - "lint": "eslint .", - "fix": "eslint . --fix", - "cov": "BABEL_ENV=test nyc npm run test", - "ci": "npm run cov && nyc report --reporter=json && codecov -f coverage/coverage-final.json", "changelog": "git log `git describe --tags --abbrev=0`..HEAD --pretty=format:' * %s (%an)' | grep -v 'Merge pull request'", - "test": "npm run build && mocha ./test --compilers js:babel-register -t 10000" + "coverage": "BABEL_ENV=test nyc npm run test", + "coverage-ci": "nyc report --reporter=json && codecov -f coverage/coverage-final.json", + "dev": "babel -w src -d lib", + "fix": "eslint . --fix", + "lint": "eslint .", + "test": "npm run build && npm run test-only", + "test-ci": "nyc npm run test", + "test-only": "mocha ./test --compilers js:babel-register -t 10000" }, "dependencies": { "babel-plugin-check-es2015-constants": "^6.3.13", @@ -55,7 +57,7 @@ "babel-eslint": "^7.1.1", "babel-helper-fixtures": "^6.22.0", "babel-helper-plugin-test-runner": "^6.18.0", - "babel-plugin-istanbul": "^4.0.0", + "babel-plugin-istanbul": "^3.1.2", "babel-plugin-transform-flow-strip-types": "^6.8.0", "babel-preset-es2015": "^6.14.0", "babel-register": "^6.14.0", @@ -91,6 +93,8 @@ }, "nyc": { "all": true, - "include": ["src/*.js"] + "include": ["src/*.js"], + "instrument": false, + "sourceMap": false } }