1.2.7 • Published 5 months ago

@erickulcyk/midgard-yarn-strict v1.2.7

Weekly downloads
-
License
MIT
Repository
-
Last release
5 months ago

midgard-yarn-strict

midgard-yarn-strict is a stopgap package manager for the 1JS repository. The goal of 1JS is to use npm so we can lean on the npm team to deliver a first class support for our package manager. The scaling challenges faced by 1JS previous package manager midgard-yarn need a solution before all the blockers of using npm are resolved, midgard-yarn-strict is this solution.

midgard-yarn-strict is a fork of midgard-yarn, which is itself a fork of yarn v1.

Improvements over yarn

  • reliability retry on more errors.
  • performance detect abnormally long requests and when detected create racing requests.
  • performance use workers to copy files from cache to node_modules.
  • performance optimize cycle-detection algorithm from o(n2) to o(n.log(n)).
  • feature add support for --frozen-lockfile in monorepos.
  • bug fix yarn would not properly remove scoped package from node_modules after uninstalling this dependency.
  • performance and reliability optimize creation of bin scripts for large repos.

Improvements over midgard-yarn

  • midgard-yarn-strict implementes the isolated-mode npm's RFC. This brings the following benefits:
    • scoped install: unrelated workspaces will not impact your installation time.
    • performance: isolated-mode allows for a maximal de-duplication of dependencies, which leads to lower installation time.
    • incremental installation: the performance of the installation depends only on packages that have never been installed before. This means that switching back and forth between two branches is very fast.

Usage

Install

Instead of yarn install, run

$ npx midgard-yarn-strict

The installation flags supported by yarn are not supported by the CLI but some are still supported via the yarn config file.

Optionally a scope can be given:

$ `npx midgard-yarn-strict "build-tools-*"`

This will install the dependencies of the local packages matching the glob provided.

By default, midgard-yarn-strict does incremental installs by storing a .hash in each node_modules directory.

If you want to run without leveraging incremental, you can run with the --skip-cache flag, or alternatively, you can simply rm -rf path/to/packages/*/node_modules/.hash.

Upgrade or add a dependency

Manual edits to the package.json files is the only current supported way to manage dependencies, no CLI tool is available yet.

yarn link

Not supported yet.

yarn run

The yarn-run command is not affected by midgard-yarn-strict, so you can still run yarn test for example.

Configuration

midgard-yarn-strict allows you to declare dependencies on behalf of external packages, this is useful when external packages forgot to declare all their dependencies.

In the example below, webpack with a version matching "^4.0.0" will be installed as if it had declared a dependency on webpack-cli.

Using package.json

{
  // rest of package.json
  "extraDependencies": {
    "webpack": {
      "^4.0.0": {
        "dependencies": {
          "webpack-cli": "^4.0.0"
        }
      }
    }
  }
}

Using extraDependencies.json

{
  "webpack": {
    "^4.0.0": {
      "dependencies": {
        "webpack-cli": "^4.0.0"
      }
    }
  }
}

ENV VARIABLES

MYS_VERBOSE_FETCH

Output extra information to diagnose fetch issues.

MYS_MAX_FEED_CONNECTIONS

Maximum simultaneous connections to the npm feed

MYS_MAX_BLOB_STORAGE_CONNECTIONS

Maximum simultaneous connections to the blob storage (per domain).

YARN_CACHE_FOLDER

Customize location of cache folder. Can be relative of absolute path.

YARN_MEMORY_CACHE

Do not write packages to cache.

Prior art

This package manager is built on the learnings brought by npm, yarn and pnpm.

1.2.7

5 months ago

1.2.6

5 months ago