Skip to content

Commit

Permalink
Merge pull request #62 from xg-wang/feat/fetch-pretender
Browse files Browse the repository at this point in the history
Update dependencies
  • Loading branch information
rwjblue committed Jul 18, 2018
2 parents 8451d76 + 2474281 commit 52c7618
Show file tree
Hide file tree
Showing 26 changed files with 6,382 additions and 214 deletions.
16 changes: 16 additions & 0 deletions .eslintignore
@@ -0,0 +1,16 @@
# unconventional js
/blueprints/*/files/
/vendor/

# compiled output
/dist/
/tmp/

# dependencies
/bower_components/

# misc
/coverage/

# ember-try
/.node_modules.ember-try/
50 changes: 50 additions & 0 deletions .eslintrc.js
@@ -0,0 +1,50 @@
module.exports = {
root: true,
parserOptions: {
ecmaVersion: 2017,
sourceType: 'module'
},
plugins: [
'ember'
],
extends: [
'eslint:recommended',
'plugin:ember/recommended'
],
env: {
browser: true
},
rules: {
},
overrides: [
// node files
{
files: [
'ember-cli-build.js',
'index.js',
'testem.js',
'blueprints/*/index.js',
'config/**/*.js',
'tests/dummy/config/**/*.js'
],
excludedFiles: [
'addon/**',
'addon-test-support/**',
'app/**',
'tests/dummy/app/**'
],
parserOptions: {
sourceType: 'script',
ecmaVersion: 2015
},
env: {
browser: false,
node: true
},
plugins: ['node'],
rules: Object.assign({}, require('eslint-plugin-node').configs.recommended.rules, {
// add your custom rules and overrides for node files here
})
}
]
};
22 changes: 14 additions & 8 deletions .gitignore
@@ -1,17 +1,23 @@
# See http://help.github.com/ignore-files/ for more about ignoring files.
# See https://help.github.com/ignore-files/ for more about ignoring files.

# compiled output
/dist
/tmp
/dist/
/tmp/

# dependencies
/node_modules
/bower_components
/bower_components/
/node_modules/

# misc
/.sass-cache
/connect.lock
/coverage/*
/coverage/
/libpeerconnection.log
npm-debug.log
testem.log
/npm-debug.log*
/testem.log
/yarn-error.log

# ember-try
/.node_modules.ember-try/
/bower.json.ember-try
/package.json.ember-try
8 changes: 7 additions & 1 deletion .npmignore
Expand Up @@ -7,10 +7,16 @@
.bowerrc
.editorconfig
.ember-cli
.eslintrc.js
.gitignore
.jshintrc
.watchmanconfig
.travis.yml
bower.json
ember-cli-build.js
testem.js
yarn.lock

# ember-try
.node_modules.ember-try/
bower.json.ember-try
package.json.ember-try
42 changes: 26 additions & 16 deletions .travis.yml
@@ -1,38 +1,48 @@
---
language: node_js
node_js:
- "4"
# we recommend testing addons with the same minimum supported node version as Ember CLI
# so that your addon works for all apps
- "6"

sudo: false
dist: trusty

addons:
chrome: stable

cache:
directories:
- node_modules
yarn: true

env:
- EMBER_TRY_SCENARIO=default
- EMBER_TRY_SCENARIO=ember-1.13
- EMBER_TRY_SCENARIO=ember-release
- EMBER_TRY_SCENARIO=ember-beta
- EMBER_TRY_SCENARIO=ember-canary
global:
# See https://git.io/vdao3 for details.
- JOBS=1
matrix:
# we recommend new addons test the current and previous LTS
# as well as latest stable release (bonus points to beta/canary)
- EMBER_TRY_SCENARIO=ember-lts-2.12
- EMBER_TRY_SCENARIO=ember-lts-2.16
- EMBER_TRY_SCENARIO=ember-lts-2.18
- EMBER_TRY_SCENARIO=ember-release
- EMBER_TRY_SCENARIO=ember-beta
- EMBER_TRY_SCENARIO=ember-canary
- EMBER_TRY_SCENARIO=ember-default

matrix:
fast_finish: true
allow_failures:
- env: EMBER_TRY_SCENARIO=ember-canary

before_install:
- npm config set spin false
- npm install -g bower
- bower --version
- npm install phantomjs-prebuilt
- phantomjs --version
- curl -o- -L https://yarnpkg.com/install.sh | bash
- export PATH=$HOME/.yarn/bin:$PATH

install:
- npm install
- bower install
- yarn install --no-lockfile --non-interactive

script:
- yarn lint:js
# Usually, it's ok to finish the test scenario without reverting
# to the addon's original dependency state, skipping "cleanup".
- ember try:one $EMBER_TRY_SCENARIO test --skip-cleanup
- node_modules/.bin/ember try:one $EMBER_TRY_SCENARIO --skip-cleanup
8 changes: 0 additions & 8 deletions bower.json

This file was deleted.

114 changes: 65 additions & 49 deletions config/ember-try.js
@@ -1,55 +1,71 @@
/*jshint node:true*/
module.exports = {
scenarios: [
{
name: 'default',
bower: {
dependencies: { }
}
},
{
name: 'ember-1.13',
bower: {
dependencies: {
'ember': '~1.13.0'
'use strict';

const getChannelURL = require('ember-source-channel-url');

module.exports = function() {
return Promise.all([
getChannelURL('release'),
getChannelURL('beta'),
getChannelURL('canary')
]).then((urls) => {
return {
useYarn: true,
scenarios: [
{
name: 'ember-lts-2.12',
npm: {
devDependencies: {
'ember-source': '~2.12.0'
}
}
},
resolutions: {
'ember': '~1.13.0'
}
}
},
{
name: 'ember-release',
bower: {
dependencies: {
'ember': 'components/ember#release'
{
name: 'ember-lts-2.16',
npm: {
devDependencies: {
'ember-source': '~2.16.0'
}
}
},
resolutions: {
'ember': 'release'
}
}
},
{
name: 'ember-beta',
bower: {
dependencies: {
'ember': 'components/ember#beta'
{
name: 'ember-lts-2.18',
npm: {
devDependencies: {
'ember-source': '~2.18.0'
}
}
},
resolutions: {
'ember': 'beta'
}
}
},
{
name: 'ember-canary',
bower: {
dependencies: {
'ember': 'components/ember#canary'
{
name: 'ember-release',
npm: {
devDependencies: {
'ember-source': urls[0]
}
}
},
{
name: 'ember-beta',
npm: {
devDependencies: {
'ember-source': urls[1]
}
}
},
{
name: 'ember-canary',
npm: {
devDependencies: {
'ember-source': urls[2]
}
}
},
resolutions: {
'ember': 'canary'
{
name: 'ember-default',
npm: {
devDependencies: {}
}
}
}
}
]
]
};
});
};
1 change: 0 additions & 1 deletion config/environment.js
@@ -1,4 +1,3 @@
/*jshint node:true*/
'use strict';

module.exports = function(/* environment, appConfig */) {
Expand Down
8 changes: 4 additions & 4 deletions ember-cli-build.js
@@ -1,9 +1,9 @@
/*jshint node:true*/
/* global require, module */
var EmberAddon = require('ember-cli/lib/broccoli/ember-addon');
'use strict';

const EmberAddon = require('ember-cli/lib/broccoli/ember-addon');

module.exports = function(defaults) {
var app = new EmberAddon(defaults, {
let app = new EmberAddon(defaults, {
// Add options here
});

Expand Down
25 changes: 20 additions & 5 deletions index.js
@@ -1,5 +1,7 @@
'use strict';
var path = require('path');
var Funnel = require('broccoli-funnel');
var MergeTrees = require('broccoli-merge-trees');

module.exports = {
name: 'ember-cli-pretender',
Expand All @@ -10,15 +12,14 @@ module.exports = {

this._pretenderPath = resolve.sync('pretender');
this._pretenderDir = path.dirname(this._pretenderPath);
this._routeRecognizerPath = resolve.sync('route-recognizer', { basedir: this._pretenderDir });
this._fakeRequestPath = resolve.sync('fake-xml-http-request', { basedir: this._pretenderDir });
this._routeRecognizerPath = resolve.sync('route-recognizer');
this._fakeRequestPath = resolve.sync('fake-xml-http-request');
this._abortControllerPath = resolve.sync('abortcontroller-polyfill/dist/abortcontroller-polyfill-only.js');
this._whatwgFetchPath = resolve.sync('@xg-wang/whatwg-fetch/dist/fetch.umd.js');
}
},

treeForVendor: function(tree) {
var Funnel = require('broccoli-funnel');
var MergeTrees = require('broccoli-merge-trees');

this._findPretenderPaths();

var pretenderTree = new Funnel(this._pretenderDir, {
Expand All @@ -37,11 +38,23 @@ module.exports = {
destDir: '/fake-xml-http-request',
});

var abortControllerTree = new Funnel(path.dirname(this._abortControllerPath), {
files: [path.basename(this._abortControllerPath)],
destDir: '/abortcontroller-polyfill',
});

var whatwgFetchTree = new Funnel(path.dirname(this._whatwgFetchPath), {
files: [path.basename(this._whatwgFetchPath)],
destDir: '/whatwg-fetch',
});

var trees = [
tree,
pretenderTree,
routeRecognizerTree,
fakeRequestTree,
abortControllerTree,
whatwgFetchTree
// tree is not always defined, so filter out if empty
].filter(Boolean);

Expand All @@ -62,6 +75,8 @@ module.exports = {

app.import('vendor/fake-xml-http-request/' + path.basename(this._fakeRequestPath));
app.import('vendor/route-recognizer/' + path.basename(this._routeRecognizerPath));
app.import('vendor/abortcontroller-polyfill/' + path.basename(this._abortControllerPath));
app.import('vendor/whatwg-fetch/' + path.basename(this._whatwgFetchPath));
app.import('vendor/pretender/' + path.basename(this._pretenderPath));
}
},
Expand Down

0 comments on commit 52c7618

Please sign in to comment.