diff --git a/.eslintrc b/.eslintrc
new file mode 100644
index 000000000..42a52a6bc
--- /dev/null
+++ b/.eslintrc
@@ -0,0 +1,6 @@
+{
+ "extends": "standard",
+ "rules": {
+ "no-var": "error"
+ }
+}
\ No newline at end of file
diff --git a/command.js b/command.js
index 3406cd00c..23e3ab2d5 100755
--- a/command.js
+++ b/command.js
@@ -1,4 +1,4 @@
-var defaults = require('./defaults')
+let defaults = require('./defaults')
module.exports = require('yargs')
.usage('Usage: $0 [options]')
diff --git a/index.js b/index.js
index 8408defdc..956e1e808 100755
--- a/index.js
+++ b/index.js
@@ -11,9 +11,9 @@ module.exports = function standardVersion (argv) {
let pkg
bump.pkgFiles.forEach((filename) => {
if (pkg) return
- var pkgPath = path.resolve(process.cwd(), filename)
+ let pkgPath = path.resolve(process.cwd(), filename)
try {
- var data = fs.readFileSync(pkgPath, 'utf8')
+ let data = fs.readFileSync(pkgPath, 'utf8')
pkg = JSON.parse(data)
} catch (err) {}
})
diff --git a/lib/lifecycles/bump.js b/lib/lifecycles/bump.js
index 11028c83d..a62d770b5 100644
--- a/lib/lifecycles/bump.js
+++ b/lib/lifecycles/bump.js
@@ -14,7 +14,7 @@ const semver = require('semver')
const stringifyPackage = require('stringify-package')
const writeFile = require('../write-file')
-var configsToUpdate = {}
+let configsToUpdate = {}
function Bump (args, version) {
// reset the cache of updated config files each
@@ -22,7 +22,7 @@ function Bump (args, version) {
configsToUpdate = {}
if (args.skip.bump) return Promise.resolve()
- var newVersion = version
+ let newVersion = version
return runLifecycleScript(args, 'prerelease')
.then(runLifecycleScript.bind(this, args, 'prebump'))
.then((stdout) => {
@@ -31,7 +31,7 @@ function Bump (args, version) {
})
.then((release) => {
if (!args.firstRelease) {
- var releaseType = getReleaseType(args.prerelease, release.releaseType, version)
+ let releaseType = getReleaseType(args.prerelease, release.releaseType, version)
newVersion = semver.valid(releaseType) || semver.inc(version, releaseType, args.prerelease)
updateConfigs(args, newVersion)
} else {
@@ -100,7 +100,7 @@ function isInPrerelease (version) {
return Array.isArray(semver.prerelease(version))
}
-var TypeList = ['major', 'minor', 'patch'].reverse()
+let TypeList = ['major', 'minor', 'patch'].reverse()
/**
* extract the in-pre-release type in target version
@@ -109,8 +109,8 @@ var TypeList = ['major', 'minor', 'patch'].reverse()
* @return {string}
*/
function getCurrentActiveType (version) {
- var typelist = TypeList
- for (var i = 0; i < typelist.length; i++) {
+ let typelist = TypeList
+ for (let i = 0; i < typelist.length; i++) {
if (semver[typelist[i]](version)) {
return typelist[i]
}
@@ -163,13 +163,13 @@ function updateConfigs (args, newVersion) {
Object.keys(configsToUpdate).forEach(function (configPath) {
try {
if (dotgit.ignore(configPath)) return
- var stat = fs.lstatSync(configPath)
+ let stat = fs.lstatSync(configPath)
if (stat.isFile()) {
- var data = fs.readFileSync(configPath, 'utf8')
- var indent = detectIndent(data).indent
- var newline = detectNewline(data)
- var config = JSON.parse(data)
- var filename = path.basename(configPath)
+ let data = fs.readFileSync(configPath, 'utf8')
+ let indent = detectIndent(data).indent
+ let newline = detectNewline(data)
+ let config = JSON.parse(data)
+ let filename = path.basename(configPath)
checkpoint(args, 'bumping version in ' + filename + ' from %s to %s', [config.version, newVersion])
config.version = newVersion
writeFile(args, configPath, stringifyPackage(config, indent, newline))
diff --git a/lib/lifecycles/changelog.js b/lib/lifecycles/changelog.js
index fb2e0f9f3..ea39f4201 100644
--- a/lib/lifecycles/changelog.js
+++ b/lib/lifecycles/changelog.js
@@ -20,16 +20,16 @@ module.exports = function (args, newVersion) {
function outputChangelog (args, newVersion) {
return new Promise((resolve, reject) => {
createIfMissing(args)
- var header = '# Change Log\n\nAll notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.\n'
- var oldContent = args.dryRun ? '' : fs.readFileSync(args.infile, 'utf-8')
+ let header = '# Change Log\n\nAll notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.\n'
+ let oldContent = args.dryRun ? '' : fs.readFileSync(args.infile, 'utf-8')
// find the position of the last release and remove header:
if (oldContent.indexOf(' {
- var message = 'git push --follow-tags origin master'
+ let message = 'git push --follow-tags origin master'
if (pkgPrivate !== true) {
message += ' && npm publish'
if (args.prerelease !== undefined) {
diff --git a/lib/run-lifecycle-hook.js b/lib/run-lifecycle-hook.js
index 17efd336a..9c0dc2cbf 100644
--- a/lib/run-lifecycle-hook.js
+++ b/lib/run-lifecycle-hook.js
@@ -5,7 +5,7 @@ const runExec = require('./run-exec')
module.exports = function (args, hookName, newVersion, hooks, cb) {
if (!hooks[hookName]) return Promise.resolve()
- var command = hooks[hookName] + ' --new-version="' + newVersion + '"'
+ let command = hooks[hookName] + ' --new-version="' + newVersion + '"'
checkpoint(args, 'Running lifecycle hook "%s"', [hookName])
checkpoint(args, '- hook command: "%s"', [command], chalk.blue(figures.info))
return runExec(args, command)
diff --git a/lib/run-lifecycle-script.js b/lib/run-lifecycle-script.js
index a5014482b..7a9b2a2ba 100644
--- a/lib/run-lifecycle-script.js
+++ b/lib/run-lifecycle-script.js
@@ -6,7 +6,7 @@ const runExec = require('./run-exec')
module.exports = function (args, hookName) {
const scripts = args.scripts
if (!scripts || !scripts[hookName]) return Promise.resolve()
- var command = scripts[hookName]
+ let command = scripts[hookName]
checkpoint(args, 'Running lifecycle script "%s"', [hookName])
checkpoint(args, '- execute command: "%s"', [command], chalk.blue(figures.info))
return runExec(args, command)
diff --git a/package.json b/package.json
index 7f7e843c9..a82980578 100644
--- a/package.json
+++ b/package.json
@@ -4,7 +4,7 @@
"description": "replacement for `npm version` with automatic CHANGELOG generation",
"bin": "bin/cli.js",
"scripts": {
- "pretest": "standard",
+ "pretest": "eslint .",
"coverage": "nyc report --reporter=text-lcov | coveralls",
"test": "nyc mocha --timeout=20000 test.js",
"release": "bin/cli.js"
@@ -54,11 +54,16 @@
"devDependencies": {
"chai": "^3.5.0",
"coveralls": "^3.0.1",
+ "eslint": "^5.16.0",
+ "eslint-config-standard": "^12.0.0",
+ "eslint-plugin-import": "^2.16.0",
+ "eslint-plugin-node": "^8.0.1",
+ "eslint-plugin-promise": "^4.0.1",
+ "eslint-plugin-standard": "^4.0.0",
"mocha": "^5.2.0",
"mock-git": "^1.0.3",
"mockery": "^2.0.0",
"nyc": "^13.3.0",
- "shelljs": "^0.7.8",
- "standard": "^12.0.1"
+ "shelljs": "^0.7.8"
}
}
diff --git a/test.js b/test.js
index 88126d430..0c5bfaf4e 100644
--- a/test.js
+++ b/test.js
@@ -15,7 +15,7 @@ const standardVersion = require('./index')
require('chai').should()
-var cliPath = path.resolve(__dirname, './bin/cli.js')
+let cliPath = path.resolve(__dirname, './bin/cli.js')
function branch (branch) {
shell.exec('git branch ' + branch)
@@ -43,31 +43,31 @@ function execCliAsync (argString) {
function writePackageJson (version, option) {
option = option || {}
- var pkg = Object.assign(option, { version: version })
+ let pkg = Object.assign(option, { version: version })
fs.writeFileSync('package.json', JSON.stringify(pkg), 'utf-8')
}
function writeBowerJson (version, option) {
option = option || {}
- var bower = Object.assign(option, { version: version })
+ let bower = Object.assign(option, { version: version })
fs.writeFileSync('bower.json', JSON.stringify(bower), 'utf-8')
}
function writeManifestJson (version, option) {
option = option || {}
- var manifest = Object.assign(option, { version: version })
+ let manifest = Object.assign(option, { version: version })
fs.writeFileSync('manifest.json', JSON.stringify(manifest), 'utf-8')
}
function writeNpmShrinkwrapJson (version, option) {
option = option || {}
- var shrinkwrap = Object.assign(option, { version: version })
+ let shrinkwrap = Object.assign(option, { version: version })
fs.writeFileSync('npm-shrinkwrap.json', JSON.stringify(shrinkwrap), 'utf-8')
}
function writePackageLockJson (version, option) {
option = option || {}
- var pkgLock = Object.assign(option, { version: version })
+ let pkgLock = Object.assign(option, { version: version })
fs.writeFileSync('package-lock.json', JSON.stringify(pkgLock), 'utf-8')
}
@@ -82,7 +82,7 @@ function writePostBumpHook (causeError) {
function writeHook (hookName, causeError, script) {
shell.mkdir('-p', 'scripts')
- var content = script || 'console.error("' + hookName + ' ran")'
+ let content = script || 'console.error("' + hookName + ' ran")'
content += causeError ? '\nthrow new Error("' + hookName + '-failure")' : ''
fs.writeFileSync('scripts/' + hookName + '.js', content, 'utf-8')
fs.chmodSync('scripts/' + hookName + '.js', '755')
@@ -131,7 +131,7 @@ describe('cli', function () {
execCli().code.should.equal(0)
- var content = fs.readFileSync('CHANGELOG.md', 'utf-8')
+ let content = fs.readFileSync('CHANGELOG.md', 'utf-8')
content.should.match(/patch release/)
content.should.not.match(/first commit/)
})
@@ -143,7 +143,7 @@ describe('cli', function () {
commit('fix: patch release')
execCli('--first-release').code.should.equal(0)
- var content = fs.readFileSync('CHANGELOG.md', 'utf-8')
+ let content = fs.readFileSync('CHANGELOG.md', 'utf-8')
content.should.match(/patch release/)
content.should.match(/first commit/)
shell.exec('git tag').stdout.should.match(/1\.0\.1/)
@@ -159,7 +159,7 @@ describe('cli', function () {
commit('fix: patch release')
execCli().code.should.equal(0)
- var content = fs.readFileSync('CHANGELOG.md', 'utf-8')
+ let content = fs.readFileSync('CHANGELOG.md', 'utf-8')
content.should.match(/1\.0\.1/)
content.should.not.match(/legacy header format/)
})
@@ -177,8 +177,8 @@ describe('cli', function () {
execCli('--commit-all').code.should.equal(0)
- var content = fs.readFileSync('CHANGELOG.md', 'utf-8')
- var status = shell.exec('git status --porcelain') // see http://unix.stackexchange.com/questions/155046/determine-if-git-working-directory-is-clean-from-a-script
+ let content = fs.readFileSync('CHANGELOG.md', 'utf-8')
+ let status = shell.exec('git status --porcelain') // see http://unix.stackexchange.com/questions/155046/determine-if-git-working-directory-is-clean-from-a-script
status.should.equal('')
status.should.not.match(/STUFF.md/)
@@ -195,7 +195,7 @@ describe('cli', function () {
.then(function (unmock) {
execCli('--sign').code.should.equal(0)
- var captured = shell.cat('gitcapture.log').stdout.split('\n').map(function (line) {
+ let captured = shell.cat('gitcapture.log').stdout.split('\n').map(function (line) {
return line ? JSON.parse(line) : line
})
captured[captured.length - 3].should.deep.equal(['commit', '-S', 'CHANGELOG.md', 'package.json', '-m', 'chore(release): 1.0.1'])
@@ -209,7 +209,7 @@ describe('cli', function () {
// mock git by throwing on attempt to commit
return mockGit('console.error("commit yourself"); process.exit(128);', 'commit')
.then(function (unmock) {
- var result = execCli()
+ let result = execCli()
result.code.should.equal(1)
result.stderr.should.match(/commit yourself/)
@@ -221,7 +221,7 @@ describe('cli', function () {
// mock git by throwing on attempt to add
return mockGit('console.error("addition is hard"); process.exit(128);', 'add')
.then(function (unmock) {
- var result = execCli()
+ let result = execCli()
result.code.should.equal(1)
result.stderr.should.match(/addition is hard/)
@@ -233,7 +233,7 @@ describe('cli', function () {
// mock git by throwing on attempt to commit
return mockGit('console.error("tag, you\'re it"); process.exit(128);', 'tag')
.then(function (unmock) {
- var result = execCli()
+ let result = execCli()
result.code.should.equal(1)
result.stderr.should.match(/tag, you're it/)
@@ -247,7 +247,7 @@ describe('cli', function () {
.then(function (unmock) {
writePackageJson('1.0.0')
- var result = execCli()
+ let result = execCli()
result.code.should.equal(0)
result.stderr.should.match(/haha, kidding, this is just a warning/)
@@ -270,7 +270,7 @@ describe('cli', function () {
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
commit('feat: first commit')
- var result = execCli('--patch')
+ let result = execCli('--patch')
result.code.should.equal(0)
result.stderr.should.match(/prerelease ran/)
})
@@ -287,7 +287,7 @@ describe('cli', function () {
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
commit('feat: first commit')
- var result = execCli('--patch')
+ let result = execCli('--patch')
result.code.should.equal(1)
result.stderr.should.match(/prerelease ran/)
})
@@ -306,7 +306,7 @@ describe('cli', function () {
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
commit('feat: first commit')
- var result = execCli('--patch')
+ let result = execCli('--patch')
result.stdout.should.match(/9\.9\.9/)
result.code.should.equal(0)
})
@@ -325,7 +325,7 @@ describe('cli', function () {
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
commit('feat: first commit')
- var result = execCli('--patch')
+ let result = execCli('--patch')
result.code.should.equal(0)
result.stderr.should.match(/postbump ran/)
})
@@ -342,7 +342,7 @@ describe('cli', function () {
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
commit('feat: first commit')
- var result = execCli('--patch')
+ let result = execCli('--patch')
result.code.should.equal(1)
result.stderr.should.match(/postbump-failure/)
})
@@ -361,7 +361,7 @@ describe('cli', function () {
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
commit('feat: first commit')
- var result = execCli('--patch')
+ let result = execCli('--patch')
result.code.should.equal(0)
result.stderr.should.match(/precommit ran/)
})
@@ -378,7 +378,7 @@ describe('cli', function () {
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
commit('feat: first commit')
- var result = execCli('--patch')
+ let result = execCli('--patch')
result.code.should.equal(1)
result.stderr.should.match(/precommit-failure/)
})
@@ -395,7 +395,7 @@ describe('cli', function () {
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
commit('feat: first commit')
- var result = execCli('--patch')
+ let result = execCli('--patch')
result.code.should.equal(0)
shell.exec('git log --oneline -n1').should.match(/delivers #222/)
})
@@ -450,11 +450,11 @@ describe('cli', function () {
})
describe('release-types', function () {
- var regularTypes = ['major', 'minor', 'patch']
+ let regularTypes = ['major', 'minor', 'patch']
regularTypes.forEach(function (type) {
it('creates a ' + type + ' release', function () {
- var originVer = '1.0.0'
+ let originVer = '1.0.0'
writePackageJson(originVer)
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
@@ -462,7 +462,7 @@ describe('cli', function () {
return execCliAsync('--release-as ' + type)
.then(function () {
- var version = {
+ let version = {
major: semver.major(originVer),
minor: semver.minor(originVer),
patch: semver.patch(originVer)
@@ -478,7 +478,7 @@ describe('cli', function () {
// this is for pre-releases
regularTypes.forEach(function (type) {
it('creates a pre' + type + ' release', function () {
- var originVer = '1.0.0'
+ let originVer = '1.0.0'
writePackageJson(originVer)
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
@@ -486,7 +486,7 @@ describe('cli', function () {
return execCliAsync('--release-as ' + type + ' --prerelease ' + type)
.then(function () {
- var version = {
+ let version = {
major: semver.major(originVer),
minor: semver.minor(originVer),
patch: semver.patch(originVer)
@@ -502,7 +502,7 @@ describe('cli', function () {
describe('release-as-exact', function () {
it('releases as v100.0.0', function () {
- var originVer = '1.0.0'
+ let originVer = '1.0.0'
writePackageJson(originVer)
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
@@ -515,7 +515,7 @@ describe('cli', function () {
})
it('releases as 200.0.0-amazing', function () {
- var originVer = '1.0.0'
+ let originVer = '1.0.0'
writePackageJson(originVer)
fs.writeFileSync('CHANGELOG.md', 'legacy header format\n', 'utf-8')
@@ -581,7 +581,7 @@ describe('cli', function () {
execCli().code.should.equal(0)
- var content = fs.readFileSync('CHANGELOG.md', 'utf-8')
+ let content = fs.readFileSync('CHANGELOG.md', 'utf-8')
content.should.match(/this is my fairly long commit message which is testing whether or not we allow for long commit messages/)
})
@@ -601,45 +601,45 @@ describe('cli', function () {
it('appends line feed at end of package.json', function () {
execCli().code.should.equal(0)
- var pkgJson = fs.readFileSync('package.json', 'utf-8')
+ let pkgJson = fs.readFileSync('package.json', 'utf-8')
pkgJson.should.equal(['{', ' "version": "1.0.1"', '}', ''].join('\n'))
})
it('preserves indentation of tabs in package.json', function () {
- var indentation = '\t'
- var newPkgJson = ['{', indentation + '"version": "1.0.0"', '}', ''].join('\n')
+ let indentation = '\t'
+ let newPkgJson = ['{', indentation + '"version": "1.0.0"', '}', ''].join('\n')
fs.writeFileSync('package.json', newPkgJson, 'utf-8')
execCli().code.should.equal(0)
- var pkgJson = fs.readFileSync('package.json', 'utf-8')
+ let pkgJson = fs.readFileSync('package.json', 'utf-8')
pkgJson.should.equal(['{', indentation + '"version": "1.0.1"', '}', ''].join('\n'))
})
it('preserves indentation of spaces in package.json', function () {
- var indentation = ' '
- var newPkgJson = ['{', indentation + '"version": "1.0.0"', '}', ''].join('\n')
+ let indentation = ' '
+ let newPkgJson = ['{', indentation + '"version": "1.0.0"', '}', ''].join('\n')
fs.writeFileSync('package.json', newPkgJson, 'utf-8')
execCli().code.should.equal(0)
- var pkgJson = fs.readFileSync('package.json', 'utf-8')
+ let pkgJson = fs.readFileSync('package.json', 'utf-8')
pkgJson.should.equal(['{', indentation + '"version": "1.0.1"', '}', ''].join('\n'))
})
it('preserves line feed in package.json', function () {
- var newPkgJson = ['{', ' "version": "1.0.0"', '}', ''].join('\n')
+ let newPkgJson = ['{', ' "version": "1.0.0"', '}', ''].join('\n')
fs.writeFileSync('package.json', newPkgJson, 'utf-8')
execCli().code.should.equal(0)
- var pkgJson = fs.readFileSync('package.json', 'utf-8')
+ let pkgJson = fs.readFileSync('package.json', 'utf-8')
pkgJson.should.equal(['{', ' "version": "1.0.1"', '}', ''].join('\n'))
})
it('preserves carriage return + line feed in package.json', function () {
- var newPkgJson = ['{', ' "version": "1.0.0"', '}', ''].join('\r\n')
+ let newPkgJson = ['{', ' "version": "1.0.0"', '}', ''].join('\r\n')
fs.writeFileSync('package.json', newPkgJson, 'utf-8')
execCli().code.should.equal(0)
- var pkgJson = fs.readFileSync('package.json', 'utf-8')
+ let pkgJson = fs.readFileSync('package.json', 'utf-8')
pkgJson.should.equal(['{', ' "version": "1.0.1"', '}', ''].join('\r\n'))
})
@@ -653,7 +653,7 @@ describe('cli', function () {
})
it('does not print output when the --silent flag is passed', function () {
- var result = execCli('--silent')
+ let result = execCli('--silent')
result.code.should.equal(0)
result.stdout.should.equal('')
result.stderr.should.equal('')
@@ -662,13 +662,13 @@ describe('cli', function () {
it('does not display `npm publish` if the package is private', function () {
writePackageJson('1.0.0', { private: true })
- var result = execCli()
+ let result = execCli()
result.code.should.equal(0)
result.stdout.should.not.match(/npm publish/)
})
it('includes merge commits', function () {
- var branchName = 'new-feature'
+ let branchName = 'new-feature'
commit('feat: first commit')
shell.exec('git tag -a v1.0.0 -m "my awesome first release"')
branch(branchName)
@@ -679,10 +679,10 @@ describe('cli', function () {
execCli().code.should.equal(0)
- var content = fs.readFileSync('CHANGELOG.md', 'utf-8')
+ let content = fs.readFileSync('CHANGELOG.md', 'utf-8')
content.should.match(/new feature from branch/)
- var pkgJson = fs.readFileSync('package.json', 'utf-8')
+ let pkgJson = fs.readFileSync('package.json', 'utf-8')
pkgJson.should.equal(['{', ' "version": "1.1.0"', '}', ''].join('\n'))
})
@@ -694,7 +694,7 @@ describe('cli', function () {
})
commit('feat: first commit')
- var result = execCli()
+ let result = execCli()
result.code.should.equal(1)
result.stderr.should.match(/scripts must be an object/)
})
@@ -707,7 +707,7 @@ describe('cli', function () {
})
commit('feat: first commit')
- var result = execCli()
+ let result = execCli()
result.code.should.equal(1)
result.stderr.should.match(/skip must be an object/)
})
@@ -747,7 +747,7 @@ describe('standard-version', function () {
beforeEach(function () {
mockery.enable({ warnOnUnregistered: false, useCleanCache: true })
mockery.registerMock('conventional-changelog', function () {
- var readable = new stream.Readable({ objectMode: true })
+ let readable = new stream.Readable({ objectMode: true })
readable._read = function () {
}
setImmediate(readable.emit.bind(readable), 'error', new Error('changelog err'))
@@ -894,7 +894,7 @@ describe('standard-version', function () {
return execCliAsync('--skip.bump true --skip.changelog true')
.then(function () {
getPackageVersion().should.equal('1.0.0')
- var content = fs.readFileSync('CHANGELOG.md', 'utf-8')
+ let content = fs.readFileSync('CHANGELOG.md', 'utf-8')
content.should.equal(changelogContent)
})
})
@@ -908,7 +908,7 @@ describe('standard-version', function () {
return execCliAsync('--skip.commit true')
.then(function () {
getPackageVersion().should.equal('1.1.0')
- var content = fs.readFileSync('CHANGELOG.md', 'utf-8')
+ let content = fs.readFileSync('CHANGELOG.md', 'utf-8')
content.should.match(/new feature from branch/)
// check last commit message
shell.exec('git log --oneline -n1').stdout.should.match(/feat: new feature from branch/)