bugsnag/bugsnag-js

View on GitHub
scripts/publish.js

Summary

Maintainability
A
0 mins
Test Coverage
const common = require('./common')

function publish (publishUrl) {
  const version = common.determineVersion()
  const distTag = common.getCommitId()

  // Check for existing published packages
  let myVersions = []
  try {
    const allVersions = JSON.parse(common.run(`npm view @bugsnag/js versions --registry ${publishUrl} --json`).toString())
    myVersions = allVersions.filter(function (str) { return str.indexOf(version) !== -1 })
  } catch (err) {
    // Ignore any errors and assume we can just publish.  For example, the command will fail
    // with a 404 when there are no @bugsnag/js at all, but that's fine here.
  }

  if (myVersions.length === 0) {
    // Build and publish packages
    console.log(`Publishing as '${version}'`)

    common.run('npm install', true)
    common.run('npm run bootstrap', true)
    common.run('npm run build', true)
    common.run('git checkout .')
    common.run(`./node_modules/.bin/lerna publish ${version} --dist-tag ${distTag} --exact --yes --force-publish --no-push --no-git-tag-version --registry ${publishUrl}`, true)
    console.log(`Publishing of version '${version}' complete`)
  } else {
    console.log(`Version '${version}' already found in registry - skipping publishing`)
  }
}

if (process.argv.length !== 3) {
  console.error('Usage: publish.js <registry url>')
  process.exit(1)
}
publish(process.argv[2])