Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Repoint node-memwatch to fork which supports node 18 #47

Open
wants to merge 12 commits into
base: master
Choose a base branch
from

Conversation

token-cjg
Copy link

@token-cjg token-cjg commented Sep 1, 2022

This change repoints the node-memwatch package dependency to a different fork (@airbnb/node-memwatch) which supports node 18.

Also in this change is a slight implicit change in development tooling to suggest the use of asdf (https://asdf-vm.com/), as well as a quick sweep of security vulnerabilities using npm audit fix --force.

In particular this proposed alteration should address #34.

asdf [1] is a tool for running multiple versions of different languages.
To use it one installs asdf itself, and then 'plugins'. For this case,
we will need the nodejs plugin [2].

Then, to use asdf, one runs:

```
asdf install nodejs 16.15.0
asdf reshim nodejs
```

The reshim is important, otherwise asdf won't pick up the latest
versions that have been installed for a given plugin.

To set a default version for a project one uses a .tool-versions file.

In this commit this file has been set to default nodejs to 16.15.0.

[1]: https://asdf-vm.com/
[2]: https://github.com/asdf-vm/asdf-nodejs
@aide-master/node-memwatch hasn't been updated for 3 years [1], so it
might be worthwhile exploring other forks like @airbnb/node-memwatch
that have been more recently touched.

After blowing away package-lock.json and rebuilding it with node
16.15.0, it appears that the node-gyp issue per [2] is fixed, so this
seems sufficient.

[1]: https://www.npmjs.com/package/@aidemaster/node-memwatch
[2]: andywer#34
Upon running the tests locally I noticed that after altering the
packages things failed. However CI on github is currently green.

To mitigate against this form of change management risk adding a github
action to exercise the test harness seems wise.
Since we've switched from @aidemaster/node-memwatch to
@airbnb/node-memwatch, we should update the source to reflect this.
Allows for step through debugging of tests
It appears that there is a bug in the 16.x.x series [1] that amongst
other things leads to memory leaks when attaching a memory watch process
to a noop process (i.e., () => {}).

To work around this, bump to the latest node.  18.x.x will soon be
active anyway [2], so this seems okay to do.

[1]: nodejs/node#28787
[2]: https://nodejs.org/en/about/releases/
@token-cjg token-cjg changed the title Repoint node-memwatch to fork which supports node 16 Repoint node-memwatch to fork which supports node 18 Sep 1, 2022
A previous test run failed with

"AssertionError: expected 25864 to be below 24576" [1]

This seems much of a muchness. To avoid flakes let's just increase the
margin that we're testing against a tad.

[1]: https://github.com/token-cjg/leakage/runs/8145013267?check_suite_focus=true
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant