Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@spryker-lerna/publish

lerna19MIT5.3.0

Publish packages in the current project

lerna, command

readme

@lerna/publish

Publish packages in the current project

Install lerna for access to the lerna CLI.

Usage

lerna publish              # publish packages that have changed since the last release
lerna publish from-git     # explicitly publish packages tagged in the current commit
lerna publish from-package # explicitly publish packages where the latest version is not present in the registry

When run, this command does one of the following things:

  • Publish packages updated since the last release (calling lerna version behind the scenes).
    • This is the legacy behavior of lerna 2.x
  • Publish packages tagged in the current commit (from-git).
  • Publish packages in the latest commit where the version is not present in the registry (from-package).
  • Publish an unversioned "canary" release of packages (and their dependents) updated in the previous commit.

Lerna will never publish packages which are marked as private ("private": true in the package.json).

During all publish operations, appropriate lifecycle scripts are called in the root and per-package (unless disabled by `--ignore-scripts).

Check out Per-Package Configuration for more details about publishing scoped packages, custom registries, and custom dist-tags.

Positionals

bump from-git

In addition to the semver keywords supported by lerna version, lerna publish also supports the from-git keyword. This will identify packages tagged by lerna version and publish them to npm. This is useful in CI scenarios where you wish to manually increment versions, but have the package contents themselves consistently published by an automated process.

bump from-package

Similar to the from-git keyword except the list of packages to publish is determined by inspecting each package.json and determining if any package version is not present in the registry. Any versions not present in the registry will be published. This is useful when a previous lerna publish failed to publish all packages to the registry.

Options

lerna publish supports all of the options provided by lerna version in addition to the following:

--canary

lerna publish --canary
# 1.0.0 => 1.0.1-alpha.0+${SHA} of packages changed since the previous commit
# a subsequent canary publish will yield 1.0.1-alpha.1+${SHA}, etc

lerna publish --canary --preid beta
# 1.0.0 => 1.0.1-beta.0+${SHA}

# The following are equivalent:
lerna publish --canary minor
lerna publish --canary preminor
# 1.0.0 => 1.1.0-alpha.0+${SHA}

When run with this flag, lerna publish publishes packages in a more granular way (per commit). Before publishing to npm, it creates the new version tag by taking the current version, bumping it to the next minor version, adding the provided meta suffix (defaults to alpha) and appending the current git sha (ex: 1.0.0 becomes 1.1.0-alpha.0+81e3b443).

If you have publish canary releases from multiple active development branches in CI, it is recommended to customize the --preid and --dist-tag <tag> on a per-branch basis to avoid clashing versions.

The intended use case for this flag is a per commit level release or nightly release.

--contents <dir>

Subdirectory to publish. Must apply to ALL packages, and MUST contain a package.json file. Package lifecycles will still be run in the original leaf directory. You should probably use one of those lifecycles (prepare, prepublishOnly, or prepack) to create the subdirectory and whatnot.

If you're into unnecessarily complicated publishing, this will give you joy.

lerna publish --contents dist
# publish the "dist" subfolder of every Lerna-managed leaf package

NOTE: You should wait until the postpublish lifecycle phase (root or leaf) to clean up this generated subdirectory, as the generated package.json is used during package upload (after postpack).

--dist-tag <tag>

lerna publish --dist-tag next

When run with this flag, lerna publish will publish to npm with the given npm dist-tag (defaults to latest).

This option can be used to publish a prerelease or beta version under a non-latest dist-tag, helping consumers avoid automatically upgrading to prerelease-quality code.

Note: the latest tag is the one that is used when a user runs npm install my-package. To install a different tag, a user can run npm install my-package@prerelease.

--git-head <sha>

Explicit SHA to set as gitHead on manifests when packing tarballs, only allowed with from-package positional.

For example, when publishing from AWS CodeBuild (where git is not available), you could use this option to pass the appropriate environment variable to use for this package metadata:

lerna publish from-package --git-head ${CODEBUILD_RESOLVED_SOURCE_VERSION}

Under all other circumstances, this value is derived from a local git command.

--graph-type <all|dependencies>

Set which kind of dependencies to use when building a package graph. The default value is dependencies, whereby only packages listed in the dependencies section of a package's package.json are included. Pass all to include both dependencies and devDependencies when constructing the package graph and determining topological order.

When using traditional peer + dev dependency pairs, this option should be configured to all so the peers are always published before their dependents.

lerna publish --graph-type all

Configured via lerna.json:

{
  "command": {
    "publish": {
      "graphType": "all"
    }
  }
}

--ignore-scripts

When passed, this flag will disable running lifecycle scripts during lerna publish.

--ignore-prepublish

When passed, this flag will disable running deprecated prepublish scripts during lerna publish.

--legacy-auth

When publishing packages that require authentication but you are working with an internally hosted NPM Registry that only uses the legacy Base64 version of username:password. This is the same as the NPM publish _auth flag.

lerna publish --legacy-auth aGk6bW9t

--no-git-reset

By default, lerna publish ensures any changes to the working tree have been reset.

To avoid this, pass --no-git-reset. This can be especially useful when used as part of a CI pipeline in conjunction with the --canary flag. For instance, the package.json version numbers which have been bumped may need to be used in subsequent CI pipeline steps (such as Docker builds).

lerna publish --no-git-reset

--no-granular-pathspec

By default, lerna publish will attempt (if enabled) to git checkout only the leaf package manifests that are temporarily modified during the publishing process. This yields the equivalent of git checkout -- packages/*/package.json, but tailored to exactly what changed.

If you know you need different behavior, you'll understand: Pass --no-granular-pathspec to make the git command literally git checkout -- .. By opting into this pathspec, you must have all intentionally unversioned content properly ignored.

This option makes the most sense configured in lerna.json, as you really don't want to mess it up:

{
  "version": "independent",
  "granularPathspec": false
}

The root-level configuration is intentional, as this also covers the identically-named option in lerna version.

--no-verify-access

By default, lerna will verify the logged-in npm user's access to the packages about to be published. Passing this flag will disable that check.

If you are using a third-party registry that does not support npm access ls-packages, you will need to pass this flag (or set command.publish.verifyAccess to false in lerna.json).

Please use with caution

--otp

When publishing packages that require two-factor authentication, you can specify a one-time password using --otp:

lerna publish --otp 123456

Please keep in mind that one-time passwords expire within 30 seconds of their generation. If it expires during publish operations, a prompt will request a refreshed value before continuing.

--preid

Unlike the lerna version option of the same name, this option only applies to --canary version calculation.

lerna publish --canary
# uses the next semantic prerelease version, e.g.
# 1.0.0 => 1.0.1-alpha.0

lerna publish --canary --preid next
# uses the next semantic prerelease version with a specific prerelease identifier, e.g.
# 1.0.0 => 1.0.1-next.0

When run with this flag, lerna publish --canary will increment premajor, preminor, prepatch, or prerelease semver bumps using the specified prerelease identifier.

--pre-dist-tag <tag>

lerna publish --pre-dist-tag next

Works the same as --dist-tag, except only applies to packages being released with a prerelease version.

--registry <url>

When run with this flag, forwarded npm commands will use the specified registry for your package(s).

This is useful if you do not want to explicitly set up your registry configuration in all of your package.json files individually when e.g. using private registries.

--tag-version-prefix

This option allows to provide custom prefix instead of the default one: v.

Keep in mind, if splitting lerna version and lerna publish, you need to pass it to both commands:

# locally
lerna version --tag-version-prefix=''

# on ci
lerna publish from-git --tag-version-prefix=''

You could also configure this at the root level of lerna.json, applying to both commands equally:

{
  "tagVersionPrefix": "",
  "packages": ["packages/*"],
  "version": "independent"
}

--temp-tag

When passed, this flag will alter the default publish process by first publishing all changed packages to a temporary dist-tag (lerna-temp) and then moving the new version(s) to the dist-tag configured by --dist-tag (default latest).

This is not generally necessary, as Lerna will publish packages in topological order (all dependencies before dependents) by default.

--yes

lerna publish --canary --yes
# skips `Are you sure you want to publish the above changes?`

When run with this flag, lerna publish will skip all confirmation prompts. Useful in Continuous integration (CI) to automatically answer the publish confirmation prompt.

Deprecated Options

--skip-npm

Call lerna version directly, instead.

Per-Package Configuration

A leaf package can be configured with special publishConfig that in certain circumstances changes the behavior of lerna publish.

publishConfig.access

To publish packages with a scope (e.g., @mycompany/rocks), you must set access:

  "publishConfig": {
    "access": "public"
  }
  • If this field is set for a package without a scope, it will fail.
  • If you want your scoped package to remain private (i.e., "restricted"), there is no need to set this value.

    Note that this is not the same as setting "private": true in a leaf package; if the private field is set, that package will never be published under any circumstances.

publishConfig.registry

You can customize the registry on a per-package basis by setting registry:

  "publishConfig": {
    "registry": "http://my-awesome-registry.com/"
  }
  • Passing --registry applies globally, and in some cases isn't what you want.

publishConfig.tag

You can customize the dist-tag on a per-package basis by setting tag:

  "publishConfig": {
    "tag": "flippin-sweet"
  }
  • Passing --dist-tag will overwrite this value.
  • This value is always ignored when --canary is passed.

publishConfig.directory

This non-standard field allows you to customize the published subdirectory just like --contents, but on a per-package basis. All other caveats of --contents still apply.

  "publishConfig": {
    "directory": "dist"
  }

Lifecycle Scripts

// prepublish:      Run BEFORE the package is packed and published.
// prepare:         Run BEFORE the package is packed and published, AFTER prepublish, BEFORE prepublishOnly.
// prepublishOnly:  Run BEFORE the package is packed and published, ONLY on npm publish.
// prepack:     Run BEFORE a tarball is packed.
// postpack:    Run AFTER the tarball has been generated and moved to its final destination.
// publish:     Run AFTER the package is published.
// postpublish: Run AFTER the package is published.

Lerna will run npm lifecycle scripts during lerna publish in the following order:

  1. If versioning implicitly, run all version lifecycle scripts
  2. Run prepublish lifecycle in root, if enabled
  3. Run prepare lifecycle in root
  4. Run prepublishOnly lifecycle in root
  5. Run prepack lifecycle in root
  6. For each changed package, in topological order (all dependencies before dependents):
    1. Run prepublish lifecycle, if enabled
    2. Run prepare lifecycle
    3. Run prepublishOnly lifecycle
    4. Run prepack lifecycle
    5. Create package tarball in temp directory via JS API
    6. Run postpack lifecycle
  7. Run postpack lifecycle in root
  8. For each changed package, in topological order (all dependencies before dependents):
    1. Publish package to configured registry via JS API
    2. Run publish lifecycle
    3. Run postpublish lifecycle
  9. Run publish lifecycle in root
    • To avoid recursive calls, don't use this root lifecycle to run lerna publish
  10. Run postpublish lifecycle in root
  11. Update temporary dist-tag to latest, if enabled

changelog

Change Log

All notable changes to this project will be documented in this file. See Conventional Commits for commit guidelines.

5.3.0 (2022-06-08)

Features

  • handle the edge cases in the lerna-nx integration (c6808fc)

5.2.1 (2022-06-07)

Note: Version bump only for package @spryker-lerna/publish

5.2.0 (2022-06-04)

Bug Fixes

  • lerna: apply tag prefix consistenly for all modes (69a319e)
  • scope: update packages scopes (b45949d)

5.1.4 (2022-06-04)

Bug Fixes

  • lerna: apply tag prefix consistenly for all modes (8869664)

5.1.1 (2022-06-04)

Note: Version bump only for package @spryker-lerna/publish

5.1.0 (2022-06-03)

Bug Fixes

  • scope: update packages scopes (eb0de43)

5.0.0 (2022-05-24)

Note: Version bump only for package @lerna/publish

4.0.0 (2021-02-10)

Bug Fixes

  • Improve accuracy of JSDoc type annotations (1ec69f0)

Features

  • deps: Bump dependencies (affed1c)
  • Consume named exports of sibling modules (63499e3)
  • deps: @evocateur/libnpmaccess -> libnpmaccess@^4.0.1 (7974b35)
  • deps: @evocateur/npm-registry-fetch -> npm-registry-fetch@^9.0.0 (6df42f2)
  • deps: @evocateur/pacote -> pacote@^11.1.13 (99b4217)
  • deps: execa@^4.1.0 (9051dca)
  • deps: fs-extra@^9.0.1 (2f6f4e0)
  • deps: npm-package-arg@^8.1.0 (12c8923)
  • deps: p-finally -> Promise.prototype.finally() (028db04)
  • deps: p-finally@^2.0.1 (165e47e)
  • deps: p-map@^4.0.0 (92b1364)
  • deps: p-pipe@^3.1.0 (489f59e)
  • deps: semver@^7.3.2 (003ad66)
  • publish: Remove figgy-pudding (caf823e)
  • Drop support for Node v6.x & v8.x (ff4bb4d)

BREAKING CHANGES

  • Node v6.x & v8.x are no longer supported. Please upgrade to the latest LTS release.

Here's the gnarly one-liner I used to make these changes:

npx lerna exec --concurrency 1 --stream -- 'json -I -f package.json -e '"'"'this.engines=this.engines||{};this.engines.node=">= 10.18.0"'"'"

(requires npm i -g json beforehand)

3.22.1 (2020-06-09)

Bug Fixes

3.22.0 (2020-05-24)

Bug Fixes

  • publish: Avoid errors when files are ignored by git (#2445) (448f2ae), closes #2151
  • publish: Avoid exception when publishing 1st version (#2485) (5d80285)
  • publish: Support --tag-version-prefix in --canary mode (#2435) (611c38e)

3.21.0 (2020-05-13)

Bug Fixes

  • publish: Canary releases without previous tags should not explode (c9eb590)

Features

  • version: Ignore private packages completely with --no-private (a9b9f97)

3.20.2 (2020-01-02)

Note: Version bump only for package @lerna/publish

3.20.1 (2019-12-29)

Note: Version bump only for package @lerna/publish

3.20.0 (2019-12-27)

Features

3.18.5 (2019-11-20)

Bug Fixes

  • Auto-fix prettier formatting (5344820)

3.18.4 (2019-11-08)

Note: Version bump only for package @lerna/publish

3.18.3 (2019-10-22)

Note: Version bump only for package @lerna/publish

3.18.2 (2019-10-21)

Note: Version bump only for package @lerna/publish

3.18.1 (2019-10-15)

Note: Version bump only for package @lerna/publish

3.18.0 (2019-10-15)

Bug Fixes

  • options: Explicit --ignore-prepublish (fa21723)
  • options: Explicit --ignore-scripts (efcb3bd)
  • options: Explicit --pre-dist-tag (1d9552c)

3.16.5 (2019-10-07)

Note: Version bump only for package @lerna/publish

3.16.4 (2019-07-24)

Bug Fixes

  • publish: Pass correct arguments to packDirectory() (b1aade3)

3.16.3 (2019-07-23)

Bug Fixes

  • publish: Identify tagged packages correctly with custom --tag-version-prefix (f4cbd4d), closes #2195

3.16.2 (2019-07-22)

Note: Version bump only for package @lerna/publish

3.16.1 (2019-07-19)

Note: Version bump only for package @lerna/publish

3.16.0 (2019-07-18)

Bug Fixes

  • deps: Bump @evocateur/pacote (03e4797)
  • deps: Update forked npm libs (4d67426)
  • publish: Add --graph-type option to control packages included in topological sort (#2152) (ae87669), closes #1437
  • publish: Allow --no-verify-access to prevent checking for account-level 2FA (ce58d8f)
  • publish: OTP cache should be seeded from conf value, not CLI directly (cf56622)
  • publish: Propagate root license into custom publish directories (d410a58), closes #2157

Features

  • deps: fs-extra@^8.1.0 (313287f)
  • deps: p-map@^2.1.0 (9e58394)
  • deps: semver@^6.2.0 (d8016d9)
  • publish: Eager prompt for OTP when account-level 2FA is enabled (4f893d1)

3.15.0 (2019-06-09)

Bug Fixes

  • deps: Consume forked npm libs (bdd4fa1)

3.14.2 (2019-06-09)

Bug Fixes

  • publish: Allow per-leaf subdirectory publishing (ea861d9), closes #2109

3.14.1 (2019-05-15)

Note: Version bump only for package @lerna/publish

3.14.0 (2019-05-14)

Features

3.13.4 (2019-04-24)

Note: Version bump only for package @lerna/publish

3.13.3 (2019-04-17)

Bug Fixes

3.13.2 (2019-04-08)

Bug Fixes

  • lifecycles: Avoid duplicating 'rooted leaf' lifecycles (a7ad9b6)

3.13.1 (2019-02-26)

Bug Fixes

3.13.0 (2019-02-15)

Features

  • meta: Add repository.directory field to package.json (aec5023)
  • meta: Normalize package.json homepage field (abeb4dc)

3.12.1 (2019-02-14)

Note: Version bump only for package @lerna/publish

3.12.0 (2019-02-14)

Bug Fixes

  • publish: Check for git describe error explicitly (237d1c5)
  • publish: Make the missing license warning clearer and more actionable (#1921) (8a71ac4)
  • publish: Revert foolhardy refactoring (5e975e0) (a6733a2)

Features

  • publish: Add --git-head option to preserve gitless from-package metadata (3d18f2f), closes #1933
  • publish: Allow from-package positional to run without a git repo (df49bfc), closes #1933

3.11.1 (2019-02-11)

Note: Version bump only for package @lerna/publish

3.11.0 (2019-02-08)

Bug Fixes

  • deps: Explicit libnpmaccess ^3.0.1 (6ba3d1d)
  • deps: Explicit libnpmpublish ^1.1.1 (a506d96)
  • deps: Explicit npm-package-arg ^6.1.0 (4b20791)
  • deps: Explicit npm-registry-fetch ^3.9.0 (a83c487)
  • deps: Explicit npmlog ^4.1.2 (571c2e2)
  • deps: Explicit pacote ^9.4.1 (44d05bf)
  • deps: Remove unused libnpm (replaced by direct sub-packages) (1caeb28)
  • publish: Correct silly log heading (f1dc3fc)

3.10.8 (2019-02-01)

Bug Fixes

3.10.7 (2019-01-22)

Note: Version bump only for package @lerna/publish

3.10.6 (2019-01-19)

Bug Fixes

  • options: Document negated boolean options explicitly (8bc9669)
  • publish: Map packument requests concurrently directly from package graph (c79a827)

3.10.5 (2019-01-11)

Note: Version bump only for package @lerna/publish

3.10.3 (2019-01-10)

Note: Version bump only for package @lerna/publish

3.10.1 (2019-01-09)

Note: Version bump only for package @lerna/publish

3.10.0 (2019-01-08)

Bug Fixes

  • publish: Correctly determine canary version when --include-merged-tags present (fb2a1b2), closes #1820

3.9.0 (2019-01-08)

Note: Version bump only for package @lerna/publish

3.8.5 (2019-01-05)

Bug Fixes

  • publish: Deprecate --npm-tag, replaced by --dist-tag (196d663)
  • publish: Ensure pkg.publishConfig is handled correctly when promoting dist-tags (af1c2ad)
  • publish: Tweak progress logging (5a04145)

3.8.4 (2019-01-03)

Bug Fixes

  • publish: Pass username to access.lsPackages() (31982a1)

3.8.3 (2019-01-03)

Bug Fixes

  • publish: Give up trying to validate third-party registries (b44f2f9), closes #1685 #1687

3.8.2 (2019-01-03)

Bug Fixes

  • publish: Avoid recursive root lifecycle execution (e133134)
  • publish: Run root prepublish lifecycle if it exists (c5676bb)

3.8.1 (2018-12-31)

Bug Fixes

  • progress: Correctly avoid progress where we don't want it (0de3df9)
  • progress: Enable progress during logging setup, correcting default (da81e60)
  • publish: --canary should also respect --include-merged-tags (462b15c), closes #1820

3.8.0 (2018-12-21)

Bug Fixes

  • publish: Heighten dist-tag success log level to distinguish from noisy fetch logging (f1f0871)
  • publish: Unhide options shared with version command (09fccd3)

Features

3.7.2 (2018-12-21)

Bug Fixes

  • pack-directory: Accept lazy Package, passing directory as second parameter (c6819c0)
  • publish: Re-order --git-reset flag in options (0653af9)
  • publish: Remove unused --npm-client option (4e7eaef)

3.7.1 (2018-12-20)

Bug Fixes

  • publish: Do not pass this.logger into conf, it does not respect log.level (9bcd503)
  • publish: Pulse progress bar during execution (49b8771)

3.7.0 (2018-12-19)

Bug Fixes

  • publish: Remove unused dependency (d4ab6c4)
  • publish: Short-circuit retries for npm username validation (ca4dd95)

Features

  • npm-publish: Use libnpm/publish instead of subprocess execution (433275e)
  • publish: Add npm-session, npm-version, and user-agent fields to libnpm/fetch config (5edb27d)
  • publish: Refresh package manifests after prepare/prepublishOnly lifecycle (e6b31f8)
  • publish: Use @lerna/pack-directory instead of subprocess npm pack (fd7299f)
  • publish: Use libnpm/publish instead of subprocess execution (58fda8d)

3.6.0 (2018-12-07)

Bug Fixes

  • pkg: Exclude mocks from package tarball (4017f37)

Features

  • Migrate existing usage to libnpm (0d3a786), closes #1767
  • npm-dist-tag: Use fetch API instead of CLI to make changes (54008c6)
  • publish: Add a "from-package" positional argument (#1708) (16611be), closes #1648
  • publish: Attempt profile retrieval before whoami endpoint during user validation (38097d8)

3.5.1 (2018-11-29)

Bug Fixes

  • publish: Pass explicit list of files to checkout instead of globs (a4c57c2), closes #1786

3.5.0 (2018-11-27)

Bug Fixes

  • publish: Ignore non-release tags when detecting from-git (#1782) (3cb7465)
  • version: Add friendly error message when remote branch doesn't exist (#1741) (cd34b48)
  • version: Don't version private packages lacking a version field (#1654) (578bb19)

Features

  • publish: Add option --no-git-reset to leave unstaged changes in working tree (#1791) (eae5619)

3.4.3 (2018-10-10)

Bug Fixes

  • publish: Use correct field name when limiting retries (76589d4)

3.4.2 (2018-10-09)

Bug Fixes

  • publish: Prevent retries during access validation so third-party registries are skipped faster (a89ae62)
  • publish: Use modern auth resolution (7ba41a6)

3.4.1 (2018-10-04)

Bug Fixes

  • publish: Overwrite Yarn registry proxy when encountered (f7fdc77)
  • publish: Set token on npm config, allow third-party registries to remain non-compliant (06a9479)

3.4.0 (2018-09-14)

Features

  • publish: Use APIs for validation queries instead of CLI (65fc603)

3.3.2 (2018-09-12)

Bug Fixes

  • publish: Allow --force-publish in a canary release (b97d9a3), closes #1638

3.3.1 (2018-09-11)

Note: Version bump only for package @lerna/publish

3.3.0 (2018-09-06)

Bug Fixes

  • describe-ref: Fallback refCount is the number of commits since beginning of repository (6dfea52)

Features

  • deps: Upgrade fs-extra to ^7.0.0 (042b1a3)

3.2.1 (2018-08-28)

Bug Fixes

  • publish: Use package version as fallback for independent canary bump (989a3b5), closes #1614

3.2.0 (2018-08-28)

Bug Fixes

  • publish: Call synthetic prepublishOnly lifecycle before packing (dda9812), closes #1169

Features

  • publish: Support prepack/postpack lifecycle in root manifest (9df88a4)

3.1.3 (2018-08-21)

Note: Version bump only for package @lerna/publish

3.1.2 (2018-08-20)

Bug Fixes

  • publish: Allow composed version command to decide when to verify working tree (e61aa67)
  • Use packageGraph.rawPackageList instead of misleading instance.filteredPackages (2e2abdc)

3.1.0 (2018-08-17)

Bug Fixes

  • command: Detect composed commands more accurately (1e51b39)
  • command: Log lerna CLI version with less ambiguity (67494e7)
  • publish: Throw errors if --canary attempted on unclean tree or tagged release (5da0e42)

3.0.6 (2018-08-16)

Note: Version bump only for package @lerna/publish

3.0.5 (2018-08-15)

Bug Fixes

  • help: Insert line break before describing boolean negations (da2f886)
  • options: Provide -y alias for --yes (3ea460c)
  • publish: Add confirmation prompt before execution (47766e5), closes #1566
  • publish: Get tagged packages from merge commit (#1567) (fc771d9)
  • version: Log skipped publish when composed (89645b7)

3.0.4 (2018-08-14)

Bug Fixes

  • publish: Do not ping third-party registries (42f4fdd), closes #1560
  • publish: Only pass --json to npm pack when npm >= 5.10.0 (71babce), closes #1558
  • publish: Run publish from leaf nodes again (3d348ec), closes #1560

3.0.3 (2018-08-11)

Bug Fixes

  • publish: Restore deprecated --skip-npm functionality (cb47cb6), closes #1553

3.0.2 (2018-08-11)

Bug Fixes

  • publish: Add default for --tag-version-prefix (f159442)
  • publish: Allow disabling of registry and package verification (0bfdff5), closes #1552

3.0.1 (2018-08-10)

Bug Fixes

  • publish: Allow unpublished packages to pass access verification (3a7348c)

3.0.0 (2018-08-10)

Bug Fixes

  • publish: Improve npm pack experience (627cfc2)

Features

BREAKING CHANGES

    • --preid now defaults to "alpha" during prereleases:

    The previous default for this option was undefined, which led to an awkward "1.0.1-0" result when passed to semver.inc().

    The new default "alpha" yields a much more useful "1.0.1-alpha.0" result. Any previous prerelease ID will be preserved, just as it was before.

  • --no-verify is no longer passed to git commit by default, but controlled by the new --commit-hooks option:

    The previous behavior was too overzealous, and the new option operates exactly like the corresponding npm version option of the same name.

    As long as your pre-commit hooks are properly scoped to ignore changes in package.json files, this change should not affect you. If that is not the case, you may pass --no-commit-hooks to restore the previous behavior.

3.0.0-rc.0 (2018-07-27)

Bug Fixes

  • core/package: Serialize hosted git URLs with original protocol/shorthand (60ff432), closes #1499
  • publish: Add default description 'npm' for --npm-client (649048c)
  • publish: Avoid fs-extra warning on 32-bit machines (e908d23)
  • publish: Do not leave unstaged changes with --skip-git (2d497ed)
  • publish: Exit early when publishing w/o commits (#1453) (6cbae35), closes #773
  • publish: Pass --repo-version argument through semver.valid() (272e9f1), closes #1483
  • publish: Update lerna.json version after root preversion lifecycle (7b3817c), closes #1495

Code Refactoring

  • collect-updates: Make argument signature explicit (e6ba19f)

Features

  • Add description from --help summary [skip ci] (9b65d8e)
  • cli: Upgrade to Yargs 12 (7899ab8)
  • command: Remove .defaultOptions() from option resolution stack (2b27a54)
  • Count packages affected in command summary logging (5f5e585)
  • publish: Add --require-scripts option to opt-in to raw JS lifecycle scripts (054392b)
  • publish: Add --amend flag (#1422) (ef5f0db)
  • publish: Ensure published packages contain a LICENSE file (#1465) (5863564), closes #1213

BREAKING CHANGES

  • publish: External $PKGDIR/scripts/{pre,post}publish.js lifecycles are now opt-in instead of automatic. Pass --require-scripts explicitly to restore previous functionality.
  • collect-updates: Instead of an opaque command instance, distinct positional arguments are required.

3.0.0-beta.21 (2018-05-12)

Note: Version bump only for package @lerna/publish

3.0.0-beta.20 (2018-05-07)

Note: Version bump only for package @lerna/publish

3.0.0-beta.19 (2018-05-03)

Bug Fixes

  • publish: Include all packages during global major bump (#1391) (9cebed1), closes #1383

3.0.0-beta.18 (2018-04-24)

Bug Fixes

  • git-utils: Pass --follow-tags to git push (6907e90)

Features

  • command: Move GitUtilities.isInitialized into class method (abecfcc)
  • git-utils: Devolve getCurrentSHA() to consumers (ecbc1d3)
  • git-utils: Devolve getShortSHA() to consumers (95d179d)
  • publish: Move publish-only git utilities (5594749)

BREAKING CHANGES

  • git-utils: Don't use GitUtilities!
  • git-utils: Don't use GitUtilities.
  • command: GitUtilities.isInitialized no longer exists. You shouldn't be using GitUtilities.
  • publish: Many named exports of GitUtilities are no longer provided. Don't use GitUtilities, it's a bad pattern.

3.0.0-beta.17 (2018-04-13)

Note: Version bump only for package @lerna/publish

3.0.0-beta.15 (2018-04-09)

Features

  • conventional-commits: Support local file presets (a1bff40)

3.0.0-beta.14 (2018-04-03)

Bug Fixes

  • publish: Ensure optionalDependencies are updated during publish to registry (559b731)

3.0.0-beta.13 (2018-03-31)

Features

  • Enable progress bars only when necessary (b766c83)

3.0.0-beta.12 (2018-03-30)

Features

  • package: Add serialize() method (fdec3ac)
  • package: Add Map-like get/set methods, remove raw json getter (707d1f0)
  • project: Merge package and packageJson into manifest (9a47ff7)

BREAKING CHANGES

  • package: The Package class no longer provides direct access to the JSON object used to construct the instance. Map-like get()/set(val) methods are available to modify the internal representation.

3.0.0-beta.11 (2018-03-29)

Bug Fixes

  • publish: Write temporary annotations once, not repeatedly (6abae76)

Features

  • Execute atomic publish lifecycle during lerna publish (#1348) (45efa24)
  • Support optionalDependencies (b73e19d), closes #121

3.0.0-beta.10 (2018-03-27)

Features

  • commands: Delay require of command instantiation (a1284f3)

BREAKING CHANGES

  • commands: The default export of command packages is now a factory, not the subclass (which is now a named export).

3.0.0-beta.9 (2018-03-24)

Bug Fixes

  • publish: Split --skip-* properly, leave working tree clean (5b4b2c9)

Features

  • command: Rename this.repository -> this.project (43e98a0)
  • project: Use cosmiconfig to locate and read lerna.json (b8c2789)

BREAKING CHANGES

  • publish: Previously, gitHead annotations were leftover if --skip-npm was passed, despite no actual requirement for that property when no publishing is going on.

Now, all publish-related operations are truly skipped with --skip-npm, and all git commit/push-related operations are skipped with --skip-git. Passing --skip-npm will now also always push to remote, which represents a breaking change from 2.x behavior.

Thanks @KingScooty for raising the issue!

3.0.0-beta.8 (2018-03-22)

Features

  • utils: Add "vendored" npm-conf (9c24a25)

3.0.0-beta.7 (2018-03-20)

Note: Version bump only for package @lerna/publish

3.0.0-beta.4 (2018-03-19)

Note: Version bump only for package @lerna/publish

3.0.0-beta.3 (2018-03-15)

Features

  • Check for upstream changes before attempting to publish (#1317) (cef0a69)
  • Upstream changes warn in CI, throw locally (4de055d), closes #1177 #1317
  • publish: Add logging when --skip-git or --skip-npm are passed (#1319) (8eef9ff)

3.0.0-beta.2 (2018-03-10)

Note: Version bump only for package @lerna/publish

3.0.0-beta.1 (2018-03-09)

Bug Fixes