Compare commits
53 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
833530eb12 | ||
|
|
4bdd57ba0f | ||
|
|
d02ddcac2c | ||
|
|
ef7fc2f2c0 | ||
|
|
b64e5474ea | ||
|
|
1f970ccb7a | ||
|
|
6743aef70c | ||
|
|
10cdda081f | ||
|
|
8241287349 | ||
|
|
6aeab3349c | ||
|
|
bfce5889f7 | ||
|
|
fd412645ca | ||
|
|
2426a0c4b2 | ||
|
|
8a83b36688 | ||
|
|
414e8d426f | ||
|
|
1b102ab9a6 | ||
|
|
d4a733e4d8 | ||
|
|
1de3333651 | ||
|
|
1eaaada499 | ||
|
|
c92adb3c47 | ||
|
|
15eba7b7e6 | ||
|
|
a1601eddb8 | ||
|
|
324b81a722 | ||
|
|
55075db96d | ||
|
|
4618ce0aa1 | ||
|
|
3afdce0a2c | ||
|
|
8fbf8ab694 | ||
|
|
4fc91d408c | ||
|
|
f86847fdd2 | ||
|
|
9a769630d7 | ||
|
|
c26422a03e | ||
|
|
7c3cd81ad9 | ||
|
|
0ebda7eea3 | ||
|
|
5410ae57ba | ||
|
|
70aa611abc | ||
|
|
c08b38a2a4 | ||
|
|
a07cd41af1 | ||
|
|
d1a22a63bd | ||
|
|
0d9b5c2a00 | ||
|
|
44e1d9c911 | ||
|
|
b1331c20b0 | ||
|
|
766341fca1 | ||
|
|
946da2e743 | ||
|
|
dde04f9392 | ||
|
|
ffcb5213e2 | ||
|
|
ea3b65f02e | ||
|
|
ee6f766712 | ||
|
|
edacf8275e | ||
|
|
f36516b472 | ||
|
|
dc691121b8 | ||
|
|
ce35311657 | ||
|
|
fe06825a96 | ||
|
|
a60ac08a80 |
20
.github/SECURITY.md
vendored
20
.github/SECURITY.md
vendored
@@ -1,3 +1,23 @@
|
|||||||
# Security
|
# Security
|
||||||
|
|
||||||
Please email [@ljharb](https://github.com/ljharb) or see https://tidelift.com/security if you have a potential security vulnerability to report.
|
Please email [@ljharb](https://github.com/ljharb) or see https://tidelift.com/security if you have a potential security vulnerability to report.
|
||||||
|
|
||||||
|
## OpenSSF CII Best Practices
|
||||||
|
|
||||||
|
[](https://bestpractices.coreinfrastructure.org/projects/684)
|
||||||
|
|
||||||
|
There are three “tiers”: passing, silver, and gold.
|
||||||
|
|
||||||
|
### Passing
|
||||||
|
We meet 100% of the “passing” criteria.
|
||||||
|
|
||||||
|
### Silver
|
||||||
|
We meet 95% of the “silver” criteria. The gaps are as follows:
|
||||||
|
- we do not have a DCO or a CLA process for contributions.
|
||||||
|
- because we only have one maintainer, the project has no way to continue if that maintainer stops being active.
|
||||||
|
- we do not currently document “what the user can and cannot expect in terms of security” for our project. This is planned to be completed in 2023.
|
||||||
|
|
||||||
|
### Gold
|
||||||
|
We meet 65% of the “gold” criteria. The gaps are as follows:
|
||||||
|
- we do not yet have the “silver” badge; see all the gaps above.
|
||||||
|
- We do not include a copyright or license statement in each source file. Efforts are underway to change this archaic practice into a suggestion instead of a hard requirement.
|
||||||
|
|||||||
1
.github/workflows/latest-npm.yml
vendored
1
.github/workflows/latest-npm.yml
vendored
@@ -50,6 +50,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
allowed-endpoints:
|
allowed-endpoints:
|
||||||
github.com:443
|
github.com:443
|
||||||
|
raw.githubusercontent.com:443
|
||||||
iojs.org:443
|
iojs.org:443
|
||||||
nodejs.org:443
|
nodejs.org:443
|
||||||
registry.npmjs.org:443
|
registry.npmjs.org:443
|
||||||
|
|||||||
4
.github/workflows/lint.yml
vendored
4
.github/workflows/lint.yml
vendored
@@ -12,6 +12,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
allowed-endpoints:
|
allowed-endpoints:
|
||||||
github.com:443
|
github.com:443
|
||||||
|
raw.githubusercontent.com:443
|
||||||
nodejs.org:443
|
nodejs.org:443
|
||||||
registry.npmjs.org:443
|
registry.npmjs.org:443
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
@@ -31,6 +32,7 @@ jobs:
|
|||||||
allowed-endpoints:
|
allowed-endpoints:
|
||||||
ghcr.io:443
|
ghcr.io:443
|
||||||
github.com:443
|
github.com:443
|
||||||
|
raw.githubusercontent.com:443
|
||||||
pkg-containers.githubusercontent.com:443
|
pkg-containers.githubusercontent.com:443
|
||||||
nodejs.org:443
|
nodejs.org:443
|
||||||
registry.npmjs.org:443
|
registry.npmjs.org:443
|
||||||
@@ -50,6 +52,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
allowed-endpoints:
|
allowed-endpoints:
|
||||||
github.com:443
|
github.com:443
|
||||||
|
raw.githubusercontent.com:443
|
||||||
nodejs.org:443
|
nodejs.org:443
|
||||||
registry.npmjs.org:443
|
registry.npmjs.org:443
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
@@ -68,6 +71,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
allowed-endpoints:
|
allowed-endpoints:
|
||||||
github.com:443
|
github.com:443
|
||||||
|
raw.githubusercontent.com:443
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: check tests filenames
|
- name: check tests filenames
|
||||||
run: ./rename_test.sh --check
|
run: ./rename_test.sh --check
|
||||||
|
|||||||
56
.github/workflows/tests.yml
vendored
Normal file
56
.github/workflows/tests.yml
vendored
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
name: urchin tests
|
||||||
|
|
||||||
|
on: [push]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
tests:
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
|
||||||
|
name: "tests"
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: 'script -q -e -c "${{ matrix.shell }} {0}"'
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- shell: bash
|
||||||
|
suite: install_script
|
||||||
|
# shell:
|
||||||
|
# - bash
|
||||||
|
# suite:
|
||||||
|
# - install_script
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Harden Runner
|
||||||
|
uses: step-security/harden-runner@v1
|
||||||
|
with:
|
||||||
|
allowed-endpoints:
|
||||||
|
github.com:443
|
||||||
|
registry.npmjs.org:443
|
||||||
|
raw.githubusercontent.com:443
|
||||||
|
nodejs.org:443
|
||||||
|
iojs.org:443
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- run: sudo ${{ matrix.shell }} --version 2> /dev/null || dpkg -s ${{ matrix.shell }} 2> /dev/null || which ${{ matrix.shell }}
|
||||||
|
- run: curl --version
|
||||||
|
- run: wget --version
|
||||||
|
- uses: ljharb/actions/node/run@main
|
||||||
|
name: 'npm install && version checks'
|
||||||
|
with:
|
||||||
|
node-version: 'lts/*'
|
||||||
|
skip-ls-check: true
|
||||||
|
shell-command: echo installed
|
||||||
|
- run: npm ls urchin
|
||||||
|
- run: env
|
||||||
|
- run: make TERM=xterm-256color TEST_SUITE="${{ matrix.suite }}" SHELL="${{ matrix.shell }}" URCHIN="$(npx which urchin)" test-${{ matrix.shell }}
|
||||||
|
|
||||||
|
nvm:
|
||||||
|
name: 'all test suites, all shells'
|
||||||
|
needs: [tests]
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- run: 'echo tests completed'
|
||||||
62
.github/workflows/windows-npm.yml
vendored
62
.github/workflows/windows-npm.yml
vendored
@@ -55,7 +55,8 @@ jobs:
|
|||||||
- name: Install Cygwin
|
- name: Install Cygwin
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
export SITE='https://mirror.clarkson.edu/cygwin/'
|
export SITE='https://mirror.clarkson.edu/cygwin/' # see https://archlinux.org/mirrors/clarkson.edu/1603/ for uptime status
|
||||||
|
export SITE='https://mirrors.kernel.org/sourceware/cygwin/'
|
||||||
export LOCALDIR="$(pwd)"
|
export LOCALDIR="$(pwd)"
|
||||||
export ROOTDIR="$USERPROFILE\\cygwin"
|
export ROOTDIR="$USERPROFILE\\cygwin"
|
||||||
export PACKAGES='bash,git,curl'
|
export PACKAGES='bash,git,curl'
|
||||||
@@ -98,19 +99,29 @@ jobs:
|
|||||||
matrix:
|
matrix:
|
||||||
wsl-distrib:
|
wsl-distrib:
|
||||||
- Debian
|
- Debian
|
||||||
- Alpine
|
# - Alpine # fails
|
||||||
|
- Ubuntu-20.04
|
||||||
- Ubuntu-18.04
|
- Ubuntu-18.04
|
||||||
npm-node-version:
|
npm-node-version:
|
||||||
- '--lts'
|
- '--lts'
|
||||||
|
- '21'
|
||||||
|
- '18'
|
||||||
|
- '16'
|
||||||
- '14'
|
- '14'
|
||||||
- '12'
|
- '12'
|
||||||
- '11'
|
|
||||||
- '10'
|
- '10'
|
||||||
|
exclude:
|
||||||
|
- wsl-distrib: Ubuntu-18.04
|
||||||
|
npm-node-version: '--lts'
|
||||||
|
- wsl-distrib: Ubuntu-18.04
|
||||||
|
npm-node-version: '21'
|
||||||
|
- wsl-distrib: Ubuntu-18.04
|
||||||
|
npm-node-version: '18'
|
||||||
method:
|
method:
|
||||||
- ''
|
- ''
|
||||||
- 'script'
|
- 'script'
|
||||||
steps:
|
steps:
|
||||||
- uses: Vampire/setup-wsl@v1
|
- uses: Vampire/setup-wsl@v2
|
||||||
with:
|
with:
|
||||||
distribution: ${{ matrix.wsl-distrib }}
|
distribution: ${{ matrix.wsl-distrib }}
|
||||||
additional-packages: bash git curl ca-certificates wget
|
additional-packages: bash git curl ca-certificates wget
|
||||||
@@ -123,8 +134,51 @@ jobs:
|
|||||||
fi
|
fi
|
||||||
. "$HOME/.nvm/nvm.sh"
|
. "$HOME/.nvm/nvm.sh"
|
||||||
nvm install ${{ matrix.npm-node-version }}
|
nvm install ${{ matrix.npm-node-version }}
|
||||||
|
node -v
|
||||||
|
|
||||||
|
wsl_matrix_unofficial:
|
||||||
|
name: 'WSL nvm install'
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: wsl-bash {0}
|
||||||
|
runs-on: windows-latest
|
||||||
|
env:
|
||||||
|
WSLENV: NVM_INSTALL_GITHUB_REPO:NVM_INSTALL_VERSION:/p
|
||||||
|
NVM_NODEJS_ORG_MIRROR: https://unofficial-builds.nodejs.org/download/release
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
wsl-distrib:
|
||||||
|
- Alpine
|
||||||
|
npm-node-version:
|
||||||
|
- '--lts'
|
||||||
|
- '21'
|
||||||
|
- '18'
|
||||||
|
- '16'
|
||||||
|
- '14'
|
||||||
|
- '12'
|
||||||
|
- '11'
|
||||||
|
- '10'
|
||||||
|
method:
|
||||||
|
- ''
|
||||||
|
- 'script'
|
||||||
|
steps:
|
||||||
|
- uses: Vampire/setup-wsl@v2
|
||||||
|
with:
|
||||||
|
distribution: ${{ matrix.wsl-distrib }}
|
||||||
|
additional-packages: bash git curl ca-certificates wget
|
||||||
|
- name: Retrieve nvm on WSL
|
||||||
|
run: |
|
||||||
|
if [ -z "${{ matrix.method }}" ]; then
|
||||||
|
curl -fsSLo- "https://raw.githubusercontent.com/${NVM_INSTALL_GITHUB_REPO}/${NVM_INSTALL_VERSION}/install.sh" | bash
|
||||||
|
else
|
||||||
|
curl -fsSLo- "https://raw.githubusercontent.com/${NVM_INSTALL_GITHUB_REPO}/${NVM_INSTALL_VERSION}/install.sh" | METHOD="${{matrix.method}}" bash
|
||||||
|
fi
|
||||||
|
. "$HOME/.nvm/nvm.sh"
|
||||||
|
NVM_NODEJS_ORG_MIRROR=${{ env.NVM_NODEJS_ORG_MIRROR }} nvm install ${{ matrix.npm-node-version }}
|
||||||
|
|
||||||
nvm_windows:
|
nvm_windows:
|
||||||
|
name: 'tests, on windows'
|
||||||
permissions:
|
permissions:
|
||||||
contents: none
|
contents: none
|
||||||
needs: [wsl_matrix, cygwin_matrix, msys_matrix, msys_fail_install]
|
needs: [wsl_matrix, cygwin_matrix, msys_matrix, msys_fail_install]
|
||||||
|
|||||||
@@ -22,7 +22,10 @@ before_install:
|
|||||||
- bash --version | head
|
- bash --version | head
|
||||||
- zsh --version
|
- zsh --version
|
||||||
- dpkg -s dash | grep ^Version | awk '{print $2}'
|
- dpkg -s dash | grep ^Version | awk '{print $2}'
|
||||||
- pyenv local 3.9 || echo 'pyenv failed'
|
# install python
|
||||||
|
- pyenv install 2.7.18
|
||||||
|
- pyenv local 2.7.18 || echo 'pyenv failed'
|
||||||
|
- python -V
|
||||||
install:
|
install:
|
||||||
- if [ -z "${SHELLCHECK-}" ]; then nvm install 16 && nvm unalias default && npm install && npm prune && npm ls urchin doctoc eclint dockerfile_lint; fi
|
- if [ -z "${SHELLCHECK-}" ]; then nvm install 16 && nvm unalias default && npm install && npm prune && npm ls urchin doctoc eclint dockerfile_lint; fi
|
||||||
- '[ -z "$WITHOUT_CURL" ] || sudo apt-get remove curl -y'
|
- '[ -z "$WITHOUT_CURL" ] || sudo apt-get remove curl -y'
|
||||||
@@ -70,7 +73,6 @@ env:
|
|||||||
- PATH="/usr/lib/ccache/:$PATH"
|
- PATH="/usr/lib/ccache/:$PATH"
|
||||||
- NVM_DIR="${TRAVIS_BUILD_DIR}"
|
- NVM_DIR="${TRAVIS_BUILD_DIR}"
|
||||||
matrix:
|
matrix:
|
||||||
- SHELL=bash TEST_SUITE=install_script
|
|
||||||
- SHELL=sh TEST_SUITE=fast
|
- SHELL=sh TEST_SUITE=fast
|
||||||
- SHELL=dash TEST_SUITE=fast
|
- SHELL=dash TEST_SUITE=fast
|
||||||
- SHELL=bash TEST_SUITE=fast
|
- SHELL=bash TEST_SUITE=fast
|
||||||
|
|||||||
@@ -74,8 +74,6 @@ Verify your changes
|
|||||||
|
|
||||||
```
|
```
|
||||||
npm test
|
npm test
|
||||||
# or
|
|
||||||
npm run tests-only
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Push your changes
|
Push your changes
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
# Please note that it'll use about 1.2 GB disk space and about 15 minutes to
|
# Please note that it'll use about 1.2 GB disk space and about 15 minutes to
|
||||||
# build this image, it depends on your hardware.
|
# build this image, it depends on your hardware.
|
||||||
|
|
||||||
FROM ubuntu:20.04
|
FROM ubuntu:22.04
|
||||||
LABEL maintainer="Peter Dave Hello <hsu@peterdavehello.org>"
|
LABEL maintainer="Peter Dave Hello <hsu@peterdavehello.org>"
|
||||||
LABEL name="nvm-dev-env"
|
LABEL name="nvm-dev-env"
|
||||||
LABEL version="latest"
|
LABEL version="latest"
|
||||||
@@ -24,9 +24,6 @@ ENV SHELLCHECK_VERSION=0.7.0
|
|||||||
# ref: https://launchpad.net/ubuntu/+archivemirrors
|
# ref: https://launchpad.net/ubuntu/+archivemirrors
|
||||||
ENV UBUNTU_APT_SITE ubuntu.cs.utah.edu
|
ENV UBUNTU_APT_SITE ubuntu.cs.utah.edu
|
||||||
|
|
||||||
# Disable src package source
|
|
||||||
RUN sed -i 's/^deb-src\ /\#deb-src\ /g' /etc/apt/sources.list
|
|
||||||
|
|
||||||
# Replace origin apt package site with the mirror site
|
# Replace origin apt package site with the mirror site
|
||||||
RUN sed -E -i "s/([a-z]+.)?archive.ubuntu.com/$UBUNTU_APT_SITE/g" /etc/apt/sources.list
|
RUN sed -E -i "s/([a-z]+.)?archive.ubuntu.com/$UBUNTU_APT_SITE/g" /etc/apt/sources.list
|
||||||
RUN sed -i "s/security.ubuntu.com/$UBUNTU_APT_SITE/g" /etc/apt/sources.list
|
RUN sed -i "s/security.ubuntu.com/$UBUNTU_APT_SITE/g" /etc/apt/sources.list
|
||||||
@@ -86,7 +83,7 @@ RUN useradd -ms /bin/bash nvm
|
|||||||
|
|
||||||
# Copy and set permission for nvm directory
|
# Copy and set permission for nvm directory
|
||||||
COPY . /home/nvm/.nvm/
|
COPY . /home/nvm/.nvm/
|
||||||
RUN chown nvm:nvm -R "home/nvm/.nvm"
|
RUN chown nvm:nvm -R "/home/nvm/.nvm"
|
||||||
|
|
||||||
# Set sudoer for "nvm"
|
# Set sudoer for "nvm"
|
||||||
RUN echo 'nvm ALL=(ALL) NOPASSWD: ALL' >> /etc/sudoers
|
RUN echo 'nvm ALL=(ALL) NOPASSWD: ALL' >> /etc/sudoers
|
||||||
|
|||||||
70
README.md
70
README.md
@@ -1,6 +1,12 @@
|
|||||||
<a href="https://github.com/nvm-sh/logos"><img alt="nvm project logo" src="https://raw.githubusercontent.com/nvm-sh/logos/HEAD/nvm-logo-color.svg" height="50" /></a>
|
<a href="https://github.com/nvm-sh/logos">
|
||||||
|
<picture>
|
||||||
|
<source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/nvm-sh/logos/HEAD/nvm-logo-white.svg" />
|
||||||
|
<img src="https://raw.githubusercontent.com/nvm-sh/logos/HEAD/nvm-logo-color.svg" height="50" alt="nvm project logo" />
|
||||||
|
</picture>
|
||||||
|
</a>
|
||||||
|
|
||||||
# Node Version Manager [][3] [][4] [](https://bestpractices.coreinfrastructure.org/projects/684)
|
|
||||||
|
# Node Version Manager [][3] [][4] [](https://bestpractices.coreinfrastructure.org/projects/684)
|
||||||
|
|
||||||
<!-- To update this table of contents, ensure you have run `npm install` then `npm run doctoc` -->
|
<!-- To update this table of contents, ensure you have run `npm install` then `npm run doctoc` -->
|
||||||
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
|
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
|
||||||
@@ -95,10 +101,10 @@ nvm is a version manager for [node.js](https://nodejs.org/en/), designed to be i
|
|||||||
|
|
||||||
To **install** or **update** nvm, you should run the [install script][2]. To do that, you may either download and run the script manually, or use the following cURL or Wget command:
|
To **install** or **update** nvm, you should run the [install script][2]. To do that, you may either download and run the script manually, or use the following cURL or Wget command:
|
||||||
```sh
|
```sh
|
||||||
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash
|
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
|
||||||
```
|
```
|
||||||
```sh
|
```sh
|
||||||
wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash
|
wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
|
||||||
```
|
```
|
||||||
|
|
||||||
Running either of the above commands downloads a script and runs it. The script clones the nvm repository to `~/.nvm`, and attempts to add the source lines from the snippet below to the correct profile file (`~/.bash_profile`, `~/.zshrc`, `~/.profile`, or `~/.bashrc`).
|
Running either of the above commands downloads a script and runs it. The script clones the nvm repository to `~/.nvm`, and attempts to add the source lines from the snippet below to the correct profile file (`~/.bash_profile`, `~/.zshrc`, `~/.profile`, or `~/.bashrc`).
|
||||||
@@ -120,6 +126,8 @@ Eg: `curl ... | NVM_DIR="path/to/nvm"`. Ensure that the `NVM_DIR` does not conta
|
|||||||
|
|
||||||
- The installer can use `git`, `curl`, or `wget` to download `nvm`, whichever is available.
|
- The installer can use `git`, `curl`, or `wget` to download `nvm`, whichever is available.
|
||||||
|
|
||||||
|
- You can instruct the installer to not edit your shell config (for example if you already get completions via a [zsh nvm plugin](https://github.com/ohmyzsh/ohmyzsh/tree/master/plugins/nvm)) by setting `PROFILE=/dev/null` before running the `install.sh` script. Here's an example one-line command to do that: `PROFILE=/dev/null bash -c 'curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash'`
|
||||||
|
|
||||||
#### Troubleshooting on Linux
|
#### Troubleshooting on Linux
|
||||||
|
|
||||||
On Linux, after running the install script, if you get `nvm: command not found` or see no feedback from your terminal after you type `command -v nvm`, simply close your current terminal, open a new terminal, and try verifying again.
|
On Linux, after running the install script, if you get `nvm: command not found` or see no feedback from your terminal after you type `command -v nvm`, simply close your current terminal, open a new terminal, and try verifying again.
|
||||||
@@ -166,7 +174,7 @@ You can use a task:
|
|||||||
```yaml
|
```yaml
|
||||||
- name: Install nvm
|
- name: Install nvm
|
||||||
ansible.builtin.shell: >
|
ansible.builtin.shell: >
|
||||||
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash
|
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
|
||||||
args:
|
args:
|
||||||
creates: "{{ ansible_env.HOME }}/.nvm/nvm.sh"
|
creates: "{{ ansible_env.HOME }}/.nvm/nvm.sh"
|
||||||
```
|
```
|
||||||
@@ -228,7 +236,7 @@ If you have `git` installed (requires git v1.7.10+):
|
|||||||
|
|
||||||
1. clone this repo in the root of your user profile
|
1. clone this repo in the root of your user profile
|
||||||
- `cd ~/` from anywhere then `git clone https://github.com/nvm-sh/nvm.git .nvm`
|
- `cd ~/` from anywhere then `git clone https://github.com/nvm-sh/nvm.git .nvm`
|
||||||
1. `cd ~/.nvm` and check out the latest version with `git checkout v0.39.3`
|
1. `cd ~/.nvm` and check out the latest version with `git checkout v0.39.5`
|
||||||
1. activate `nvm` by sourcing it from your shell: `. ./nvm.sh`
|
1. activate `nvm` by sourcing it from your shell: `. ./nvm.sh`
|
||||||
|
|
||||||
Now add these lines to your `~/.bashrc`, `~/.profile`, or `~/.zshrc` file to have it automatically sourced upon login:
|
Now add these lines to your `~/.bashrc`, `~/.profile`, or `~/.zshrc` file to have it automatically sourced upon login:
|
||||||
@@ -381,7 +389,7 @@ or, you can at any time run the following command to get the latest supported np
|
|||||||
nvm install-latest-npm
|
nvm install-latest-npm
|
||||||
```
|
```
|
||||||
|
|
||||||
If you've already gotten an error to the effect of "npm does not support Node.js", you'll need to (1) revert to a previous node version (`nvm ls` & `nvm use <your latest _working_ version from the ls>`, (2) delete the newly created node version (`nvm uninstall <your _broken_ version of node from the ls>`), then (3) rerun your `nvm install` with the `--latest-npm` flag.
|
If you've already gotten an error to the effect of "npm does not support Node.js", you'll need to (1) revert to a previous node version (`nvm ls` & `nvm use <your latest _working_ version from the ls>`), (2) delete the newly created node version (`nvm uninstall <your _broken_ version of node from the ls>`), then (3) rerun your `nvm install` with the `--latest-npm` flag.
|
||||||
|
|
||||||
|
|
||||||
### Default Global Packages From File While Installing
|
### Default Global Packages From File While Installing
|
||||||
@@ -491,7 +499,9 @@ nvm deactivate
|
|||||||
To set a default Node version to be used in any new shell, use the alias 'default':
|
To set a default Node version to be used in any new shell, use the alias 'default':
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
nvm alias default node
|
nvm alias default node # this refers to the latest installed version of node
|
||||||
|
nvm alias default 18 # this refers to the latest installed v18.x version of node
|
||||||
|
nvm alias default 18.12 # this refers to the latest installed v18.12.x version of node
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Use a mirror of node binaries
|
#### Use a mirror of node binaries
|
||||||
@@ -532,7 +542,7 @@ $ echo "node" > .nvmrc # to default to the latest version
|
|||||||
|
|
||||||
[NB these examples assume a POSIX-compliant shell version of `echo`. If you use a Windows `cmd` development environment, eg the `.nvmrc` file is used to configure a remote Linux deployment, then keep in mind the `"`s will be copied leading to an invalid file. Remove them.]
|
[NB these examples assume a POSIX-compliant shell version of `echo`. If you use a Windows `cmd` development environment, eg the `.nvmrc` file is used to configure a remote Linux deployment, then keep in mind the `"`s will be copied leading to an invalid file. Remove them.]
|
||||||
|
|
||||||
Then when you run nvm:
|
Then when you run nvm use:
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
$ nvm use
|
$ nvm use
|
||||||
@@ -540,6 +550,19 @@ Found '/path/to/project/.nvmrc' with version <5.9>
|
|||||||
Now using node v5.9.1 (npm v3.7.3)
|
Now using node v5.9.1 (npm v3.7.3)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Running nvm install will also switch over to the correct version, but if the correct node version isn't already installed, it will install it for you.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
$ nvm install
|
||||||
|
Found '/path/to/project/.nvmrc' with version <5.9>
|
||||||
|
Downloading and installing node v5.9.1...
|
||||||
|
Downloading https://nodejs.org/dist/v5.9.1/node-v5.9.1-linux-x64.tar.xz...
|
||||||
|
#################################################################################### 100.0%
|
||||||
|
Computing checksum with sha256sum
|
||||||
|
Checksums matched!
|
||||||
|
Now using node v5.9.1 (npm v3.7.3)
|
||||||
|
```
|
||||||
|
|
||||||
`nvm use` et. al. will traverse directory structure upwards from the current directory looking for the `.nvmrc` file. In other words, running `nvm use` et. al. in any subdirectory of a directory with an `.nvmrc` will result in that `.nvmrc` being utilized.
|
`nvm use` et. al. will traverse directory structure upwards from the current directory looking for the `.nvmrc` file. In other words, running `nvm use` et. al. in any subdirectory of a directory with an `.nvmrc` will result in that `.nvmrc` being utilized.
|
||||||
|
|
||||||
The contents of a `.nvmrc` file **must** be the `<version>` (as described by `nvm --help`) followed by a newline. No trailing spaces are allowed, and the trailing newline is required.
|
The contents of a `.nvmrc` file **must** be the `<version>` (as described by `nvm --help`) followed by a newline. No trailing spaces are allowed, and the trailing newline is required.
|
||||||
@@ -548,6 +571,8 @@ The contents of a `.nvmrc` file **must** be the `<version>` (as described by `nv
|
|||||||
|
|
||||||
You can use [`avn`](https://github.com/wbyoung/avn) to deeply integrate into your shell and automatically invoke `nvm` when changing directories. `avn` is **not** supported by the `nvm` maintainers. Please [report issues to the `avn` team](https://github.com/wbyoung/avn/issues/new).
|
You can use [`avn`](https://github.com/wbyoung/avn) to deeply integrate into your shell and automatically invoke `nvm` when changing directories. `avn` is **not** supported by the `nvm` maintainers. Please [report issues to the `avn` team](https://github.com/wbyoung/avn/issues/new).
|
||||||
|
|
||||||
|
You can also use [`nvshim`](https://github.com/iamogbz/nvshim) to shim the `node`, `npm`, and `npx` bins to automatically use the `nvm` config in the current directory. `nvshim` is **not** supported by the `nvm` maintainers. Please [report issues to the `nvshim` team](https://github.com/iamogbz/nvshim/issues/new).
|
||||||
|
|
||||||
If you prefer a lighter-weight solution, the recipes below have been contributed by `nvm` users. They are **not** supported by the `nvm` maintainers. We are, however, accepting pull requests for more examples.
|
If you prefer a lighter-weight solution, the recipes below have been contributed by `nvm` users. They are **not** supported by the `nvm` maintainers. We are, however, accepting pull requests for more examples.
|
||||||
|
|
||||||
#### bash
|
#### bash
|
||||||
@@ -599,8 +624,9 @@ cdnvm() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
alias cd='cdnvm'
|
alias cd='cdnvm'
|
||||||
cd "$PWD"
|
cdnvm "$PWD" || exit
|
||||||
```
|
```
|
||||||
|
|
||||||
This alias would search 'up' from your current directory in order to detect a `.nvmrc` file. If it finds it, it will switch to that version; if not, it will use the default version.
|
This alias would search 'up' from your current directory in order to detect a `.nvmrc` file. If it finds it, it will switch to that version; if not, it will use the default version.
|
||||||
@@ -615,11 +641,14 @@ Put this into your `$HOME/.zshrc` to call `nvm use` automatically whenever you e
|
|||||||
```zsh
|
```zsh
|
||||||
# place this after nvm initialization!
|
# place this after nvm initialization!
|
||||||
autoload -U add-zsh-hook
|
autoload -U add-zsh-hook
|
||||||
|
|
||||||
load-nvmrc() {
|
load-nvmrc() {
|
||||||
local nvmrc_path="$(nvm_find_nvmrc)"
|
local nvmrc_path
|
||||||
|
nvmrc_path="$(nvm_find_nvmrc)"
|
||||||
|
|
||||||
if [ -n "$nvmrc_path" ]; then
|
if [ -n "$nvmrc_path" ]; then
|
||||||
local nvmrc_node_version=$(nvm version "$(cat "${nvmrc_path}")")
|
local nvmrc_node_version
|
||||||
|
nvmrc_node_version=$(nvm version "$(cat "${nvmrc_path}")")
|
||||||
|
|
||||||
if [ "$nvmrc_node_version" = "N/A" ]; then
|
if [ "$nvmrc_node_version" = "N/A" ]; then
|
||||||
nvm install
|
nvm install
|
||||||
@@ -631,6 +660,7 @@ load-nvmrc() {
|
|||||||
nvm use default
|
nvm use default
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
add-zsh-hook chpwd load-nvmrc
|
add-zsh-hook chpwd load-nvmrc
|
||||||
load-nvmrc
|
load-nvmrc
|
||||||
```
|
```
|
||||||
@@ -794,13 +824,13 @@ If installing nvm on Alpine Linux *is* still what you want or need to do, you sh
|
|||||||
### Alpine Linux 3.13+
|
### Alpine Linux 3.13+
|
||||||
```sh
|
```sh
|
||||||
apk add -U curl bash ca-certificates openssl ncurses coreutils python3 make gcc g++ libgcc linux-headers grep util-linux binutils findutils
|
apk add -U curl bash ca-certificates openssl ncurses coreutils python3 make gcc g++ libgcc linux-headers grep util-linux binutils findutils
|
||||||
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash
|
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
|
||||||
```
|
```
|
||||||
|
|
||||||
### Alpine Linux 3.5 - 3.12
|
### Alpine Linux 3.5 - 3.12
|
||||||
```sh
|
```sh
|
||||||
apk add -U curl bash ca-certificates openssl ncurses coreutils python2 make gcc g++ libgcc linux-headers grep util-linux binutils findutils
|
apk add -U curl bash ca-certificates openssl ncurses coreutils python2 make gcc g++ libgcc linux-headers grep util-linux binutils findutils
|
||||||
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash
|
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
|
||||||
```
|
```
|
||||||
|
|
||||||
_Note: Alpine 3.5 can only install NodeJS versions up to v6.9.5, Alpine 3.6 can only install versions up to v6.10.3, Alpine 3.7 installs versions up to v8.9.3, Alpine 3.8 installs versions up to v8.14.0, Alpine 3.9 installs versions up to v10.19.0, Alpine 3.10 installs versions up to v10.24.1, Alpine 3.11 installs versions up to v12.22.6, Alpine 3.12 installs versions up to v12.22.12, Alpine 3.13 & 3.14 install versions up to v14.20.0, Alpine 3.15 & 3.16 install versions up to v16.16.0 (**These are all versions on the main branch**). Alpine 3.5 - 3.12 required the package `python2` to build NodeJS, as they are older versions to build. Alpine 3.13+ requires `python3` to successfully build newer NodeJS versions, but you can use `python2` with Alpine 3.13+ if you need to build versions of node supported in Alpine 3.5 - 3.15, you just need to specify what version of NodeJS you need to install in the package install script._
|
_Note: Alpine 3.5 can only install NodeJS versions up to v6.9.5, Alpine 3.6 can only install versions up to v6.10.3, Alpine 3.7 installs versions up to v8.9.3, Alpine 3.8 installs versions up to v8.14.0, Alpine 3.9 installs versions up to v10.19.0, Alpine 3.10 installs versions up to v10.24.1, Alpine 3.11 installs versions up to v12.22.6, Alpine 3.12 installs versions up to v12.22.12, Alpine 3.13 & 3.14 install versions up to v14.20.0, Alpine 3.15 & 3.16 install versions up to v16.16.0 (**These are all versions on the main branch**). Alpine 3.5 - 3.12 required the package `python2` to build NodeJS, as they are older versions to build. Alpine 3.13+ requires `python3` to successfully build newer NodeJS versions, but you can use `python2` with Alpine 3.13+ if you need to build versions of node supported in Alpine 3.5 - 3.15, you just need to specify what version of NodeJS you need to install in the package install script._
|
||||||
@@ -899,10 +929,10 @@ You have to make sure that the user directory name in `$HOME` and the user direc
|
|||||||
To change the user directory and/or account name follow the instructions [here](https://support.apple.com/en-us/HT201548)
|
To change the user directory and/or account name follow the instructions [here](https://support.apple.com/en-us/HT201548)
|
||||||
|
|
||||||
[1]: https://github.com/nvm-sh/nvm.git
|
[1]: https://github.com/nvm-sh/nvm.git
|
||||||
[2]: https://github.com/nvm-sh/nvm/blob/v0.39.3/install.sh
|
[2]: https://github.com/nvm-sh/nvm/blob/v0.39.5/install.sh
|
||||||
[3]: https://travis-ci.org/nvm-sh/nvm
|
[3]: https://app.travis-ci.com/nvm-sh/nvm
|
||||||
[4]: https://github.com/nvm-sh/nvm/releases/tag/v0.39.3
|
[4]: https://github.com/nvm-sh/nvm/releases/tag/v0.39.5
|
||||||
[Urchin]: https://github.com/scraperwiki/urchin
|
[Urchin]: https://git.sdf.org/tlevine/urchin
|
||||||
[Fish]: https://fishshell.com
|
[Fish]: https://fishshell.com
|
||||||
|
|
||||||
**Homebrew makes zsh directories unsecure**
|
**Homebrew makes zsh directories unsecure**
|
||||||
@@ -986,7 +1016,7 @@ Now you should be able to use node as usual.
|
|||||||
If you've encountered this error on WSL-2:
|
If you've encountered this error on WSL-2:
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash
|
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.5/install.sh | bash
|
||||||
% Total % Received % Xferd Average Speed Time Time Time Current
|
% Total % Received % Xferd Average Speed Time Time Time Current
|
||||||
Dload Upload Total Spent Left Speed
|
Dload Upload Total Spent Left Speed
|
||||||
0 0 0 0 0 0 0 0 --:--:-- 0:00:09 --:--:-- 0curl: (6) Could not resolve host: raw.githubusercontent.com
|
0 0 0 0 0 0 0 0 --:--:-- 0:00:09 --:--:-- 0curl: (6) Could not resolve host: raw.githubusercontent.com
|
||||||
@@ -1007,7 +1037,7 @@ This could simply be solved by running this in your root directory:
|
|||||||
sudo chattr +i /etc/resolv.conf
|
sudo chattr +i /etc/resolv.conf
|
||||||
```
|
```
|
||||||
|
|
||||||
This deletes your `resolve.conf` file thats automatically generated when u run WSL, creates a new file and puts `nameserver 8.8.8.8`, then creates a `wsl.conf` file and adds `[network]` and `generateResolveConf = false` to prevent auto generation of that file.
|
This deletes your `resolv.conf` file thats automatically generated when u run WSL, creates a new file and puts `nameserver 8.8.8.8`, then creates a `wsl.conf` file and adds `[network]` and `generateResolveConf = false` to prevent auto generation of that file.
|
||||||
|
|
||||||
You can check the contents of the file by running:
|
You can check the contents of the file by running:
|
||||||
|
|
||||||
|
|||||||
18
install.sh
18
install.sh
@@ -33,7 +33,7 @@ nvm_install_dir() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
nvm_latest_version() {
|
nvm_latest_version() {
|
||||||
nvm_echo "v0.39.3"
|
nvm_echo "v0.39.5"
|
||||||
}
|
}
|
||||||
|
|
||||||
nvm_profile_is_bash_or_zsh() {
|
nvm_profile_is_bash_or_zsh() {
|
||||||
@@ -52,12 +52,28 @@ nvm_profile_is_bash_or_zsh() {
|
|||||||
#
|
#
|
||||||
# Outputs the location to NVM depending on:
|
# Outputs the location to NVM depending on:
|
||||||
# * The availability of $NVM_SOURCE
|
# * The availability of $NVM_SOURCE
|
||||||
|
# * The presence of $NVM_INSTALL_GITHUB_REPO
|
||||||
# * The method used ("script" or "git" in the script, defaults to "git")
|
# * The method used ("script" or "git" in the script, defaults to "git")
|
||||||
# NVM_SOURCE always takes precedence unless the method is "script-nvm-exec"
|
# NVM_SOURCE always takes precedence unless the method is "script-nvm-exec"
|
||||||
#
|
#
|
||||||
nvm_source() {
|
nvm_source() {
|
||||||
local NVM_GITHUB_REPO
|
local NVM_GITHUB_REPO
|
||||||
NVM_GITHUB_REPO="${NVM_INSTALL_GITHUB_REPO:-nvm-sh/nvm}"
|
NVM_GITHUB_REPO="${NVM_INSTALL_GITHUB_REPO:-nvm-sh/nvm}"
|
||||||
|
if [ "${NVM_GITHUB_REPO}" != 'nvm-sh/nvm' ]; then
|
||||||
|
{ nvm_echo >&2 "$(cat)" ; } << EOF
|
||||||
|
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
||||||
|
@ WARNING: REMOTE REPO IDENTIFICATION HAS CHANGED! @
|
||||||
|
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
|
||||||
|
IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!
|
||||||
|
|
||||||
|
The default repository for this install is \`nvm-sh/nvm\`,
|
||||||
|
but the environment variables \`\$NVM_INSTALL_GITHUB_REPO\` is
|
||||||
|
currently set to \`${NVM_GITHUB_REPO}\`.
|
||||||
|
|
||||||
|
If this is not intentional, interrupt this installation and
|
||||||
|
verify your environment variables.
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
local NVM_VERSION
|
local NVM_VERSION
|
||||||
NVM_VERSION="${NVM_INSTALL_VERSION:-$(nvm_latest_version)}"
|
NVM_VERSION="${NVM_INSTALL_VERSION:-$(nvm_latest_version)}"
|
||||||
local NVM_METHOD
|
local NVM_METHOD
|
||||||
|
|||||||
2
nvm-exec
2
nvm-exec
@@ -2,6 +2,8 @@
|
|||||||
|
|
||||||
DIR="$(command cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
DIR="$(command cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
||||||
|
|
||||||
|
unset NVM_CD_FLAGS
|
||||||
|
|
||||||
# shellcheck disable=SC1090,SC1091
|
# shellcheck disable=SC1090,SC1091
|
||||||
\. "$DIR/nvm.sh" --no-use
|
\. "$DIR/nvm.sh" --no-use
|
||||||
|
|
||||||
|
|||||||
117
nvm.sh
117
nvm.sh
@@ -163,7 +163,11 @@ nvm_is_version_installed() {
|
|||||||
|
|
||||||
nvm_print_npm_version() {
|
nvm_print_npm_version() {
|
||||||
if nvm_has "npm"; then
|
if nvm_has "npm"; then
|
||||||
command printf " (npm v$(npm --version 2>/dev/null))"
|
local NPM_VERSION
|
||||||
|
NPM_VERSION="$(npm --version 2>/dev/null)"
|
||||||
|
if [ -n "${NPM_VERSION}" ]; then
|
||||||
|
command printf " (npm v${NPM_VERSION})"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -313,6 +317,21 @@ nvm_install_latest_npm() {
|
|||||||
if [ $NVM_IS_17_OR_ABOVE -eq 1 ] && nvm_version_greater_than_or_equal_to "${NODE_VERSION}" 18.0.0; then
|
if [ $NVM_IS_17_OR_ABOVE -eq 1 ] && nvm_version_greater_than_or_equal_to "${NODE_VERSION}" 18.0.0; then
|
||||||
NVM_IS_18_OR_ABOVE=1
|
NVM_IS_18_OR_ABOVE=1
|
||||||
fi
|
fi
|
||||||
|
local NVM_IS_18_17_OR_ABOVE
|
||||||
|
NVM_IS_18_17_OR_ABOVE=0
|
||||||
|
if [ $NVM_IS_18_OR_ABOVE -eq 1 ] && nvm_version_greater_than_or_equal_to "${NODE_VERSION}" 18.17.0; then
|
||||||
|
NVM_IS_18_17_OR_ABOVE=1
|
||||||
|
fi
|
||||||
|
local NVM_IS_19_OR_ABOVE
|
||||||
|
NVM_IS_19_OR_ABOVE=0
|
||||||
|
if [ $NVM_IS_18_17_OR_ABOVE -eq 1 ] && nvm_version_greater_than_or_equal_to "${NODE_VERSION}" 19.0.0; then
|
||||||
|
NVM_IS_19_OR_ABOVE=1
|
||||||
|
fi
|
||||||
|
local NVM_IS_20_5_OR_ABOVE
|
||||||
|
NVM_IS_20_5_OR_ABOVE=0
|
||||||
|
if [ $NVM_IS_19_OR_ABOVE -eq 1 ] && nvm_version_greater_than_or_equal_to "${NODE_VERSION}" 20.5.0; then
|
||||||
|
NVM_IS_20_5_OR_ABOVE=1
|
||||||
|
fi
|
||||||
|
|
||||||
if [ $NVM_IS_4_4_OR_BELOW -eq 1 ] || {
|
if [ $NVM_IS_4_4_OR_BELOW -eq 1 ] || {
|
||||||
[ $NVM_IS_5_OR_ABOVE -eq 1 ] && nvm_version_greater 5.10.0 "${NODE_VERSION}"; \
|
[ $NVM_IS_5_OR_ABOVE -eq 1 ] && nvm_version_greater 5.10.0 "${NODE_VERSION}"; \
|
||||||
@@ -353,6 +372,12 @@ nvm_install_latest_npm() {
|
|||||||
; then
|
; then
|
||||||
nvm_echo '* `npm` `v8.x` is the last version that works on `node` `v12`, `v14.13` - `v14.16`, or `v16.0` - `v16.12`'
|
nvm_echo '* `npm` `v8.x` is the last version that works on `node` `v12`, `v14.13` - `v14.16`, or `v16.0` - `v16.12`'
|
||||||
$NVM_NPM_CMD install -g npm@8
|
$NVM_NPM_CMD install -g npm@8
|
||||||
|
elif \
|
||||||
|
[ $NVM_IS_18_17_OR_ABOVE -eq 0 ] \
|
||||||
|
|| { [ $NVM_IS_19_OR_ABOVE -eq 1 ] && [ $NVM_IS_20_5_OR_ABOVE -eq 0 ]; } \
|
||||||
|
; then
|
||||||
|
nvm_echo '* `npm` `v9.x` is the last version that works on `node` `< v18.17`, `v19`, or `v20.0` - `v20.4`'
|
||||||
|
$NVM_NPM_CMD install -g npm@9
|
||||||
else
|
else
|
||||||
nvm_echo '* Installing latest `npm`; if this does not work on your node version, please report a bug!'
|
nvm_echo '* Installing latest `npm`; if this does not work on your node version, please report a bug!'
|
||||||
$NVM_NPM_CMD install -g npm
|
$NVM_NPM_CMD install -g npm
|
||||||
@@ -418,7 +443,7 @@ nvm_tree_contains_path() {
|
|||||||
nvm_find_project_dir() {
|
nvm_find_project_dir() {
|
||||||
local path_
|
local path_
|
||||||
path_="${PWD}"
|
path_="${PWD}"
|
||||||
while [ "${path_}" != "" ] && [ ! -f "${path_}/package.json" ] && [ ! -d "${path_}/node_modules" ]; do
|
while [ "${path_}" != "" ] && [ "${path_}" != '.' ] && [ ! -f "${path_}/package.json" ] && [ ! -d "${path_}/node_modules" ]; do
|
||||||
path_=${path_%/*}
|
path_=${path_%/*}
|
||||||
done
|
done
|
||||||
nvm_echo "${path_}"
|
nvm_echo "${path_}"
|
||||||
@@ -428,7 +453,7 @@ nvm_find_project_dir() {
|
|||||||
nvm_find_up() {
|
nvm_find_up() {
|
||||||
local path_
|
local path_
|
||||||
path_="${PWD}"
|
path_="${PWD}"
|
||||||
while [ "${path_}" != "" ] && [ ! -f "${path_}/${1-}" ]; do
|
while [ "${path_}" != "" ] && [ "${path_}" != '.' ] && [ ! -f "${path_}/${1-}" ]; do
|
||||||
path_=${path_%/*}
|
path_=${path_%/*}
|
||||||
done
|
done
|
||||||
nvm_echo "${path_}"
|
nvm_echo "${path_}"
|
||||||
@@ -731,10 +756,16 @@ nvm_normalize_lts() {
|
|||||||
local LTS
|
local LTS
|
||||||
LTS="${1-}"
|
LTS="${1-}"
|
||||||
|
|
||||||
if [ "$(expr "${LTS}" : '^lts/-[1-9][0-9]*$')" -gt 0 ]; then
|
case "${LTS}" in
|
||||||
|
lts/-[123456789] | lts/-[123456789][0123456789]*)
|
||||||
local N
|
local N
|
||||||
N="$(echo "${LTS}" | cut -d '-' -f 2)"
|
N="$(echo "${LTS}" | cut -d '-' -f 2)"
|
||||||
N=$((N+1))
|
N=$((N+1))
|
||||||
|
# shellcheck disable=SC2181
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
nvm_echo "${LTS}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
local NVM_ALIAS_DIR
|
local NVM_ALIAS_DIR
|
||||||
NVM_ALIAS_DIR="$(nvm_alias_path)"
|
NVM_ALIAS_DIR="$(nvm_alias_path)"
|
||||||
local RESULT
|
local RESULT
|
||||||
@@ -745,9 +776,11 @@ nvm_normalize_lts() {
|
|||||||
nvm_err 'That many LTS releases do not exist yet.'
|
nvm_err 'That many LTS releases do not exist yet.'
|
||||||
return 2
|
return 2
|
||||||
fi
|
fi
|
||||||
else
|
;;
|
||||||
|
*)
|
||||||
nvm_echo "${LTS}"
|
nvm_echo "${LTS}"
|
||||||
fi
|
;;
|
||||||
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
nvm_ensure_version_prefix() {
|
nvm_ensure_version_prefix() {
|
||||||
@@ -798,7 +831,8 @@ nvm_strip_path() {
|
|||||||
path = substr($0, length(NVM_DIR) + 1)
|
path = substr($0, length(NVM_DIR) + 1)
|
||||||
if (path ~ "^(/versions/[^/]*)?/[^/]*'"${2-}"'.*$") { next }
|
if (path ~ "^(/versions/[^/]*)?/[^/]*'"${2-}"'.*$") { next }
|
||||||
}
|
}
|
||||||
{ print }' | command paste -s -d: -
|
# The final RT will contain a colon if the input has a trailing colon, or a null string otherwise
|
||||||
|
{ printf "%s%s", sep, $0; sep=RS } END { printf "%s", RT }'
|
||||||
}
|
}
|
||||||
|
|
||||||
nvm_change_path() {
|
nvm_change_path() {
|
||||||
@@ -1064,11 +1098,11 @@ nvm_list_aliases() {
|
|||||||
NVM_NO_COLORS="${NVM_NO_COLORS-}" NVM_CURRENT="${NVM_CURRENT}" nvm_print_alias_path "${NVM_ALIAS_DIR}" "${ALIAS_PATH}" &
|
NVM_NO_COLORS="${NVM_NO_COLORS-}" NVM_CURRENT="${NVM_CURRENT}" nvm_print_alias_path "${NVM_ALIAS_DIR}" "${ALIAS_PATH}" &
|
||||||
done
|
done
|
||||||
wait
|
wait
|
||||||
) | sort
|
) | command sort
|
||||||
|
|
||||||
(
|
(
|
||||||
local ALIAS_NAME
|
local ALIAS_NAME
|
||||||
for ALIAS_NAME in "$(nvm_node_prefix)" "stable" "unstable"; do
|
for ALIAS_NAME in "$(nvm_node_prefix)" "stable" "unstable" "$(nvm_iojs_prefix)"; do
|
||||||
{
|
{
|
||||||
# shellcheck disable=SC2030,SC2031 # (https://github.com/koalaman/shellcheck/issues/2217)
|
# shellcheck disable=SC2030,SC2031 # (https://github.com/koalaman/shellcheck/issues/2217)
|
||||||
if [ ! -f "${NVM_ALIAS_DIR}/${ALIAS_NAME}" ] && { [ -z "${ALIAS}" ] || [ "${ALIAS_NAME}" = "${ALIAS}" ]; }; then
|
if [ ! -f "${NVM_ALIAS_DIR}/${ALIAS_NAME}" ] && { [ -z "${ALIAS}" ] || [ "${ALIAS_NAME}" = "${ALIAS}" ]; }; then
|
||||||
@@ -1077,12 +1111,7 @@ nvm_list_aliases() {
|
|||||||
} &
|
} &
|
||||||
done
|
done
|
||||||
wait
|
wait
|
||||||
ALIAS_NAME="$(nvm_iojs_prefix)"
|
) | command sort
|
||||||
# shellcheck disable=SC2030,SC2031 # (https://github.com/koalaman/shellcheck/issues/2217)
|
|
||||||
if [ ! -f "${NVM_ALIAS_DIR}/${ALIAS_NAME}" ] && { [ -z "${ALIAS}" ] || [ "${ALIAS_NAME}" = "${ALIAS}" ]; }; then
|
|
||||||
NVM_NO_COLORS="${NVM_NO_COLORS-}" NVM_CURRENT="${NVM_CURRENT}" nvm_print_default_alias "${ALIAS_NAME}"
|
|
||||||
fi
|
|
||||||
) | sort
|
|
||||||
|
|
||||||
(
|
(
|
||||||
local LTS_ALIAS
|
local LTS_ALIAS
|
||||||
@@ -1096,7 +1125,7 @@ nvm_list_aliases() {
|
|||||||
} &
|
} &
|
||||||
done
|
done
|
||||||
wait
|
wait
|
||||||
) | sort
|
) | command sort
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1120,7 +1149,7 @@ nvm_alias() {
|
|||||||
return 2
|
return 2
|
||||||
fi
|
fi
|
||||||
|
|
||||||
command cat "${NVM_ALIAS_PATH}"
|
command awk 'NF' "${NVM_ALIAS_PATH}"
|
||||||
}
|
}
|
||||||
|
|
||||||
nvm_ls_current() {
|
nvm_ls_current() {
|
||||||
@@ -1135,7 +1164,7 @@ nvm_ls_current() {
|
|||||||
if [ "${VERSION}" = "v0.6.21-pre" ]; then
|
if [ "${VERSION}" = "v0.6.21-pre" ]; then
|
||||||
nvm_echo 'v0.6.21'
|
nvm_echo 'v0.6.21'
|
||||||
else
|
else
|
||||||
nvm_echo "${VERSION}"
|
nvm_echo "${VERSION:-none}"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
nvm_echo 'system'
|
nvm_echo 'system'
|
||||||
@@ -1156,8 +1185,10 @@ nvm_resolve_alias() {
|
|||||||
|
|
||||||
local SEEN_ALIASES
|
local SEEN_ALIASES
|
||||||
SEEN_ALIASES="${ALIAS}"
|
SEEN_ALIASES="${ALIAS}"
|
||||||
|
local NVM_ALIAS_INDEX
|
||||||
|
NVM_ALIAS_INDEX=1
|
||||||
while true; do
|
while true; do
|
||||||
ALIAS_TEMP="$(nvm_alias "${ALIAS}" 2>/dev/null || nvm_echo)"
|
ALIAS_TEMP="$( (nvm_alias "${ALIAS}" 2>/dev/null | command head -n "${NVM_ALIAS_INDEX}" | command tail -n 1) || nvm_echo)"
|
||||||
|
|
||||||
if [ -z "${ALIAS_TEMP}" ]; then
|
if [ -z "${ALIAS_TEMP}" ]; then
|
||||||
break
|
break
|
||||||
@@ -1376,9 +1407,10 @@ nvm_ls() {
|
|||||||
|
|
||||||
if [ "${NVM_ADD_SYSTEM-}" = true ]; then
|
if [ "${NVM_ADD_SYSTEM-}" = true ]; then
|
||||||
if [ -z "${PATTERN}" ] || [ "${PATTERN}" = 'v' ]; then
|
if [ -z "${PATTERN}" ] || [ "${PATTERN}" = 'v' ]; then
|
||||||
VERSIONS="${VERSIONS}$(command printf '\n%s' 'system')"
|
VERSIONS="${VERSIONS}
|
||||||
|
system"
|
||||||
elif [ "${PATTERN}" = 'system' ]; then
|
elif [ "${PATTERN}" = 'system' ]; then
|
||||||
VERSIONS="$(command printf '%s' 'system')"
|
VERSIONS="system"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -1642,7 +1674,7 @@ nvm_compare_checksum() {
|
|||||||
nvm_err "Computed checksum of '${FILE}' is empty." # missing in raspberry pi binary
|
nvm_err "Computed checksum of '${FILE}' is empty." # missing in raspberry pi binary
|
||||||
nvm_err 'WARNING: Continuing *without checksum verification*'
|
nvm_err 'WARNING: Continuing *without checksum verification*'
|
||||||
return
|
return
|
||||||
elif [ "${COMPUTED_SUM}" != "${CHECKSUM}" ]; then
|
elif [ "${COMPUTED_SUM}" != "${CHECKSUM}" ] && [ "${COMPUTED_SUM}" != "\\${CHECKSUM}" ]; then
|
||||||
nvm_err "Checksums do not match: '${COMPUTED_SUM}' found, '${CHECKSUM}' expected."
|
nvm_err "Checksums do not match: '${COMPUTED_SUM}' found, '${CHECKSUM}' expected."
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -1889,6 +1921,7 @@ nvm_get_arch() {
|
|||||||
local HOST_ARCH
|
local HOST_ARCH
|
||||||
local NVM_OS
|
local NVM_OS
|
||||||
local EXIT_CODE
|
local EXIT_CODE
|
||||||
|
local LONG_BIT
|
||||||
|
|
||||||
NVM_OS="$(nvm_get_os)"
|
NVM_OS="$(nvm_get_os)"
|
||||||
# If the OS is SunOS, first try to use pkgsrc to guess
|
# If the OS is SunOS, first try to use pkgsrc to guess
|
||||||
@@ -1905,26 +1938,37 @@ nvm_get_arch() {
|
|||||||
HOST_ARCH=ppc64
|
HOST_ARCH=ppc64
|
||||||
else
|
else
|
||||||
HOST_ARCH="$(command uname -m)"
|
HOST_ARCH="$(command uname -m)"
|
||||||
|
LONG_BIT="$(getconf LONG_BIT 2>/dev/null)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
local NVM_ARCH
|
local NVM_ARCH
|
||||||
case "${HOST_ARCH}" in
|
case "${HOST_ARCH}" in
|
||||||
x86_64 | amd64) NVM_ARCH="x64" ;;
|
x86_64 | amd64) NVM_ARCH="x64" ;;
|
||||||
i*86) NVM_ARCH="x86" ;;
|
i*86) NVM_ARCH="x86" ;;
|
||||||
aarch64) NVM_ARCH="arm64" ;;
|
aarch64 | armv8l) NVM_ARCH="arm64" ;;
|
||||||
*) NVM_ARCH="${HOST_ARCH}" ;;
|
*) NVM_ARCH="${HOST_ARCH}" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
# If running inside a 32Bit docker container the kernel still is 64bit
|
||||||
|
# change ARCH to 32bit if LONG_BIT is 32
|
||||||
|
if [ "_${LONG_BIT}" = "_32" ] && [ "${NVM_ARCH}" = "x64" ]; then
|
||||||
|
NVM_ARCH="x86"
|
||||||
|
fi
|
||||||
|
|
||||||
# If running a 64bit ARM kernel but a 32bit ARM userland,
|
# If running a 64bit ARM kernel but a 32bit ARM userland,
|
||||||
# change ARCH to 32bit ARM (armv7l) if /sbin/init is 32bit executable
|
# change ARCH to 32bit ARM (armv7l) if /sbin/init is 32bit executable
|
||||||
local L
|
if [ "$(uname)" = "Linux" ] \
|
||||||
if [ "$(uname)" = "Linux" ] && [ "${NVM_ARCH}" = arm64 ] &&
|
&& [ "${NVM_ARCH}" = arm64 ] \
|
||||||
L="$(command ls -dl /sbin/init 2>/dev/null)" &&
|
&& [ "$(command od -An -t x1 -j 4 -N 1 "/sbin/init" 2>/dev/null)" = ' 01' ]\
|
||||||
[ "$(od -An -t x1 -j 4 -N 1 "${L#*-> }")" = ' 01' ]; then
|
; then
|
||||||
NVM_ARCH=armv7l
|
NVM_ARCH=armv7l
|
||||||
HOST_ARCH=armv7l
|
HOST_ARCH=armv7l
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -f "/etc/alpine-release" ]; then
|
||||||
|
NVM_ARCH=x64-musl
|
||||||
|
fi
|
||||||
|
|
||||||
nvm_echo "${NVM_ARCH}"
|
nvm_echo "${NVM_ARCH}"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1979,14 +2023,25 @@ nvm_is_merged_node_version() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
nvm_get_mirror() {
|
nvm_get_mirror() {
|
||||||
|
local NVM_MIRROR
|
||||||
|
NVM_MIRROR=''
|
||||||
case "${1}-${2}" in
|
case "${1}-${2}" in
|
||||||
node-std) nvm_echo "${NVM_NODEJS_ORG_MIRROR:-https://nodejs.org/dist}" ;;
|
node-std) NVM_MIRROR="${NVM_NODEJS_ORG_MIRROR:-https://nodejs.org/dist}" ;;
|
||||||
iojs-std) nvm_echo "${NVM_IOJS_ORG_MIRROR:-https://iojs.org/dist}" ;;
|
iojs-std) NVM_MIRROR="${NVM_IOJS_ORG_MIRROR:-https://iojs.org/dist}" ;;
|
||||||
*)
|
*)
|
||||||
nvm_err 'unknown type of node.js or io.js release'
|
nvm_err 'unknown type of node.js or io.js release'
|
||||||
return 1
|
return 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
case "${NVM_MIRROR}" in
|
||||||
|
*\`* | *\\* | *\'* | *\(* )
|
||||||
|
nvm_err '$NVM_NODEJS_ORG_MIRROR and $NVM_IOJS_ORG_MIRROR may only contain a URL'
|
||||||
|
return 2
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
nvm_echo "${NVM_MIRROR}"
|
||||||
}
|
}
|
||||||
|
|
||||||
# args: os, prefixed version, version, tarball, extract directory
|
# args: os, prefixed version, version, tarball, extract directory
|
||||||
@@ -2754,7 +2809,7 @@ nvm_check_file_permissions() {
|
|||||||
if [ -n "${NVM_DEBUG-}" ]; then
|
if [ -n "${NVM_DEBUG-}" ]; then
|
||||||
nvm_err "${FILE}"
|
nvm_err "${FILE}"
|
||||||
fi
|
fi
|
||||||
if ! nvm_check_file_permissions "${FILE}"; then
|
if [ ! -L "${FILE}" ] && ! nvm_check_file_permissions "${FILE}"; then
|
||||||
return 2
|
return 2
|
||||||
fi
|
fi
|
||||||
elif [ -e "$FILE" ] && [ ! -w "$FILE" ] && [ ! -O "$FILE" ]; then
|
elif [ -e "$FILE" ] && [ ! -w "$FILE" ] && [ ! -O "$FILE" ]; then
|
||||||
@@ -4165,7 +4220,7 @@ nvm() {
|
|||||||
NVM_VERSION_ONLY=true NVM_LTS="${NVM_LTS-}" nvm_remote_version "${PATTERN:-node}"
|
NVM_VERSION_ONLY=true NVM_LTS="${NVM_LTS-}" nvm_remote_version "${PATTERN:-node}"
|
||||||
;;
|
;;
|
||||||
"--version" | "-v")
|
"--version" | "-v")
|
||||||
nvm_echo '0.39.3'
|
nvm_echo '0.39.5'
|
||||||
;;
|
;;
|
||||||
"unload")
|
"unload")
|
||||||
nvm deactivate >/dev/null 2>&1
|
nvm deactivate >/dev/null 2>&1
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "nvm",
|
"name": "nvm",
|
||||||
"version": "0.39.3",
|
"version": "0.39.5",
|
||||||
"description": "Node Version Manager - Simple bash script to manage multiple active node.js versions",
|
"description": "Node Version Manager - Simple bash script to manage multiple active node.js versions",
|
||||||
"directories": {
|
"directories": {
|
||||||
"test": "test"
|
"test": "test"
|
||||||
@@ -43,9 +43,9 @@
|
|||||||
"dockerfile_lint": "^0.3.4",
|
"dockerfile_lint": "^0.3.4",
|
||||||
"doctoc": "^2.2.1",
|
"doctoc": "^2.2.1",
|
||||||
"eclint": "^2.8.1",
|
"eclint": "^2.8.1",
|
||||||
"markdown-link-check": "^3.10.3",
|
"markdown-link-check": "^3.11.2",
|
||||||
"replace": "^1.2.2",
|
"replace": "^1.2.2",
|
||||||
"semver": "^7.3.8",
|
"semver": "^7.5.4",
|
||||||
"urchin": "^0.0.5"
|
"urchin": "^0.0.5"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
20
test/fast/Aliases/'nvm alias' should ignore leading blank lines in the file
Executable file
20
test/fast/Aliases/'nvm alias' should ignore leading blank lines in the file
Executable file
@@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
die() { echo "$@" ; exit 1; }
|
||||||
|
|
||||||
|
export NVM_DIR="$(cd ../../.. && pwd)"
|
||||||
|
|
||||||
|
\. "${NVM_DIR}/nvm.sh"
|
||||||
|
\. ../../common.sh
|
||||||
|
|
||||||
|
echo "
|
||||||
|
|
||||||
|
v0.0.1
|
||||||
|
" > ../../../alias/test-blank-lines
|
||||||
|
|
||||||
|
EXPECTED='v0.0.1'
|
||||||
|
ACTUAL="$(nvm_alias test-blank-lines)"
|
||||||
|
EXIT_CODE="$(nvm_alias test-blank-lines 2>&1 >/dev/null; echo $?)"
|
||||||
|
|
||||||
|
[ "${ACTUAL}" = "${EXPECTED}" ] || die "expected >${EXPECTED}<, got >${ACTUAL}<"
|
||||||
|
[ "${EXIT_CODE}" = '0' ] || die "expected exit code 0, got ${EXIT_CODE}"
|
||||||
@@ -2,7 +2,9 @@
|
|||||||
|
|
||||||
die () { echo "$@" ; exit 1; }
|
die () { echo "$@" ; exit 1; }
|
||||||
|
|
||||||
\. ../../../nvm.sh
|
export NVM_DIR="$(cd ../../.. && pwd)"
|
||||||
|
|
||||||
|
\. "${NVM_DIR}/nvm.sh"
|
||||||
|
|
||||||
EXIT_CODE=$(nvm_resolve_alias ; echo $?)
|
EXIT_CODE=$(nvm_resolve_alias ; echo $?)
|
||||||
[ $EXIT_CODE = "1" ] || die "nvm_resolve_alias without an argument did not return 1; got $EXIT_CODE"
|
[ $EXIT_CODE = "1" ] || die "nvm_resolve_alias without an argument did not return 1; got $EXIT_CODE"
|
||||||
@@ -31,3 +33,17 @@ UNSTABLE="$(nvm_resolve_alias unstable)"
|
|||||||
|
|
||||||
IOJS="$(nvm_resolve_alias iojs)"
|
IOJS="$(nvm_resolve_alias iojs)"
|
||||||
[ "_$IOJS" = "_iojs-v0.2" ] || die "'nvm_resolve_alias iojs' was not iojs-v0.2; got $IOJS"
|
[ "_$IOJS" = "_iojs-v0.2" ] || die "'nvm_resolve_alias iojs' was not iojs-v0.2; got $IOJS"
|
||||||
|
|
||||||
|
echo "
|
||||||
|
|
||||||
|
v0.0.1
|
||||||
|
v0.0.2
|
||||||
|
v0.0.3
|
||||||
|
" > ../../../alias/test-multi-lines
|
||||||
|
|
||||||
|
EXPECTED='v0.0.1'
|
||||||
|
ACTUAL="$(nvm_resolve_alias test-multi-lines)"
|
||||||
|
EXIT_CODE="$(nvm_resolve_alias test-multi-lines 2>&1 >/dev/null; echo $?)"
|
||||||
|
|
||||||
|
[ "${ACTUAL}" = "${EXPECTED}" ] || die "expected >${EXPECTED}<, got >${ACTUAL}<"
|
||||||
|
[ "${EXIT_CODE}" = '0' ] || die "expected exit code 0, got ${EXIT_CODE}"
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
|
export NVM_DIR="$(cd ../../.. && pwd)"
|
||||||
|
|
||||||
\. ../../../nvm.sh
|
\. ../../../nvm.sh
|
||||||
\. ../../common.sh
|
\. ../../common.sh
|
||||||
|
|
||||||
|
|||||||
@@ -15,3 +15,5 @@ rm -f "../../../alias/unstable"
|
|||||||
rm -f "../../../alias/node"
|
rm -f "../../../alias/node"
|
||||||
rm -f "../../../alias/iojs"
|
rm -f "../../../alias/iojs"
|
||||||
rm -f "../../../alias/default"
|
rm -f "../../../alias/default"
|
||||||
|
rm -f "../../../alias/test-blank-lines"
|
||||||
|
rm -f "../../../alias/test-multi-lines"
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/zsh
|
#!/bin/zsh
|
||||||
|
|
||||||
|
export NVM_DIR="$(cd ../../.. && pwd)"
|
||||||
|
|
||||||
\. ../../../nvm.sh
|
\. ../../../nvm.sh
|
||||||
\. ../../common.sh
|
\. ../../common.sh
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,8 @@
|
|||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
|
export NVM_DIR="$(cd ../.. && pwd)"
|
||||||
|
|
||||||
\. ../../nvm.sh
|
\. ../../nvm.sh
|
||||||
|
|
||||||
nvm alias test v0.1.2
|
nvm alias test v0.1.2
|
||||||
|
|||||||
@@ -4,6 +4,8 @@ set -ex
|
|||||||
|
|
||||||
die () { echo "$@" ; exit 1; }
|
die () { echo "$@" ; exit 1; }
|
||||||
|
|
||||||
|
export NVM_DIR="$(cd ../.. && pwd)"
|
||||||
|
|
||||||
\. ../../nvm.sh
|
\. ../../nvm.sh
|
||||||
|
|
||||||
nvm deactivate 2>&1
|
nvm deactivate 2>&1
|
||||||
|
|||||||
@@ -4,6 +4,8 @@ set -ex
|
|||||||
|
|
||||||
die () { echo "$@" ; exit 1; }
|
die () { echo "$@" ; exit 1; }
|
||||||
|
|
||||||
|
export NVM_DIR="$(cd ../.. && pwd)"
|
||||||
|
|
||||||
\. ../../nvm.sh
|
\. ../../nvm.sh
|
||||||
\. ../common.sh
|
\. ../common.sh
|
||||||
|
|
||||||
|
|||||||
@@ -7,6 +7,8 @@ cleanup () {
|
|||||||
rm -rf "${NVM_DIR}/v0.10.4"
|
rm -rf "${NVM_DIR}/v0.10.4"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export NVM_DIR="$(cd ../.. && pwd)"
|
||||||
|
|
||||||
\. ../../nvm.sh
|
\. ../../nvm.sh
|
||||||
\. ../common.sh
|
\. ../common.sh
|
||||||
|
|
||||||
|
|||||||
@@ -4,6 +4,8 @@ set -ex
|
|||||||
|
|
||||||
die () { echo "$@" ; exit 1; }
|
die () { echo "$@" ; exit 1; }
|
||||||
|
|
||||||
|
export NVM_DIR="$(cd ../.. && pwd)"
|
||||||
|
|
||||||
\. ../../nvm.sh
|
\. ../../nvm.sh
|
||||||
|
|
||||||
set +ex # needed for stderr
|
set +ex # needed for stderr
|
||||||
|
|||||||
@@ -24,6 +24,7 @@ env | grep -v PATH= | grep -v IFS= | sort >> "${AFTER}"
|
|||||||
|
|
||||||
! type nvm > /dev/null 2>&1 || die "nvm not unloaded"
|
! type nvm > /dev/null 2>&1 || die "nvm not unloaded"
|
||||||
|
|
||||||
|
diff "${BEFORE}" "${AFTER}"
|
||||||
DIFF="$(diff "${BEFORE}" "${AFTER}" ||:)"
|
DIFF="$(diff "${BEFORE}" "${AFTER}" ||:)"
|
||||||
[ -z "${DIFF}" ] || die "function pollution found: ${DIFF}"
|
[ -z "${DIFF}" ] || die "function pollution found: ${DIFF}"
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
iron
|
||||||
hydrogen
|
hydrogen
|
||||||
gallium
|
gallium
|
||||||
fermium
|
fermium
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
lts/hydrogen
|
lts/iron
|
||||||
|
|||||||
@@ -1,9 +1,45 @@
|
|||||||
version date files npm v8 uv zlib openssl modules lts security
|
version date files npm v8 uv zlib openssl modules lts security
|
||||||
|
v21.1.0 2023-10-24 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 10.2.0 11.8.172.15 1.46.0 1.2.13.1-motley 3.0.10+quic 120 - -
|
||||||
|
v21.0.0 2023-10-17 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 10.2.0 11.8.172.13 1.46.0 1.2.13.1-motley 3.0.10+quic 120 - -
|
||||||
|
v20.9.0 2023-10-24 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 10.1.0 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.10+quic 115 Iron -
|
||||||
|
v20.8.1 2023-10-13 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 10.1.0 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.10+quic 115 - true
|
||||||
|
v20.8.0 2023-09-28 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 10.1.0 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.10+quic 115 - -
|
||||||
|
v20.7.0 2023-09-18 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 10.1.0 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.10+quic 115 - -
|
||||||
|
v20.6.1 2023-09-07 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.8.1 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.10+quic 115 - -
|
||||||
|
v20.6.0 2023-08-23 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.8.1 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.10+quic 115 - -
|
||||||
|
v20.5.1 2023-08-09 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.8.0 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.10+quic 115 - true
|
||||||
|
v20.5.0 2023-07-19 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.8.0 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.9+quic 115 - -
|
||||||
|
v20.4.0 2023-07-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.7.2 11.3.244.8 1.46.0 1.2.13.1-motley 3.0.9+quic 115 - -
|
||||||
|
v20.3.1 2023-06-20 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.6.7 11.3.244.8 1.45.0 1.2.13.1-motley 3.0.9+quic 115 - true
|
||||||
|
v20.3.0 2023-06-08 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.6.7 11.3.244.8 1.45.0 1.2.13.1-motley 3.0.8+quic 115 - -
|
||||||
|
v20.2.0 2023-05-16 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.6.6 11.3.244.8 1.44.2 1.2.13 3.0.8+quic 115 - -
|
||||||
|
v20.1.0 2023-05-03 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.6.4 11.3.244.8 1.44.2 1.2.13 3.0.8+quic 115 - -
|
||||||
|
v20.0.0 2023-04-17 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.6.4 11.3.244.4 1.44.2 1.2.13 3.0.8+quic 115 - -
|
||||||
|
v19.9.0 2023-04-10 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-arm64-7z,win-arm64-zip,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.6.3 10.8.168.25 1.44.2 1.2.13 3.0.8+quic 111 - -
|
||||||
|
v19.8.1 2023-03-15 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.5.1 10.8.168.25 1.44.2 1.2.13 3.0.8+quic 111 - -
|
||||||
|
v19.8.0 2023-03-14 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.5.1 10.8.168.25 1.44.2 1.2.13 3.0.8+quic 111 - -
|
||||||
|
v19.7.0 2023-02-21 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.5.0 10.8.168.25 1.44.2 1.2.13 3.0.8+quic 111 - -
|
||||||
|
v19.6.1 2023-02-16 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.4.0 10.8.168.25 1.44.2 1.2.13 3.0.8+quic 111 - true
|
||||||
|
v19.6.0 2023-02-01 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.4.0 10.8.168.25 1.44.2 1.2.13 3.0.7+quic 111 - -
|
||||||
|
v19.5.0 2023-01-24 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.3.1 10.8.168.25 1.44.2 1.2.13 3.0.7+quic 111 - -
|
||||||
|
v19.4.0 2023-01-05 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.2.0 10.8.168.25 1.44.2 1.2.13 3.0.7+quic 111 - -
|
||||||
v19.3.0 2022-12-14 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.2.0 10.8.168.21 1.44.2 1.2.13 3.0.7+quic 111 - -
|
v19.3.0 2022-12-14 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.2.0 10.8.168.21 1.44.2 1.2.13 3.0.7+quic 111 - -
|
||||||
v19.2.0 2022-11-29 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.3 10.8.168.20 1.44.2 1.2.13 3.0.7+quic 111 - -
|
v19.2.0 2022-11-29 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.3 10.8.168.20 1.44.2 1.2.13 3.0.7+quic 111 - -
|
||||||
v19.1.0 2022-11-14 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.3 10.7.193.20 1.44.2 1.2.11 3.0.7+quic 111 - -
|
v19.1.0 2022-11-14 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.3 10.7.193.20 1.44.2 1.2.11 3.0.7+quic 111 - -
|
||||||
v19.0.1 2022-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.7.193.13 1.43.0 1.2.11 3.0.7+quic 111 - true
|
v19.0.1 2022-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.7.193.13 1.43.0 1.2.11 3.0.7+quic 111 - true
|
||||||
v19.0.0 2022-10-17 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.7.193.13 1.43.0 1.2.11 3.0.5+quic 111 - -
|
v19.0.0 2022-10-17 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.7.193.13 1.43.0 1.2.11 3.0.5+quic 111 - -
|
||||||
|
v18.18.2 2023-10-13 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.8.1 10.2.154.26 1.44.2 1.2.13.1-motley 3.0.10+quic 108 Hydrogen true
|
||||||
|
v18.18.1 2023-10-10 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.8.1 10.2.154.26 1.44.2 1.2.13.1-motley 3.0.10+quic 108 Hydrogen -
|
||||||
|
v18.18.0 2023-09-18 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.8.1 10.2.154.26 1.46.0 1.2.13.1-motley 3.0.10+quic 108 Hydrogen -
|
||||||
|
v18.17.1 2023-08-08 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.6.7 10.2.154.26 1.44.2 1.2.13.1-motley 3.0.10+quic 108 Hydrogen -
|
||||||
|
v18.17.0 2023-07-18 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.6.7 10.2.154.26 1.44.2 1.2.13.1-motley 3.0.9+quic 108 Hydrogen -
|
||||||
|
v18.16.1 2023-06-20 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.5.1 10.2.154.26 1.44.2 1.2.13 3.0.9+quic 108 Hydrogen true
|
||||||
|
v18.16.0 2023-04-12 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.5.1 10.2.154.26 1.44.2 1.2.13 3.0.8+quic 108 Hydrogen -
|
||||||
|
v18.15.0 2023-03-05 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.5.0 10.2.154.26 1.44.2 1.2.13 3.0.8+quic 108 Hydrogen -
|
||||||
|
v18.14.2 2023-02-21 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.5.0 10.2.154.26 1.44.2 1.2.13 3.0.8+quic 108 Hydrogen -
|
||||||
|
v18.14.1 2023-02-16 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.3.1 10.2.154.23 1.44.2 1.2.13 3.0.8+quic 108 Hydrogen true
|
||||||
|
v18.14.0 2023-02-01 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 9.3.1 10.2.154.23 1.44.2 1.2.13 3.0.7+quic 108 Hydrogen -
|
||||||
|
v18.13.0 2023-01-05 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.3 10.2.154.23 1.44.2 1.2.13 3.0.7+quic 108 Hydrogen -
|
||||||
v18.12.1 2022-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.2.154.15 1.43.0 1.2.11 3.0.7+quic 108 Hydrogen true
|
v18.12.1 2022-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.2.154.15 1.43.0 1.2.11 3.0.7+quic 108 Hydrogen true
|
||||||
v18.12.0 2022-10-25 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.2.154.15 1.43.0 1.2.11 3.0.5+quic 108 Hydrogen -
|
v18.12.0 2022-10-25 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.2.154.15 1.43.0 1.2.11 3.0.5+quic 108 Hydrogen -
|
||||||
v18.11.0 2022-10-13 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.2.154.15 1.43.0 1.2.11 3.0.5+quic 108 - -
|
v18.11.0 2022-10-13 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 10.2.154.15 1.43.0 1.2.11 3.0.5+quic 108 - -
|
||||||
@@ -34,6 +70,10 @@ v17.2.0 2021-11-30 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linu
|
|||||||
v17.1.0 2021-11-09 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.1.2 9.5.172.25 1.42.0 1.2.11 3.0.0+quic 102 - -
|
v17.1.0 2021-11-09 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.1.2 9.5.172.25 1.42.0 1.2.11 3.0.0+quic 102 - -
|
||||||
v17.0.1 2021-10-20 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.1.0 9.5.172.21 1.42.0 1.2.11 3.0.0+quic 102 - -
|
v17.0.1 2021-10-20 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.1.0 9.5.172.21 1.42.0 1.2.11 3.0.0+quic 102 - -
|
||||||
v17.0.0 2021-10-19 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.1.0 9.5.172.21 1.42.0 1.2.11 3.0.0+quic 102 - -
|
v17.0.0 2021-10-19 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.1.0 9.5.172.21 1.42.0 1.2.11 3.0.0+quic 102 - -
|
||||||
|
v16.20.2 2023-08-08 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.4 9.4.146.26 1.43.0 1.2.11 1.1.1v+quic 93 Gallium true
|
||||||
|
v16.20.1 2023-06-20 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.4 9.4.146.26 1.43.0 1.2.11 1.1.1u+quic 93 Gallium true
|
||||||
|
v16.20.0 2023-03-28 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.4 9.4.146.26 1.43.0 1.2.11 1.1.1t+quic 93 Gallium -
|
||||||
|
v16.19.1 2023-02-16 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.3 9.4.146.26 1.43.0 1.2.11 1.1.1t+quic 93 Gallium true
|
||||||
v16.19.0 2022-12-13 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.3 9.4.146.26 1.43.0 1.2.11 1.1.1s+quic 93 Gallium -
|
v16.19.0 2022-12-13 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.3 9.4.146.26 1.43.0 1.2.11 1.1.1s+quic 93 Gallium -
|
||||||
v16.18.1 2022-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 9.4.146.26 1.43.0 1.2.11 1.1.1q+quic 93 Gallium true
|
v16.18.1 2022-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 9.4.146.26 1.43.0 1.2.11 1.1.1q+quic 93 Gallium true
|
||||||
v16.18.0 2022-10-12 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 9.4.146.26 1.43.0 1.2.11 1.1.1q+quic 93 Gallium -
|
v16.18.0 2022-10-12 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-arm64-tar,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 8.19.2 9.4.146.26 1.43.0 1.2.11 1.1.1q+quic 93 Gallium -
|
||||||
@@ -85,6 +125,7 @@ v15.2.0 2020-11-10 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linu
|
|||||||
v15.1.0 2020-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 7.0.8 8.6.395.17 1.40.0 1.2.11 1.1.1g 88 - -
|
v15.1.0 2020-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 7.0.8 8.6.395.17 1.40.0 1.2.11 1.1.1g 88 - -
|
||||||
v15.0.1 2020-10-21 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 7.0.3 8.6.395.17 1.40.0 1.2.11 1.1.1g 88 - -
|
v15.0.1 2020-10-21 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 7.0.3 8.6.395.17 1.40.0 1.2.11 1.1.1g 88 - -
|
||||||
v15.0.0 2020-10-20 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 7.0.2 8.6.395.16 1.40.0 1.2.11 1.1.1g 88 - -
|
v15.0.0 2020-10-20 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 7.0.2 8.6.395.16 1.40.0 1.2.11 1.1.1g 88 - -
|
||||||
|
v14.21.3 2023-02-16 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 6.14.18 8.4.371.23 1.42.0 1.2.11 1.1.1t 83 Fermium true
|
||||||
v14.21.2 2022-12-13 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 6.14.17 8.4.371.23 1.42.0 1.2.11 1.1.1s 83 Fermium -
|
v14.21.2 2022-12-13 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 6.14.17 8.4.371.23 1.42.0 1.2.11 1.1.1s 83 Fermium -
|
||||||
v14.21.1 2022-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 6.14.17 8.4.371.23 1.42.0 1.2.11 1.1.1q 83 Fermium true
|
v14.21.1 2022-11-04 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 6.14.17 8.4.371.23 1.42.0 1.2.11 1.1.1q 83 Fermium true
|
||||||
v14.21.0 2022-11-01 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 6.14.17 8.4.371.23 1.42.0 1.2.11 1.1.1q 83 Fermium -
|
v14.21.0 2022-11-01 aix-ppc64,headers,linux-arm64,linux-armv7l,linux-ppc64le,linux-s390x,linux-x64,osx-x64-pkg,osx-x64-tar,src,win-x64-7z,win-x64-exe,win-x64-msi,win-x64-zip,win-x86-7z,win-x86-exe,win-x86-msi,win-x86-zip 6.14.17 8.4.371.23 1.42.0 1.2.11 1.1.1q 83 Fermium -
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -175,7 +175,8 @@
|
|||||||
v14.20.1 [0;37m (LTS: Fermium)[0m
|
v14.20.1 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.0 [0;37m (LTS: Fermium)[0m
|
v14.21.0 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.1 [0;37m (LTS: Fermium)[0m
|
v14.21.1 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.2 [1;32m (Latest LTS: Fermium)[0m
|
v14.21.2 [0;37m (LTS: Fermium)[0m
|
||||||
|
v14.21.3 [1;32m (Latest LTS: Fermium)[0m
|
||||||
v16.13.0 [0;37m (LTS: Gallium)[0m
|
v16.13.0 [0;37m (LTS: Gallium)[0m
|
||||||
v16.13.1 [0;37m (LTS: Gallium)[0m
|
v16.13.1 [0;37m (LTS: Gallium)[0m
|
||||||
v16.13.2 [0;37m (LTS: Gallium)[0m
|
v16.13.2 [0;37m (LTS: Gallium)[0m
|
||||||
@@ -189,6 +190,23 @@
|
|||||||
v16.17.1 [0;37m (LTS: Gallium)[0m
|
v16.17.1 [0;37m (LTS: Gallium)[0m
|
||||||
v16.18.0 [0;37m (LTS: Gallium)[0m
|
v16.18.0 [0;37m (LTS: Gallium)[0m
|
||||||
v16.18.1 [0;37m (LTS: Gallium)[0m
|
v16.18.1 [0;37m (LTS: Gallium)[0m
|
||||||
v16.19.0 [1;32m (Latest LTS: Gallium)[0m
|
v16.19.0 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.19.1 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.0 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.1 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.2 [1;32m (Latest LTS: Gallium)[0m
|
||||||
v18.12.0 [0;37m (LTS: Hydrogen)[0m
|
v18.12.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
v18.12.1 [1;32m (Latest LTS: Hydrogen)[0m
|
v18.12.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.13.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.2 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.15.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.16.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.16.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.17.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.17.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.2 [1;32m (Latest LTS: Hydrogen)[0m
|
||||||
|
v20.9.0 [1;32m (Latest LTS: Iron)[0m
|
||||||
|
|||||||
@@ -581,7 +581,8 @@
|
|||||||
v14.20.1 [0;37m (LTS: Fermium)[0m
|
v14.20.1 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.0 [0;37m (LTS: Fermium)[0m
|
v14.21.0 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.1 [0;37m (LTS: Fermium)[0m
|
v14.21.1 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.2 [1;32m (Latest LTS: Fermium)[0m
|
v14.21.2 [0;37m (LTS: Fermium)[0m
|
||||||
|
v14.21.3 [1;32m (Latest LTS: Fermium)[0m
|
||||||
v15.0.0
|
v15.0.0
|
||||||
v15.0.1
|
v15.0.1
|
||||||
v15.1.0
|
v15.1.0
|
||||||
@@ -632,7 +633,11 @@
|
|||||||
v16.17.1 [0;37m (LTS: Gallium)[0m
|
v16.17.1 [0;37m (LTS: Gallium)[0m
|
||||||
v16.18.0 [0;37m (LTS: Gallium)[0m
|
v16.18.0 [0;37m (LTS: Gallium)[0m
|
||||||
v16.18.1 [0;37m (LTS: Gallium)[0m
|
v16.18.1 [0;37m (LTS: Gallium)[0m
|
||||||
v16.19.0 [1;32m (Latest LTS: Gallium)[0m
|
v16.19.0 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.19.1 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.0 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.1 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.2 [1;32m (Latest LTS: Gallium)[0m
|
||||||
v17.0.0
|
v17.0.0
|
||||||
v17.0.1
|
v17.0.1
|
||||||
v17.1.0
|
v17.1.0
|
||||||
@@ -662,9 +667,45 @@
|
|||||||
v18.10.0
|
v18.10.0
|
||||||
v18.11.0
|
v18.11.0
|
||||||
v18.12.0 [0;37m (LTS: Hydrogen)[0m
|
v18.12.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
v18.12.1 [1;32m (Latest LTS: Hydrogen)[0m
|
v18.12.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.13.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.2 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.15.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.16.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.16.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.17.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.17.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.2 [1;32m (Latest LTS: Hydrogen)[0m
|
||||||
v19.0.0
|
v19.0.0
|
||||||
v19.0.1
|
v19.0.1
|
||||||
v19.1.0
|
v19.1.0
|
||||||
v19.2.0
|
v19.2.0
|
||||||
v19.3.0
|
v19.3.0
|
||||||
|
v19.4.0
|
||||||
|
v19.5.0
|
||||||
|
v19.6.0
|
||||||
|
v19.6.1
|
||||||
|
v19.7.0
|
||||||
|
v19.8.0
|
||||||
|
v19.8.1
|
||||||
|
v19.9.0
|
||||||
|
v20.0.0
|
||||||
|
v20.1.0
|
||||||
|
v20.2.0
|
||||||
|
v20.3.0
|
||||||
|
v20.3.1
|
||||||
|
v20.4.0
|
||||||
|
v20.5.0
|
||||||
|
v20.5.1
|
||||||
|
v20.6.0
|
||||||
|
v20.6.1
|
||||||
|
v20.7.0
|
||||||
|
v20.8.0
|
||||||
|
v20.8.1
|
||||||
|
v20.9.0 [1;32m (Latest LTS: Iron)[0m
|
||||||
|
v21.0.0
|
||||||
|
v21.1.0
|
||||||
|
|||||||
@@ -622,7 +622,8 @@
|
|||||||
v14.20.1 [0;37m (LTS: Fermium)[0m
|
v14.20.1 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.0 [0;37m (LTS: Fermium)[0m
|
v14.21.0 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.1 [0;37m (LTS: Fermium)[0m
|
v14.21.1 [0;37m (LTS: Fermium)[0m
|
||||||
v14.21.2 [1;32m (Latest LTS: Fermium)[0m
|
v14.21.2 [0;37m (LTS: Fermium)[0m
|
||||||
|
v14.21.3 [1;32m (Latest LTS: Fermium)[0m
|
||||||
v15.0.0
|
v15.0.0
|
||||||
v15.0.1
|
v15.0.1
|
||||||
v15.1.0
|
v15.1.0
|
||||||
@@ -673,7 +674,11 @@
|
|||||||
v16.17.1 [0;37m (LTS: Gallium)[0m
|
v16.17.1 [0;37m (LTS: Gallium)[0m
|
||||||
v16.18.0 [0;37m (LTS: Gallium)[0m
|
v16.18.0 [0;37m (LTS: Gallium)[0m
|
||||||
v16.18.1 [0;37m (LTS: Gallium)[0m
|
v16.18.1 [0;37m (LTS: Gallium)[0m
|
||||||
v16.19.0 [1;32m (Latest LTS: Gallium)[0m
|
v16.19.0 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.19.1 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.0 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.1 [0;37m (LTS: Gallium)[0m
|
||||||
|
v16.20.2 [1;32m (Latest LTS: Gallium)[0m
|
||||||
v17.0.0
|
v17.0.0
|
||||||
v17.0.1
|
v17.0.1
|
||||||
v17.1.0
|
v17.1.0
|
||||||
@@ -703,9 +708,45 @@
|
|||||||
v18.10.0
|
v18.10.0
|
||||||
v18.11.0
|
v18.11.0
|
||||||
v18.12.0 [0;37m (LTS: Hydrogen)[0m
|
v18.12.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
v18.12.1 [1;32m (Latest LTS: Hydrogen)[0m
|
v18.12.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.13.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.14.2 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.15.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.16.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.16.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.17.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.17.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.0 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.1 [0;37m (LTS: Hydrogen)[0m
|
||||||
|
v18.18.2 [1;32m (Latest LTS: Hydrogen)[0m
|
||||||
v19.0.0
|
v19.0.0
|
||||||
v19.0.1
|
v19.0.1
|
||||||
v19.1.0
|
v19.1.0
|
||||||
v19.2.0
|
v19.2.0
|
||||||
v19.3.0
|
v19.3.0
|
||||||
|
v19.4.0
|
||||||
|
v19.5.0
|
||||||
|
v19.6.0
|
||||||
|
v19.6.1
|
||||||
|
v19.7.0
|
||||||
|
v19.8.0
|
||||||
|
v19.8.1
|
||||||
|
v19.9.0
|
||||||
|
v20.0.0
|
||||||
|
v20.1.0
|
||||||
|
v20.2.0
|
||||||
|
v20.3.0
|
||||||
|
v20.3.1
|
||||||
|
v20.4.0
|
||||||
|
v20.5.0
|
||||||
|
v20.5.1
|
||||||
|
v20.6.0
|
||||||
|
v20.6.1
|
||||||
|
v20.7.0
|
||||||
|
v20.8.0
|
||||||
|
v20.8.1
|
||||||
|
v20.9.0 [1;32m (Latest LTS: Iron)[0m
|
||||||
|
v21.0.0
|
||||||
|
v21.1.0
|
||||||
|
|||||||
@@ -1,26 +1,6 @@
|
|||||||
v6.9.1-nightly201610183843b96e46 Boron
|
v6.9.6-nightly201702013f61aae59d Boron *
|
||||||
v6.9.2-nightly201610208bb346d61a Boron
|
|
||||||
v6.9.3-nightly20161206c350268432 Boron
|
|
||||||
v6.9.4-nightly201701049844692719 Boron
|
|
||||||
v6.9.5-nightly2017013187ac44974a Boron
|
|
||||||
v6.9.6-nightly201702013f61aae59d Boron
|
|
||||||
v6.10.1-nightly20170222ee10f21f3b Boron
|
|
||||||
v6.10.2-nightly20170322426968ddd8 Boron
|
|
||||||
v6.10.3-nightly2017040479546c0b5a Boron
|
|
||||||
v6.10.4-nightly20170502312091a196 Boron
|
|
||||||
v6.11.1-nightly20170607f7ca483d68 Boron *
|
|
||||||
v8.9.1-nightly20171104a815e1b6a2 Carbon *
|
v8.9.1-nightly20171104a815e1b6a2 Carbon *
|
||||||
v10.13.1-nightly20181127a66d8774ac Dubnium
|
|
||||||
v10.14.1-nightly20181129bda1cc703a Dubnium
|
|
||||||
v10.14.2-nightly20181206fb99a4e9fa Dubnium
|
|
||||||
v10.14.3-nightly2018122617f4208a3b Dubnium
|
|
||||||
v10.15.1-nightly201901292d6e145340 Dubnium
|
|
||||||
v10.15.2-nightly201902215711238b4e Dubnium
|
|
||||||
v10.15.3-nightly20190301156e4c8e89 Dubnium
|
v10.15.3-nightly20190301156e4c8e89 Dubnium
|
||||||
v10.15.4-nightly20190522cda0d16414 Dubnium
|
v10.15.4-nightly201905019101d9368f Dubnium
|
||||||
v10.16.1-nightly201907310339fba1bb Dubnium
|
v10.16.2-nightly20190801f025f8524b Dubnium *
|
||||||
v10.16.2-nightly20190801f025f8524b Dubnium
|
|
||||||
v10.16.3-nightly20190807b743000a96 Dubnium
|
|
||||||
v10.16.4-nightly20190923859d47593e9fd97e6a9eae6eeb8b6e910acfe434 Dubnium *
|
|
||||||
v12.13.1-nightly20191022d9174b4cc5 Erbium
|
|
||||||
v12.22.10-nightly2022012660c9d3bb95 Erbium *
|
v12.22.10-nightly2022012660c9d3bb95 Erbium *
|
||||||
|
|||||||
@@ -175,7 +175,8 @@ v14.20.0 Fermium
|
|||||||
v14.20.1 Fermium
|
v14.20.1 Fermium
|
||||||
v14.21.0 Fermium
|
v14.21.0 Fermium
|
||||||
v14.21.1 Fermium
|
v14.21.1 Fermium
|
||||||
v14.21.2 Fermium *
|
v14.21.2 Fermium
|
||||||
|
v14.21.3 Fermium *
|
||||||
v16.13.0 Gallium
|
v16.13.0 Gallium
|
||||||
v16.13.1 Gallium
|
v16.13.1 Gallium
|
||||||
v16.13.2 Gallium
|
v16.13.2 Gallium
|
||||||
@@ -189,6 +190,23 @@ v16.17.0 Gallium
|
|||||||
v16.17.1 Gallium
|
v16.17.1 Gallium
|
||||||
v16.18.0 Gallium
|
v16.18.0 Gallium
|
||||||
v16.18.1 Gallium
|
v16.18.1 Gallium
|
||||||
v16.19.0 Gallium *
|
v16.19.0 Gallium
|
||||||
|
v16.19.1 Gallium
|
||||||
|
v16.20.0 Gallium
|
||||||
|
v16.20.1 Gallium
|
||||||
|
v16.20.2 Gallium *
|
||||||
v18.12.0 Hydrogen
|
v18.12.0 Hydrogen
|
||||||
v18.12.1 Hydrogen *
|
v18.12.1 Hydrogen
|
||||||
|
v18.13.0 Hydrogen
|
||||||
|
v18.14.0 Hydrogen
|
||||||
|
v18.14.1 Hydrogen
|
||||||
|
v18.14.2 Hydrogen
|
||||||
|
v18.15.0 Hydrogen
|
||||||
|
v18.16.0 Hydrogen
|
||||||
|
v18.16.1 Hydrogen
|
||||||
|
v18.17.0 Hydrogen
|
||||||
|
v18.17.1 Hydrogen
|
||||||
|
v18.18.0 Hydrogen
|
||||||
|
v18.18.1 Hydrogen
|
||||||
|
v18.18.2 Hydrogen *
|
||||||
|
v20.9.0 Iron *
|
||||||
|
|||||||
@@ -2,149 +2,48 @@ v0.10.41-nightly20151203036580393d
|
|||||||
v0.10.42-nightly20160128b125512a5c
|
v0.10.42-nightly20160128b125512a5c
|
||||||
v0.12.10-nightly20160128a305339f66
|
v0.12.10-nightly20160128a305339f66
|
||||||
v4.0.0-nightly201509079cae65c510
|
v4.0.0-nightly201509079cae65c510
|
||||||
v5.0.0-nightly201510266a04cc0a43
|
v5.7.1-nightly20160301c83725c604
|
||||||
v5.0.1-nightly2015111484bb74547d
|
|
||||||
v5.1.2-nightly201512091c1c1a0f2b
|
|
||||||
v5.2.1-nightly20151210cb938aaa33
|
|
||||||
v5.3.1-nightly20151224b4c51c5b76
|
|
||||||
v5.4.1-nightly20160107138e1e501e
|
|
||||||
v5.4.2-nightly20160121e855b596f4
|
|
||||||
v5.5.1-nightly20160127a8c2050c2d
|
|
||||||
v5.6.1-nightly201602106d8eba0e5e
|
|
||||||
v5.7.1-nightly20160302c83725c604
|
|
||||||
v5.7.2-nightly2016030801c331ea37
|
v5.7.2-nightly2016030801c331ea37
|
||||||
v5.10.2-nightly201604206d9c0c9aa7
|
v5.11.1-nightly2016050199920480ae
|
||||||
v5.11.1-nightly20160504bec5d50f1e
|
v5.11.2-nightly2016060121552bd0c5
|
||||||
v5.11.2-nightly2016062103d36aea4f
|
v6.0.0-nightly20160301d9f7a597e4
|
||||||
v6.0.0-nightly20160425eb4201f07a
|
v6.5.1-nightly20160901180867d6a6
|
||||||
v6.3.1-nightly201607209e9d499b8b
|
v6.7.1-nightly20161001d7454e7547
|
||||||
v6.3.2-nightly20160815da9bd2fc48
|
v6.9.6-nightly201702013f61aae59d Boron *
|
||||||
v6.4.1-nightly20160825723fa9637c
|
v7.0.0-nightly20161001c8c2544cd9
|
||||||
v6.5.1-nightly20160914180867d6a6
|
|
||||||
v6.6.1-nightly20160927f8ad0dc0e2
|
|
||||||
v6.7.1-nightly20161007d7454e7547
|
|
||||||
v6.8.1-nightly201610132540417ef5
|
|
||||||
v6.8.2-nightly201610154613c22b00
|
|
||||||
v6.9.1-nightly201610183843b96e46 Boron
|
|
||||||
v6.9.2-nightly201610208bb346d61a Boron
|
|
||||||
v6.9.3-nightly20161206c350268432 Boron
|
|
||||||
v6.9.4-nightly201701049844692719 Boron
|
|
||||||
v6.9.5-nightly2017013187ac44974a Boron
|
|
||||||
v6.9.6-nightly201702013f61aae59d Boron
|
|
||||||
v6.10.1-nightly20170222ee10f21f3b Boron
|
|
||||||
v6.10.2-nightly20170322426968ddd8 Boron
|
|
||||||
v6.10.3-nightly2017040479546c0b5a Boron
|
|
||||||
v6.10.4-nightly20170502312091a196 Boron
|
|
||||||
v6.11.1-nightly20170607f7ca483d68 Boron *
|
|
||||||
v7.0.0-nightly201610246bbdd668bd
|
|
||||||
v7.0.1-nightly2016102527e1749dcb
|
|
||||||
v7.1.1-nightly201611093daf11635d
|
|
||||||
v7.2.0-nightly20161123c1aa949064
|
|
||||||
v7.2.1-nightly201611248cabe28efb
|
|
||||||
v7.2.2-nightly20161207c2cc11b3c6
|
|
||||||
v7.3.1-nightly20161221586967a078
|
|
||||||
v7.4.1-nightly20170104e07b6516d7
|
|
||||||
v7.5.1-nightly2017020113a024d531
|
v7.5.1-nightly2017020113a024d531
|
||||||
v7.6.1-nightly201702227a6367017c
|
|
||||||
v7.7.1-nightly201703019c75f4c78a
|
v7.7.1-nightly201703019c75f4c78a
|
||||||
v7.7.2-nightly20170302b20bc130ef
|
|
||||||
v7.7.3-nightly20170309c62798034a
|
|
||||||
v7.7.4-nightly20170315753adee6aa
|
|
||||||
v7.7.5-nightly20170322bc664cb034
|
|
||||||
v7.8.1-nightly20170329517f13b607
|
|
||||||
v7.9.1-nightly20170411675ece47b3
|
v7.9.1-nightly20170411675ece47b3
|
||||||
v7.10.1-nightly2017050369a8053e8a
|
v8.0.0-nightly201705010f58d3cbef
|
||||||
v8.0.0-nightly20170530effeff1843
|
v8.2.1-nightly2017080132b30d519e
|
||||||
v8.1.0-nightly20170612f6fc46e036
|
|
||||||
v8.1.1-nightly2017061323318c7661
|
|
||||||
v8.1.2-nightly20170614a1b27dbfb4
|
|
||||||
v8.1.3-nightly201706220b96a2640b
|
|
||||||
v8.1.4-nightly20170704c2c7eb1a41
|
|
||||||
v8.1.5-nightly20170718e9491f1cd4
|
|
||||||
v8.2.1-nightly2017080791b7843aeb
|
|
||||||
v8.3.1-nightly201708182d8d355a5f
|
|
||||||
v8.4.1-nightly201709104b28e0055e
|
|
||||||
v8.5.1-nightly20170921535f8d5281
|
|
||||||
v8.6.1-nightly201710116f42b680e3
|
|
||||||
v8.7.1-nightly2017102478a6ef46a9
|
|
||||||
v8.8.1-nightly201710256fbef7f350
|
|
||||||
v8.8.2-nightly20171030f00ba6b142
|
|
||||||
v8.9.1-nightly20171104a815e1b6a2 Carbon *
|
v8.9.1-nightly20171104a815e1b6a2 Carbon *
|
||||||
v9.0.0-nightly2017103182790d84f2
|
v9.0.0-nightly20171001f9be5fe52a
|
||||||
v9.0.1-nightly20171105ed0fbd8d72
|
v9.5.1-nightly2018020181da708f73
|
||||||
v9.1.1-nightly20171207c81e9682c4
|
|
||||||
v9.2.1-nightly20171208f0f9e1abf0
|
|
||||||
v9.2.2-nightly20171212f8143214be
|
|
||||||
v9.3.1-nightly2018010930273d400c
|
|
||||||
v9.4.1-nightly20180124dd56bd1591
|
|
||||||
v9.5.1-nightly20180221b9b58100e0
|
|
||||||
v9.6.1-nightly20180222927c1b1a7e
|
|
||||||
v9.6.2-nightly201802277853a7fd2a
|
|
||||||
v9.7.1-nightly201803013f3995b7b7
|
v9.7.1-nightly201803013f3995b7b7
|
||||||
v9.7.2-nightly20180307cde6671b41
|
|
||||||
v9.8.1-nightly20180320607b33cfcc
|
|
||||||
v9.9.1-nightly201803256591d9f761
|
v9.9.1-nightly201803256591d9f761
|
||||||
v9.10.0-nightly201803270a18bf1304
|
v10.0.0-nightly20180401141be923f3
|
||||||
v9.10.1-nightly201803284844a263ce
|
v10.5.1-nightly20180701b28fd37a69
|
||||||
v9.10.2-nightly201804042bdf3ca235
|
|
||||||
v9.11.2-nightly201804135d9a7f81ae
|
|
||||||
v10.0.0-nightly20180424982adb5994
|
|
||||||
v10.0.1-nightly20180505ff148b987d
|
|
||||||
v10.1.1-nightly20180523235a272838
|
|
||||||
v10.2.1-nightly20180524be71c5dea9
|
|
||||||
v10.2.2-nightly20180526efc7f91354
|
|
||||||
v10.3.1-nightly201806067c0c61bde1
|
|
||||||
v10.4.1-nightly201806125752f520b1
|
|
||||||
v10.4.2-nightly20180619bc20ec0c0f
|
|
||||||
v10.5.1-nightly201807035d6d6fb121
|
|
||||||
v10.6.1-nightly20180718eef975ebae
|
|
||||||
v10.7.1-nightly2018080162fd84528e
|
v10.7.1-nightly2018080162fd84528e
|
||||||
v10.8.1-nightly2018081382830a809b
|
|
||||||
v10.9.0-nightly20180906707a37f74f
|
v10.9.0-nightly20180906707a37f74f
|
||||||
v10.10.1-nightly201809205da1f0ca2c
|
|
||||||
v10.11.1-nightly20181010d16486b215
|
|
||||||
v10.12.1-nightly201810283f63297fe8
|
|
||||||
v10.13.1-nightly20181127a66d8774ac Dubnium
|
|
||||||
v10.14.1-nightly20181129bda1cc703a Dubnium
|
|
||||||
v10.14.2-nightly20181206fb99a4e9fa Dubnium
|
|
||||||
v10.14.3-nightly2018122617f4208a3b Dubnium
|
|
||||||
v10.15.1-nightly201901292d6e145340 Dubnium
|
|
||||||
v10.15.2-nightly201902215711238b4e Dubnium
|
|
||||||
v10.15.3-nightly20190301156e4c8e89 Dubnium
|
v10.15.3-nightly20190301156e4c8e89 Dubnium
|
||||||
v10.15.4-nightly20190522cda0d16414 Dubnium
|
v10.15.4-nightly201905019101d9368f Dubnium
|
||||||
v10.16.1-nightly201907310339fba1bb Dubnium
|
v10.16.2-nightly20190801f025f8524b Dubnium *
|
||||||
v10.16.2-nightly20190801f025f8524b Dubnium
|
v11.0.0-nightly201810011be804d625
|
||||||
v10.16.3-nightly20190807b743000a96 Dubnium
|
|
||||||
v10.16.4-nightly20190923859d47593e9fd97e6a9eae6eeb8b6e910acfe434 Dubnium *
|
|
||||||
v11.0.0-nightly20181023d901d16b39
|
|
||||||
v11.1.0-nightly20181101af6d26281f
|
v11.1.0-nightly20181101af6d26281f
|
||||||
v12.0.0-nightly20190423859421188b
|
v12.0.0-nightly2019040166b95362df
|
||||||
v12.10.1-nightly20190925edd7c579e8
|
|
||||||
v12.11.1-nightly20190926acd08fdce5
|
|
||||||
v12.11.2-nightly201910115fdf4a474f
|
|
||||||
v12.12.1-nightly201910123f3c41cfb0
|
|
||||||
v12.13.1-nightly20191022d9174b4cc5 Erbium
|
|
||||||
v12.22.10-nightly2022012660c9d3bb95 Erbium *
|
v12.22.10-nightly2022012660c9d3bb95 Erbium *
|
||||||
v13.0.0-nightly2019102271b342f937
|
v13.0.0-nightly2019100116e47b976b
|
||||||
v13.0.2-nightly20191028e4ab6fced1
|
v13.2.1-nightly20191201cbd50262c0
|
||||||
v13.1.1-nightly201911219b71534d23
|
|
||||||
v13.2.1-nightly2019120319b31c1bc5
|
|
||||||
v13.3.1-nightly20191214b3ae532392
|
|
||||||
v13.4.1-nightly2019121896a65e85c5
|
|
||||||
v13.5.1-nightly2020010742d36dca90
|
|
||||||
v13.6.1-nightly20200121cbd84c5ee1
|
|
||||||
v13.7.1-nightly20200122340a1bd9a0
|
|
||||||
v13.8.1-nightly202002187c2d33f38f
|
|
||||||
v13.9.1-nightly202003041bca7b6c70
|
v13.9.1-nightly202003041bca7b6c70
|
||||||
v13.10.2-nightly202003117eed9d6bcc
|
v13.12.1-nightly20200401ffdd82ba3f
|
||||||
v13.11.1-nightly2020032628e298f219
|
|
||||||
v13.12.1-nightly202004140a8e07599b
|
|
||||||
v13.13.1-nightly20200415947ddec091
|
|
||||||
v14.0.0-nightly20200421c3554307c6
|
v14.0.0-nightly20200421c3554307c6
|
||||||
v15.0.0-nightly2020102011f1ad939f
|
v15.0.0-nightly2020102011f1ad939f
|
||||||
v16.0.0-nightly20210420a0261d231c
|
v16.0.0-nightly20210420a0261d231c
|
||||||
v17.0.0-nightly202110193f11666dc7
|
v17.0.0-nightly2021100135dc3861cd
|
||||||
v17.5.0-nightly20220209e43808936a
|
v17.5.0-nightly20220209e43808936a
|
||||||
v18.0.0-nightly20220419bde889bd4e
|
v18.0.0-nightly20220419bde889bd4e
|
||||||
v19.0.0-nightly202210182672219b78
|
v19.0.0-nightly202210182672219b78
|
||||||
v20.0.0-nightly2022122271951a0e86
|
v20.0.0-nightly2023041197d3912eb8
|
||||||
|
v20.7.0-nightly202309173557c436181c526f41bb6ce7751e63f36695aa1d
|
||||||
|
v21.0.0-nightly202310240fb512344f
|
||||||
|
v22.0.0-nightly20231025d1ccca9d2b
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
v20.0.0-nightly2022122271951a0e86
|
v22.0.0-nightly20231025d1ccca9d2b
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
v19.3.0
|
v21.1.0
|
||||||
|
|||||||
@@ -581,7 +581,8 @@ v14.20.0 Fermium
|
|||||||
v14.20.1 Fermium
|
v14.20.1 Fermium
|
||||||
v14.21.0 Fermium
|
v14.21.0 Fermium
|
||||||
v14.21.1 Fermium
|
v14.21.1 Fermium
|
||||||
v14.21.2 Fermium *
|
v14.21.2 Fermium
|
||||||
|
v14.21.3 Fermium *
|
||||||
v15.0.0
|
v15.0.0
|
||||||
v15.0.1
|
v15.0.1
|
||||||
v15.1.0
|
v15.1.0
|
||||||
@@ -632,7 +633,11 @@ v16.17.0 Gallium
|
|||||||
v16.17.1 Gallium
|
v16.17.1 Gallium
|
||||||
v16.18.0 Gallium
|
v16.18.0 Gallium
|
||||||
v16.18.1 Gallium
|
v16.18.1 Gallium
|
||||||
v16.19.0 Gallium *
|
v16.19.0 Gallium
|
||||||
|
v16.19.1 Gallium
|
||||||
|
v16.20.0 Gallium
|
||||||
|
v16.20.1 Gallium
|
||||||
|
v16.20.2 Gallium *
|
||||||
v17.0.0
|
v17.0.0
|
||||||
v17.0.1
|
v17.0.1
|
||||||
v17.1.0
|
v17.1.0
|
||||||
@@ -662,9 +667,45 @@ v18.9.1
|
|||||||
v18.10.0
|
v18.10.0
|
||||||
v18.11.0
|
v18.11.0
|
||||||
v18.12.0 Hydrogen
|
v18.12.0 Hydrogen
|
||||||
v18.12.1 Hydrogen *
|
v18.12.1 Hydrogen
|
||||||
|
v18.13.0 Hydrogen
|
||||||
|
v18.14.0 Hydrogen
|
||||||
|
v18.14.1 Hydrogen
|
||||||
|
v18.14.2 Hydrogen
|
||||||
|
v18.15.0 Hydrogen
|
||||||
|
v18.16.0 Hydrogen
|
||||||
|
v18.16.1 Hydrogen
|
||||||
|
v18.17.0 Hydrogen
|
||||||
|
v18.17.1 Hydrogen
|
||||||
|
v18.18.0 Hydrogen
|
||||||
|
v18.18.1 Hydrogen
|
||||||
|
v18.18.2 Hydrogen *
|
||||||
v19.0.0
|
v19.0.0
|
||||||
v19.0.1
|
v19.0.1
|
||||||
v19.1.0
|
v19.1.0
|
||||||
v19.2.0
|
v19.2.0
|
||||||
v19.3.0
|
v19.3.0
|
||||||
|
v19.4.0
|
||||||
|
v19.5.0
|
||||||
|
v19.6.0
|
||||||
|
v19.6.1
|
||||||
|
v19.7.0
|
||||||
|
v19.8.0
|
||||||
|
v19.8.1
|
||||||
|
v19.9.0
|
||||||
|
v20.0.0
|
||||||
|
v20.1.0
|
||||||
|
v20.2.0
|
||||||
|
v20.3.0
|
||||||
|
v20.3.1
|
||||||
|
v20.4.0
|
||||||
|
v20.5.0
|
||||||
|
v20.5.1
|
||||||
|
v20.6.0
|
||||||
|
v20.6.1
|
||||||
|
v20.7.0
|
||||||
|
v20.8.0
|
||||||
|
v20.8.1
|
||||||
|
v20.9.0 Iron *
|
||||||
|
v21.0.0
|
||||||
|
v21.1.0
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
lts/*|lts/hydrogen
|
lts/*|lts/iron
|
||||||
lts/hydrogen|v18.12.1
|
lts/iron|v20.9.0
|
||||||
lts/gallium|v16.19.0
|
lts/hydrogen|v18.18.2
|
||||||
lts/fermium|v14.21.2
|
lts/gallium|v16.20.2
|
||||||
|
lts/fermium|v14.21.3
|
||||||
lts/erbium|v12.22.12
|
lts/erbium|v12.22.12
|
||||||
lts/dubnium|v10.24.1
|
lts/dubnium|v10.24.1
|
||||||
lts/carbon|v8.17.0
|
lts/carbon|v8.17.0
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
20.0
|
22.0
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
19.3
|
21.1
|
||||||
|
|||||||
55
test/fast/Unit tests/nvm_download_artifact
Executable file
55
test/fast/Unit tests/nvm_download_artifact
Executable file
@@ -0,0 +1,55 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
cleanup () {
|
||||||
|
unset -f nvm_get_mirror
|
||||||
|
}
|
||||||
|
die () { echo "$@" ; cleanup ; exit 1; }
|
||||||
|
|
||||||
|
\. ../../../nvm.sh
|
||||||
|
|
||||||
|
# bad flavor
|
||||||
|
ACTUAL="$(nvm_download_artifact 2>&1)"
|
||||||
|
CODE="$(nvm_download_artifact >/dev/null 2>&1 ; echo $?)"
|
||||||
|
EXPECTED='supported flavors: node, iojs'
|
||||||
|
EXPECTED_CODE=1
|
||||||
|
|
||||||
|
[ "${ACTUAL}" = "${EXPECTED}" ] || die "expected >${EXPECTED}<, got >${ACTUAL}<"
|
||||||
|
[ "${CODE}" = $EXPECTED_CODE ] || die "expected exit code ${EXPECTED_CODE}, got ${CODE}"
|
||||||
|
|
||||||
|
# bad kind
|
||||||
|
ACTUAL="$(nvm_download_artifact node 2>&1)"
|
||||||
|
CODE="$(nvm_download_artifact node >/dev/null 2>&1 ; echo $?)"
|
||||||
|
EXPECTED='supported kinds: binary, source'
|
||||||
|
EXPECTED_CODE=1
|
||||||
|
|
||||||
|
[ "${ACTUAL}" = "${EXPECTED}" ] || die "expected >${EXPECTED}<, got >${ACTUAL}<"
|
||||||
|
[ "${CODE}" = $EXPECTED_CODE ] || die "expected exit code ${EXPECTED_CODE}, got ${CODE}"
|
||||||
|
|
||||||
|
# bad type
|
||||||
|
ACTUAL="$(nvm_download_artifact node binary nonexistentType 2>&1)"
|
||||||
|
CODE="$(nvm_download_artifact node binary nonexistentType >/dev/null 2>&1 ; echo $?)"
|
||||||
|
EXPECTED='unknown type of node.js or io.js release'
|
||||||
|
EXPECTED_CODE=2
|
||||||
|
|
||||||
|
[ "${ACTUAL}" = "${EXPECTED}" ] || die "expected >${EXPECTED}<, got >${ACTUAL}<"
|
||||||
|
[ "${CODE}" = $EXPECTED_CODE ] || die "expected exit code ${EXPECTED_CODE}, got ${CODE}"
|
||||||
|
|
||||||
|
# no version
|
||||||
|
ACTUAL="$(nvm_download_artifact node binary std 2>&1)"
|
||||||
|
CODE="$(nvm_download_artifact node binary std >/dev/null 2>&1 ; echo $?)"
|
||||||
|
EXPECTED='A version number is required.'
|
||||||
|
EXPECTED_CODE=3
|
||||||
|
|
||||||
|
[ "${ACTUAL}" = "${EXPECTED}" ] || die "expected >${EXPECTED}<, got >${ACTUAL}<"
|
||||||
|
[ "${CODE}" = $EXPECTED_CODE ] || die "expected exit code ${EXPECTED_CODE}, got ${CODE}"
|
||||||
|
|
||||||
|
# binary type, version without binary available
|
||||||
|
VERSION=0.8.5
|
||||||
|
ACTUAL="$(nvm_download_artifact node binary std ${VERSION} 2>&1)"
|
||||||
|
CODE="$(nvm_download_artifact node binary std ${VERSION} >/dev/null 2>&1 ; echo $?)"
|
||||||
|
EXPECTED="No precompiled binary available for ${VERSION}."
|
||||||
|
EXPECTED_CODE=0
|
||||||
|
|
||||||
|
[ "${ACTUAL}" = "${EXPECTED}" ] || die "expected >${EXPECTED}<, got >${ACTUAL}<"
|
||||||
|
[ "${CODE}" = $EXPECTED_CODE ] || die "expected exit code ${EXPECTED_CODE}, got ${CODE}"
|
||||||
|
|
||||||
@@ -31,3 +31,6 @@ ACTUAL="$(PWD=$TEST_DIR/no-nesting-n_m nvm_find_project_dir)"
|
|||||||
|
|
||||||
ACTUAL="$(PWD=$TEST_DIR/no-nesting-pkg nvm_find_project_dir)"
|
ACTUAL="$(PWD=$TEST_DIR/no-nesting-pkg nvm_find_project_dir)"
|
||||||
[ "${ACTUAL}" = "$TEST_DIR/no-nesting-pkg" ] || die "no-nesting-pkg: got ${ACTUAL}"
|
[ "${ACTUAL}" = "$TEST_DIR/no-nesting-pkg" ] || die "no-nesting-pkg: got ${ACTUAL}"
|
||||||
|
|
||||||
|
ACTUAL="$(PWD="." nvm_find_project_dir)"
|
||||||
|
[ "${ACTUAL}" = "." ] || die "insufficient permissions for pwd: got ${ACTUAL}"
|
||||||
|
|||||||
@@ -21,5 +21,6 @@ TEST_DIR="$PWD"
|
|||||||
[ "~$(PWD=$TEST_DIR/tmp_nvm_find_up/a/b nvm_find_up 'test')" = "~$TEST_DIR/tmp_nvm_find_up" ] || die "failed to find 2 dirs up"
|
[ "~$(PWD=$TEST_DIR/tmp_nvm_find_up/a/b nvm_find_up 'test')" = "~$TEST_DIR/tmp_nvm_find_up" ] || die "failed to find 2 dirs up"
|
||||||
[ "~$(PWD=$TEST_DIR/tmp_nvm_find_up/a/b/c nvm_find_up 'test')" = "~$TEST_DIR/tmp_nvm_find_up/a/b/c" ] || die "failed to find in current dir"
|
[ "~$(PWD=$TEST_DIR/tmp_nvm_find_up/a/b/c nvm_find_up 'test')" = "~$TEST_DIR/tmp_nvm_find_up/a/b/c" ] || die "failed to find in current dir"
|
||||||
[ "~$(PWD=$TEST_DIR/tmp_nvm_find_up/a/b/c/d nvm_find_up 'test')" = "~$TEST_DIR/tmp_nvm_find_up/a/b/c" ] || die "failed to find 1 level up from current dir"
|
[ "~$(PWD=$TEST_DIR/tmp_nvm_find_up/a/b/c/d nvm_find_up 'test')" = "~$TEST_DIR/tmp_nvm_find_up/a/b/c" ] || die "failed to find 1 level up from current dir"
|
||||||
|
[ "~$(PWD="." nvm_find_up 'test')" = "~." ] || die "failed to handle '.' output from pwd"
|
||||||
|
|
||||||
cleanup
|
cleanup
|
||||||
|
|||||||
@@ -80,5 +80,6 @@ run_test x86 osx x86
|
|||||||
run_test amd64 osx x64
|
run_test amd64 osx x64
|
||||||
|
|
||||||
run_test arm64 smartos x64
|
run_test arm64 smartos x64
|
||||||
|
run_test armv8l smartos x64
|
||||||
|
|
||||||
cleanup
|
cleanup
|
||||||
|
|||||||
94
test/fast/Unit tests/nvm_get_arch_unofficial
Executable file
94
test/fast/Unit tests/nvm_get_arch_unofficial
Executable file
@@ -0,0 +1,94 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Save the PATH as it was when the test started to restore it when it finishes
|
||||||
|
ORIG_PATH="${PATH}"
|
||||||
|
|
||||||
|
cleanup() {
|
||||||
|
# Restore the PATH as it was when the test started
|
||||||
|
export PATH="${ORIG_PATH}"
|
||||||
|
rm -rf "${TMP_DIR}"
|
||||||
|
}
|
||||||
|
|
||||||
|
die() {
|
||||||
|
cleanup
|
||||||
|
echo "$@"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
. ../../../nvm.sh
|
||||||
|
|
||||||
|
# Sets the PATH for these tests to include the symlinks to the mocked binaries
|
||||||
|
export PATH=".:${PATH}"
|
||||||
|
|
||||||
|
TMP_DIR=$(mktemp -d)
|
||||||
|
CHROOT_WITH_ALPINE="$TMP_DIR/with_alpine"
|
||||||
|
CHROOT_WITHOUT_ALPINE="$TMP_DIR/without_alpine"
|
||||||
|
|
||||||
|
setup_chroot() {
|
||||||
|
chroot_dir=$1
|
||||||
|
|
||||||
|
# Directories
|
||||||
|
mkdir -p "${chroot_dir}/etc"
|
||||||
|
mkdir -p "${chroot_dir}/bin"
|
||||||
|
mkdir -p "${chroot_dir}/usr/bin"
|
||||||
|
mkdir -p "${chroot_dir}/lib64"
|
||||||
|
mkdir -p "${chroot_dir}/dev"
|
||||||
|
|
||||||
|
# Files and binaries
|
||||||
|
cp ../../../nvm.sh "${chroot_dir}/"
|
||||||
|
cp /bin/sh /usr/bin/dirname "${chroot_dir}/bin/"
|
||||||
|
[ "${chroot_dir}" = "${CHROOT_WITH_ALPINE}" ] && touch "${chroot_dir}/etc/alpine-release"
|
||||||
|
|
||||||
|
# Libraries
|
||||||
|
for binary in /bin/sh /usr/bin/dirname; do
|
||||||
|
for lib in $(ldd $binary | awk '{print $3}' | grep "^/"); do
|
||||||
|
dir=$(dirname "${lib}")
|
||||||
|
mkdir -p "${chroot_dir}${dir}"
|
||||||
|
cp "${lib}" "${chroot_dir}${dir}/"
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
|
# Dynamic linker
|
||||||
|
cp /lib64/ld-linux-x86-64.so.2 "${chroot_dir}/lib64/"
|
||||||
|
|
||||||
|
# /dev/null
|
||||||
|
sudo mknod "${chroot_dir}/dev/null" c 1 3
|
||||||
|
}
|
||||||
|
|
||||||
|
setup_chroot "${CHROOT_WITH_ALPINE}"
|
||||||
|
setup_chroot "${CHROOT_WITHOUT_ALPINE}"
|
||||||
|
|
||||||
|
# Run tests in chroot environments
|
||||||
|
ARCH_WITH_ALPINE=$(sudo chroot "${CHROOT_WITH_ALPINE}" /bin/sh -c ". ./nvm.sh && nvm_get_arch")
|
||||||
|
[ "${ARCH_WITH_ALPINE}" = "x64-musl" ] || die "Expected x64-musl for alpine environment but got ${ARCH_WITH_ALPINE}"
|
||||||
|
|
||||||
|
ARCH_WITHOUT_ALPINE=$(sudo chroot "${CHROOT_WITHOUT_ALPINE}" /bin/sh -c ". ./nvm.sh && nvm_get_arch")
|
||||||
|
[ "${ARCH_WITHOUT_ALPINE}" != "x64-musl" ] || die "Did not expect x64-musl for non-alpine environment"
|
||||||
|
|
||||||
|
# Run tests for nvm ls-remote
|
||||||
|
test_default_ls_remote() {
|
||||||
|
mock_response='N/A'
|
||||||
|
result=$(NVM_NODEJS_ORG_MIRROR='http://nonexistent-url' nvm ls-remote 18)
|
||||||
|
if [ "${result}" = "${mock_response}" ]; then
|
||||||
|
die "Test failed: Expected '${mock_response}' for but got '${result}'"
|
||||||
|
else
|
||||||
|
echo "Test passed"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
test_unofficial_mirror_ls_remote() {
|
||||||
|
mock_response='v18.18.0 (LTS: Hydrogen)'
|
||||||
|
result=$(NVM_NODEJS_ORG_MIRROR='https://unofficial-builds.nodejs.org/download/release' nvm ls-remote 18.18.0 | sed -e 's/^[[:space:]]*//')
|
||||||
|
result=$(echo "${result}" | sed 's/\x1b\[[0-9;]*m//g')
|
||||||
|
|
||||||
|
if [ "${result}" = "${mock_response}" ]; then
|
||||||
|
echo "Test passed"
|
||||||
|
else
|
||||||
|
die "Test failed: Expected '${mock_response}' but got '${result}'"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
test_default_ls_remote
|
||||||
|
test_unofficial_mirror_ls_remote
|
||||||
|
|
||||||
|
cleanup
|
||||||
@@ -30,3 +30,11 @@ unset NVM_NODEJS_ORG_MIRROR
|
|||||||
NVM_IOJS_ORG_MIRROR="test://domain"
|
NVM_IOJS_ORG_MIRROR="test://domain"
|
||||||
[ "$(nvm_get_mirror iojs std)" = "test://domain" ] || die "iojs-std mirror should respect NVM_IOJS_ORG_MIRROR"
|
[ "$(nvm_get_mirror iojs std)" = "test://domain" ] || die "iojs-std mirror should respect NVM_IOJS_ORG_MIRROR"
|
||||||
unset NVM_IOJS_ORG_MIRROR
|
unset NVM_IOJS_ORG_MIRROR
|
||||||
|
|
||||||
|
NVM_NODEJS_ORG_MIRROR='`do something bad`'
|
||||||
|
! nvm_get_mirror node std || die 'NVM_NODEJS_ORG_MIRROR errors with command injection attempt'
|
||||||
|
[ "$(nvm_get_mirror node std)" = "" ] || die 'NVM_NODEJS_ORG_MIRROR is protected against command injection'
|
||||||
|
|
||||||
|
NVM_IOJS_ORG_MIRROR='`do something bad`'
|
||||||
|
! nvm_get_mirror iojs std || die 'NVM_IOJS_ORG_MIRROR errors with command injection attempt'
|
||||||
|
[ "$(nvm_get_mirror iojs std)" = "" ] || die 'NVM_IOJS_ORG_MIRROR is protected against command injection'
|
||||||
|
|||||||
@@ -27,10 +27,10 @@ OUTPUT="$(nvm_ls_remote)"
|
|||||||
EXPECTED_OUTPUT="$(cat "$EXPECTED_OUTPUT_PATH")"
|
EXPECTED_OUTPUT="$(cat "$EXPECTED_OUTPUT_PATH")"
|
||||||
[ "_$OUTPUT" = "_$EXPECTED_OUTPUT" ] || die "bare nvm_ls_remote did not output expected sorted versions; got $(echo ">$OUTPUT<") expected $(echo ">$EXPECTED_OUTPUT<")"
|
[ "_$OUTPUT" = "_$EXPECTED_OUTPUT" ] || die "bare nvm_ls_remote did not output expected sorted versions; got $(echo ">$OUTPUT<") expected $(echo ">$EXPECTED_OUTPUT<")"
|
||||||
|
|
||||||
OUTPUT="$(nvm_ls_remote 10.0)"
|
OUTPUT="$(nvm_ls_remote 11)"
|
||||||
EXPECTED_OUTPUT="v10.0.0-nightly20180424982adb5994
|
EXPECTED_OUTPUT="v11.0.0-nightly201810011be804d625
|
||||||
v10.0.1-nightly20180505ff148b987d"
|
v11.1.0-nightly20181101af6d26281f"
|
||||||
[ "_$OUTPUT" = "_$EXPECTED_OUTPUT" ] || die "nvm_ls_remote 10.0 did not output 10.0 nightly versions; got $OUTPUT"
|
[ "_$OUTPUT" = "_$EXPECTED_OUTPUT" ] || die "nvm_ls_remote 11 did not output v11 nightly versions; got $OUTPUT"
|
||||||
|
|
||||||
# Sanity checks
|
# Sanity checks
|
||||||
OUTPUT="$(nvm_print_implicit_alias remote stable)"
|
OUTPUT="$(nvm_print_implicit_alias remote stable)"
|
||||||
|
|||||||
@@ -16,3 +16,9 @@ TEST_PATH="$NVM_DIR/v0.10.5/bin:/usr/bin:$NVM_DIR/v0.11.5/bin:$NVM_DIR/v0.9.5/bi
|
|||||||
STRIPPED_PATH=`nvm_strip_path "$TEST_PATH" "/bin"`
|
STRIPPED_PATH=`nvm_strip_path "$TEST_PATH" "/bin"`
|
||||||
|
|
||||||
[ "$STRIPPED_PATH" = "/usr/bin:/usr/local/bin" ] || die "Not correctly stripped: $STRIPPED_PATH "
|
[ "$STRIPPED_PATH" = "/usr/bin:/usr/local/bin" ] || die "Not correctly stripped: $STRIPPED_PATH "
|
||||||
|
|
||||||
|
TEST_PATH=":/a/b/bin::/c/d/bin:"
|
||||||
|
|
||||||
|
STRIPPED_PATH=`nvm_strip_path "$TEST_PATH" "/bin"`
|
||||||
|
|
||||||
|
[ "$STRIPPED_PATH" = "$TEST_PATH" ] || die "Stripping does not preserve colons: $STRIPPED_PATH "
|
||||||
|
|||||||
@@ -32,15 +32,17 @@ setup
|
|||||||
|
|
||||||
npm install -g nop >/dev/null || die 'nvm_check_global_modules cannot be tested because `npm` cannot install the `nop` package'
|
npm install -g nop >/dev/null || die 'nvm_check_global_modules cannot be tested because `npm` cannot install the `nop` package'
|
||||||
message=$(nvm_check_global_modules)
|
message=$(nvm_check_global_modules)
|
||||||
[ ! -z "$message" ] || die "nvm_check_global_modules should have printed a notice when npm had global modules installed"
|
[ ! -z "$message" ] || die "nvm_check_global_modules should have printed a notice when npm had global modules installed; got:\n${message}"
|
||||||
|
|
||||||
# Admit we're using NVM, just for this one test
|
if [ -n "${ORIGINAL_NVM_DIR}" ]; then
|
||||||
message=$(NVM_DIR=$ORIGINAL_NVM_DIR nvm_check_global_modules)
|
# Admit we're using NVM, just for this one test
|
||||||
[ -z "$message" ] || die "nvm_check_global_modules should not have printed a notice when npm is managed by nvm"
|
message=$(NVM_DIR="${ORIGINAL_NVM_DIR}" nvm_check_global_modules)
|
||||||
|
[ -z "$message" ] || die "nvm_check_global_modules should not have printed a notice when npm is managed by nvm; got:\n${message}"
|
||||||
|
fi
|
||||||
|
|
||||||
npm uninstall -g nop >/dev/null
|
npm uninstall -g nop >/dev/null
|
||||||
message=$(nvm_check_global_modules)
|
message=$(nvm_check_global_modules)
|
||||||
[ -z "$message" ] || die "nvm_check_global_modules should not have printed a notice when npm had no global modules installed"
|
[ -z "$message" ] || die "nvm_check_global_modules should not have printed a notice when npm had no global modules installed; got:\n${message}"
|
||||||
|
|
||||||
# Faking an installation of npm
|
# Faking an installation of npm
|
||||||
mkdir -p "$npm_config_prefix/lib/node_modules/npm"
|
mkdir -p "$npm_config_prefix/lib/node_modules/npm"
|
||||||
@@ -49,7 +51,7 @@ cat <<'JSON' >"$npm_config_prefix/lib/node_modules/npm/package.json"
|
|||||||
JSON
|
JSON
|
||||||
|
|
||||||
message=$(nvm_check_global_modules)
|
message=$(nvm_check_global_modules)
|
||||||
[ -z "$message" ] || die "nvm_check_global_modules should have not printed a notice when npm had only itself installed as a global module"
|
[ -z "$message" ] || die "nvm_check_global_modules should have not printed a notice when npm had only itself installed as a global module; got:\n${message}"
|
||||||
|
|
||||||
# Faking the absence of npm
|
# Faking the absence of npm
|
||||||
PATH=".:$PATH"
|
PATH=".:$PATH"
|
||||||
@@ -57,7 +59,7 @@ touch npm
|
|||||||
chmod +x npm
|
chmod +x npm
|
||||||
|
|
||||||
message=$(nvm_check_global_modules)
|
message=$(nvm_check_global_modules)
|
||||||
[ -z "$message" ] || die "nvm_check_global_modules should have not printed a notice when npm was unavailable"
|
[ -z "$message" ] || die "nvm_check_global_modules should have not printed a notice when npm was unavailable; got:\n${message}"
|
||||||
|
|
||||||
|
|
||||||
cleanup
|
cleanup
|
||||||
|
|||||||
@@ -6,3 +6,13 @@ NVM_ENV=testing \. ../../install.sh
|
|||||||
|
|
||||||
#nvm_do_install is available
|
#nvm_do_install is available
|
||||||
type nvm_do_install > /dev/null 2>&1 || die 'nvm_do_install is not available'
|
type nvm_do_install > /dev/null 2>&1 || die 'nvm_do_install is not available'
|
||||||
|
|
||||||
|
FILE_PATH="$(pwd)/nvm_do_install"
|
||||||
|
echo $FILE_PATH
|
||||||
|
$(NVM_DIR="${FILE_PATH}" nvm_do_install >/dev/null 2>&1)
|
||||||
|
EXIT_CODE=$(echo $?)
|
||||||
|
[ "${EXIT_CODE}" = '1' ] || die "nvm_do_install should fail if NVM_DIR is a file: expected 1, got <${EXIT_CODE}>"
|
||||||
|
|
||||||
|
ACTUAL="$(NVM_DIR="${FILE_PATH}" nvm_do_install 2>&1)"
|
||||||
|
EXPECTED="File \"${FILE_PATH}\" has the same name as installation directory."
|
||||||
|
[ "${ACTUAL}" = "${EXPECTED}" ] || die "got <${ACTUAL}>, expected <${EXPECTED}>"
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ out=$(nvm_source "anything" 2>&1 >/dev/null) || : #Saving the process here
|
|||||||
[ -z "$out" ] && die "nvm_source with invalid parameter should error out"
|
[ -z "$out" ] && die "nvm_source with invalid parameter should error out"
|
||||||
|
|
||||||
#nvm_source should always return NVM_SOURCE no matter the parameters
|
#nvm_source should always return NVM_SOURCE no matter the parameters
|
||||||
NVM_SOURCE="my_location"
|
export NVM_SOURCE="my_location"
|
||||||
out=$(nvm_source)
|
out=$(nvm_source)
|
||||||
[ "_$out" = "_my_location" ] || die "nvm_source without arguments should have returned \$NVM_SOURCE. Got \"$out\""
|
[ "_$out" = "_my_location" ] || die "nvm_source without arguments should have returned \$NVM_SOURCE. Got \"$out\""
|
||||||
out=$(nvm_source "git")
|
out=$(nvm_source "git")
|
||||||
|
|||||||
5
test/mocks/uname_linux_armv8l
Executable file
5
test/mocks/uname_linux_armv8l
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
if [ "_$1" = "_-m" ]; then
|
||||||
|
echo "armv8l"
|
||||||
|
else
|
||||||
|
echo "Linux 3.18.14-14721103 #1 SMP PREEMPT Thu Mar 5 20:35:37 KST 2020 armv8l armv8l armv8l GNU/Linux"
|
||||||
|
fi
|
||||||
Reference in New Issue
Block a user