Skip to content
This repository has been archived by the owner on Jan 29, 2023. It is now read-only.

Commit

Permalink
feat: simplified package-scripts
Browse files Browse the repository at this point in the history
  • Loading branch information
jdx committed Jan 27, 2018
1 parent 9725407 commit f31fae9
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 102 deletions.
2 changes: 1 addition & 1 deletion templates/app/appveyor.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ install:
- git config --global user.name "dxcli"
- yarn
test_script:
- .\node_modules\.bin\nps ci.test
- yarn test
after_test:
- ps: |
$env:PATH = 'C:\msys64\usr\bin;' + $env:PATH
Expand Down
6 changes: 3 additions & 3 deletions templates/app/circle.yml.ejs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ jobs:
- v0-yarn-{{checksum ".circleci/config.yml"}}-master-
- run: .circleci/setup_git
- run: .circleci/yarn
- run: yarn exec nps ci.test
- run: yarn test
- run: curl -s https://codecov.io/bash | bash
- store_test_results: &store_test_results
path: ~/cli/reports
Expand All @@ -33,7 +33,7 @@ jobs:
- restore_cache: *restore_cache
- run: .circleci/setup_git
- run: .circleci/yarn
- run: yarn exec nps ci.test
- run: yarn test
- run: curl -s https://codecov.io/bash | bash
- store_test_results: *store_test_results
<%_ if (semantic_release) { _%>
Expand All @@ -45,7 +45,7 @@ jobs:
- restore_cache: *restore_cache
- run: .circleci/setup_git
- run: .circleci/yarn
- run: yarn exec nps ci.release
- run: yarn exec nps release
<%_ } _%>

workflows:
Expand Down
140 changes: 42 additions & 98 deletions templates/app/package-scripts.js.ejs
Original file line number Diff line number Diff line change
@@ -1,120 +1,64 @@
const {
setColors,
concurrent,
<%_ if (mocha) { _%>
crossEnv,
<%_ } _%>
ifNotWindows,
ifWindows,
mkdirp,
series,
setColors,
} = require('nps-utils')
<%_ if (semantic_release) { _%>
const pjson = require('./package.json')
const release = pjson.devDependencies.typedoc ? ['ci.release.semantic-release', 'ci.release.typedoc'] : ['ci.release.semantic-release']
<%_ } _%>
const script = (script, description) => description ? {script, description} : {script}
const hidden = script => ({script, hiddenFromHelp: true})
const unixOrWindows = (unix, windows) => series(ifNotWindows(unix), ifWindows(windows))

const lint = ['lint.eslint'<% if (semantic_release) { %>, 'lint.commitlint'<% } %><% if (ts) { %>, 'lint.tsc', 'lint.tslint'<% } %>]
} = require('nps-utils')

setColors(['dim'])

let ciTests = [
'ci.test.eslint',
<%_ if (mocha) { _%>
'ci.test.mocha',
<%_ } _%>
<%_ if (ts) { _%>
'ci.test.tslint',
<%_ } _%>
]
const script = (script, description) => description ? {script, description} : {script}

module.exports = {
scripts: {
lint: {
default: concurrent.nps(...lint),
eslint: script('eslint .', 'lint js files'),
const lint = {
eslint: script('eslint .', 'lint js files'),
<%_ if (semantic_release) { _%>
commitlint: script('commitlint --from origin/master', 'ensure that commits are in valid conventional-changelog format'),
commitlint: script('commitlint --from origin/master', 'ensure that commits are in valid conventional-changelog format'),
<%_ } _%>
<%_ if (ts) { _%>
<%_ if (mocha) { _%>
tsc: script('tsc -p test --noEmit', 'syntax check with tsc'),
tslint: script('tslint -p test', 'lint ts files'),
<%_ } else { _%>
tsc: script('tsc -p . --noEmit', 'syntax check with tsc'),
tslint: script('tslint -p .', 'lint ts files'),
<%_ } _%>
tsc: script('tsc -p test --noEmit', 'syntax check with tsc'),
tslint: script('tslint -p test', 'lint ts files'),
<%_ } _%>
},
test: {
}

const linters = Object.keys(lint).map(l => `lint.${l}`)
lint.default = concurrent.nps(...linters)

const test = {
<%_ if (mocha) { _%>
default: script(concurrent.nps(...lint), 'lint and run all tests'),
series: script(series.nps(...lint), 'lint and run all tests in series'),
mocha: {
default: script('mocha --forbid-only "test/**/*.test.<%= _ext %>"', 'run all mocha tests'),
coverage: {
default: hidden(series.nps('test.mocha.nyc nps test.mocha', 'test.mocha.coverage.report')),
report: hidden(series('nps "test.mocha.nyc report --reporter text-lcov" > coverage.lcov')),
},
junit: hidden(series(
crossEnv('MOCHA_FILE="reports/mocha.xml" ') + series.nps('test.mocha.nyc nps \\"test.mocha --reporter mocha-junit-reporter\\"'),
series.nps('test.mocha.coverage.report'),
)),
nyc: hidden('nyc --nycrc-path node_modules/@dxcli/dev-nyc-config/.nycrc'),
},
default: script(concurrent.nps(...linters, 'test.mocha'), 'lint and run all tests'),
mocha: script('mocha --forbid-only "test/**/*.test.ts"', 'run all mocha tests'),
<%_ } else { _%>
default: script(concurrent.nps('lint')),
default: lint.default
<%_ } _%>
},
ci: {
test: {
default: hidden(series(
mkdirp('reports'),
unixOrWindows(
concurrent.nps(...ciTests),
series.nps(...ciTests),
),
)),
}

const scripts = {
lint,
test,
}

<%_ if (mocha) { _%>
mocha: hidden(
unixOrWindows(
series.nps('test.mocha.junit'),
series.nps('test.mocha.coverage'),
)
),
<%_ } _%>
eslint: hidden(
unixOrWindows(
series.nps('lint.eslint --format junit --output-file reports/eslint.xml'),
series.nps('lint.eslint'),
)
),
if (process.env.CI) {
if (process.env.CIRCLECI) {
test.default.script = series(mkdirp('reports'), test.default.script)
// add mocha junit reporter
test.mocha.script = crossEnv(`MOCHA_FILE=reports/mocha.xml ${test.mocha.script} --reporter mocha-junit-reporter`)
// add eslint reporter
lint.eslint.script = `${lint.eslint.script} --format junit --output-file reports/eslint.xml`
<%_ if (ts) { _%>
tslint: hidden(
unixOrWindows(
series.nps('lint.tslint --format junit > reports/tslint.xml'),
series.nps('lint.tslint'),
)
),
<%_ } _%>
},
<%_ if (semantic_release) { _%>
typedoc: hidden('typedoc --out /tmp/docs src/index.ts --excludeNotExported --mode file'),
release: {
default: hidden(series.nps(...release)),
'semantic-release': hidden('semantic-release -e @dxcli/dev-semantic-release'),
typedoc: hidden(series(
'git clone -b gh-pages $CIRCLE_REPOSITORY_URL gh-pages',
'nps ci.typedoc',
'rm -rf ./gh-pages/*',
'mv /tmp/docs/* ./gh-pages',
'cd gh-pages && git add . && git commit -m "updates from $CIRCLE_SHA1 [skip ci]" && git push',
)),
},
// add tslint reporter
lint.tslint.script = `${lint.tslint.script} --format junit > reports/tslint.xml`
<%_ } _%>
},
},
scripts.release = 'semantic-release -e @dxcli/dev-semantic-release'
}
// add code coverage reporting with nyc
const nyc = 'nyc --nycrc-path node_modules/@dxcli/dev-nyc-config/.nycrc'
const nycReport = `${nyc} report --reporter text-lcov > coverage.lcov`
test.mocha.script = series(`${nyc} ${test.mocha.script}`, nycReport)
}
<%_ } _%>

module.exports = {scripts}

0 comments on commit f31fae9

Please sign in to comment.