Non-deterministic behavior of npm - node.js

After running npm install, I have noticed that sometimes package-lock.json changes.
This section:
"dependencies": {
"websocket": {
"version": "git://github.com/frozeman/WebSocket-Node.git#6c72925e3f8aaaea8dc8450f97627e85263999f2",
"from": "git://github.com/frozeman/WebSocket-Node.git#6c72925e3f8aaaea8dc8450f97627e85263999f2",
"requires": {
"debug": "^2.2.0",
"nan": "^2.3.3",
"typedarray-to-buffer": "^3.1.2",
"yaeti": "^0.0.6"
}
}
}
}
Changes to this:
"dependencies": {
"websocket": {
"version": "git://github.com/frozeman/WebSocket-Node.git#6c72925e3f8aaaea8dc8450f97627e85263999f2",
"from": "git://github.com/frozeman/WebSocket-Node.git#6c72925e3f8aaaea8dc8450f97627e85263999f2",
"requires": {
"debug": "^2.2.0",
"nan": "^2.3.3"
}
}
}
}
And when that happens, I get a runtime error:
module.js:538
throw err;
^
Error: Cannot find module 'typedarray-to-buffer'
at Function.Module._resolveFilename (module.js:536:15)
at Function.Module._load (module.js:466:25)
at Module.require (module.js:579:17)
at require (internal/module.js:11:18)
at Object.<anonymous> (C:\Users\...\node_modules\web3-providers-ws\node_modules\websocket\lib\W3CWebSocket.js:18:16)
at Module._compile (module.js:635:30)
at Object.Module._extensions..js (module.js:646:10)
at Module.load (module.js:554:32)
at tryModuleLoad (module.js:497:12)
at Function.Module._load (module.js:489:3)
After some debugging, this error is for require("web3") in my code.
Here is the relevant section in my package.json file:
"devDependencies": {
"chai": "^4.1.2",
"chai-as-promised": "^7.0.0",
"bignumber.js": "^7.0.0",
"decimal.js": "^10.0.0",
"web3": "1.0.0-beta.34",
"ethereumjs-testrpc-sc": "6.1.2",
"ganache-cli": "6.1.0",
"solidity-coverage": "0.4.14",
"truffle": "4.1.3"
}
How can I resolve this, and why does npm work differently from time to time?

Related

NodeJS - TypeError [ERR_INVALID_ARG_TYPE]: The “path” argument must be of type string. Received undefined (mkdirp module nodejs)

I have a Node/Angular project that won't run because of this error. I am getting the following error:
TypeError [ERR_INVALID_ARG_TYPE]: The "path" argument must be of type string. Received undefined
More context for that error:
PS C:\Users\Vinay\retail-billpay-node> node server
internal/validators.js:124
throw new ERR_INVALID_ARG_TYPE(name, 'string', value);
^
TypeError [ERR_INVALID_ARG_TYPE]: The "path" argument must be of type string. Received undefined
at validateString (internal/validators.js:124:11)
at resolve (path.js:139:9)
at pathArg (C:\Users\Vinay\retail-billpay-node\node_modules\mkdirp\lib\path-arg.js:15:10)
at mkdirp (C:\Users\Vinay\retail-billpay-node\node_modules\mkdirp\index.js:10:10)
at Object.<anonymous> (C:\Users\Vinay\retail-billpay-node\app\helpers\winston.js:26:3)
at Module._compile (internal/modules/cjs/loader.js:1063:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:1092:10)
at Module.load (internal/modules/cjs/loader.js:928:32)
at Function.Module._load (internal/modules/cjs/loader.js:769:14)
at Module.require (internal/modules/cjs/loader.js:952:19)
at require (internal/modules/cjs/helpers.js:88:18)
at Object.<anonymous> (C:\Users\Vinay\retail-billpay-node\app\services\LogService.js:9:17)
at Module._compile (internal/modules/cjs/loader.js:1063:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:1092:10)
at Module.load (internal/modules/cjs/loader.js:928:32)
at Function.Module._load (internal/modules/cjs/loader.js:769:14) {
code: 'ERR_INVALID_ARG_TYPE'
}
And here is my package.json if it helps:
{
"name": "retail-billpay-node",
"version": "1.0.0",
"description": "start your node express app from this boilerplate code",
"main": "server.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "siddhant-np",
"license": "ISC",
"dependencies": {
"async": "2.6.1",
"bluebird": "3.5.3",
"body-parser": "1.18.3",
"crypto": "1.0.1",
"csvtojson": "2.0.8",
"dotenv": "6.0.0",
"express": "4.16.3",
"extract-zip": "1.6.7",
"imap-simple": "4.3.0",
"ioredis": "4.6.2",
"kafka-node": "^5.0.0",
"lodash": "4.17.10",
"md5": "2.2.1",
"mkdirp": "0.5.1",
"moment": "2.22.2",
"moment-timezone": "0.5.21",
"mongoose": "5.2.9",
"nodemailer": "5.1.1",
"otp.js": "1.1.0",
"request": "2.87.0",
"util": "0.11.1",
"winston": "3.0.0",
"winston-daily-rotate-file": "3.2.1",
"xlsx": "0.14.1",
"xml-parse": "0.3.1",
"xml2js": "0.4.19",
"xmlbuilder": "10.0.0"
}
}
OK, I figured out the issue. I thought the error was telling me that path was undefined. When it fact it was saying the variables passed into path.join() were undefined. And that was because I forgot to add my .env file to the root so it could grab those variables.
Since it was an enterprise project so they don't keep .env file in the source code, I asked them and put it root.

heroku host with eris

i want to host a discord bot using eris but every time i have a problem that tell me eris isn't install i have this error
Error: Cannot find module 'eris'
at Function.Module._resolveFilename (internal/modules/cjs/loader.js:581:15)
at Function.Module._load (internal/modules/cjs/loader.js:507:25)
at Module.require (internal/modules/cjs/loader.js:637:17)
at require (internal/modules/cjs/helpers.js:22:18)
at Object.<anonymous> (/app/bot.js:1:76)
at Module._compile (internal/modules/cjs/loader.js:689:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:700:10)
at Module.load (internal/modules/cjs/loader.js:599:32)
at tryModuleLoad (internal/modules/cjs/loader.js:538:12)
at Function.Module._load (internal/modules/cjs/loader.js:530:3)
and this the package.json file that i use i change to many files many times
{
"name": "manarceus",
"description": "project",
"version": "0.0.0",
"main": "bot.js",
"scripts": {
"start": "node bot.js"
},
"dependencies": {
"discord.js": "^11.3.2",
"discord.js-musicbot-addon": "^1.10.3",
"express": "^4.16.3",
"finalhandler": "^1.1.1",
"fortnite": "^3.0.0",
"fs": "^0.0.2",
"hastebin-gen":"1.3.1",
"canvas": "^1.6.11",
"giphy-api": "1.2.7",
"math-expression-evaluator":"1.2.17",
"common-tags":"1.7.2",
"zalgolize":"1.2.4",
"eris":"0.8.5",
"quick.db":"6.3.1",
"google-translate-api":"2.3.0",
"ascii-data-table":"2.1.1",
"array-sort": "1.0.0",
"table": "4.0.3",
"dateformat":"3.0.3",
"jimp":"0.2.28",
"get-youtube-id": "^1.0.0",
"moment": "^2.22.1",
"ms": "^2.1.1",
"goo.gl":"0.1.4",
"figlet":"1.2.0",
"google-it":"1.1.1",
"node-opus": "^0.2.7",
"opusscript": "0.0.6",
"python": "0.0.4",
"request": "^2.85.0",
"hypixel-api" : "1.0.0",
"router": "^1.3.2",
"snekfetch": "^3.6.4",
"sqlite": "^2.9.1",
"youtube-info": "^1.2.0",
"ytdl-core": "^0.20.2",
"ffmpeg": "0.0.4",
"pretty-ms": "3.1.0",
"ffmpeg-binaries": "^3.2.2-3",
"simple-youtube-api": "^5.0.2"
}
}
and i try to run commands to install eris too
any help

Error: Cannot find module 'babel-core/register'

I have following error when trying to run my app on Heroku
Error: Cannot find module 'babel-core/register'
2017-11-13T10:42:19.749689+00:00 app[web.1]: at Function.Module._resolveFilename (module.js:469:15)
2017-11-13T10:42:19.749690+00:00 app[web.1]: at Function.Module._load (module.js:417:25)
2017-11-13T10:42:19.749691+00:00 app[web.1]: at Module.require (module.js:497:17)
2017-11-13T10:42:19.749691+00:00 app[web.1]: at require (internal/module.js:20:19)
2017-11-13T10:42:19.749692+00:00 app[web.1]: at Object.<anonymous> (/app/bootstrap.js:1:63)
2017-11-13T10:42:19.749692+00:00 app[web.1]: at Module._compile (module.js:570:32)
2017-11-13T10:42:19.749693+00:00 app[web.1]: at Object.Module._extensions..js (module.js:579:10)
2017-11-13T10:42:19.749694+00:00 app[web.1]: at Module.load (module.js:487:32)
2017-11-13T10:42:19.749694+00:00 app[web.1]: at tryModuleLoad (module.js:446:12)
2017-11-13T10:42:19.749695+00:00 app[web.1]: at Function.Module._load (module.js:438:3)
My package.json file is:
{
"name": "birdbase",
"version": "1.0.0",
"devDependencies": {
"babel-core": "^6.26.0",
"babel-loader": "^7.1.2",
"babel-preset-es2015": "^6.18.0"
},
"dependencies": {
"babel-register": "^6.26.0",
"babel-core": "^6.26.0",
"babel-loader": "^7.1.2",
"babel-preset-es2015": "^6.18.0",
"bell": "^8.7.0",
"hapi": "^16.0.1",
"hapi-auth-jwt": "^4.0.0",
"jsonwebtoken": "^8.1.0",
"knex": "^0.14.0",
"mysql": "^2.14.1",
"node-uuid": "^1.4.8"
},
"scripts": {
"start": "node bootstrap.js"
}
}
and my app is based on the following tutorial:
https://scotch.io/tutorials/making-a-restful-api-with-hapi-js
src: https://github.com/labsvisual/hapijs-birds-api
So package.json dependencies are same as in devDependencies (as was indicated on other Stack Overflow issues).
Any idea why there is an error?

node.js app azure deployment from bitbucket

I am getting following error when i try to deploy nodejs app from bitbucket.
Command: "D:\home\site\deployments\tools\deploy.cmd"
Handling node.js deployment.
KuduSync.NET from: 'D:\home\site\repository' to: 'D:\home\site\wwwroot'
undefined:38
}
^
An error has occurred during web site deployment.
SyntaxError: Unexpected token } in JSON at position 1090
at Object.parse (native)
at Object.<anonymous> (D:\Program Files (x86)\SiteExtensions\Kudu\63.60712.2926\bin\Scripts\selectNodeVersion.js:179:44)
at Module._compile (module.js:570:32)
at Object.Module._extensions..js (module.js:579:10)
at Module.load (module.js:487:32)
at tryModuleLoad (module.js:446:12)
at Function.Module._load (module.js:438:3)
at Module.runMain (module.js:604:10)
at run (bootstrap_node.js:394:7)
at startup (bootstrap_node.js:149:9)
undefined:38\r\n}\r\n^\r\n\r\nSyntaxError: Unexpected token } in JSON at position 1090\r\n at Object.parse (native)\r\n at Object.<anonymous> (D:\Program Files (x86)\SiteExtensions\Kudu\63.60712.2926\bin\Scripts\selectNodeVersion.js:179:44)\r\n at Module._compile (module.js:570:32)\r\n at Object.Module._extensions..js (module.js:579:10)\r\n at Module.load (module.js:487:32)\r\n at tryModuleLoad (module.js:446:12)\r\n at Function.Module._load (module.js:438:3)\r\n at Module.runMain (module.js:604:10)\r\n at run (bootstrap_node.js:394:7)\r\n at startup (bootstrap_node.js:149:9)\r\nD:\Program Files (x86)\SiteExtensions\Kudu\63.60712.2926\bin\Scripts\starter.cmd "D:\home\site\deployments\tools\deploy.cmd"
Using node 6.9.1
package.json
{
"name": "example",
"version": "1.0.0",
"description": "REST APIs for example",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"repository": {
"type": "git",
"url": "git+abc"
},
"author": "abc",
"license": "ISC",
"homepage": "abc#readme",
"dependencies": {
"azure-storage": "^2.1.0",
"body-parser": "^1.17.1",
"change-case": "^3.0.1",
"dateformat": "^2.0.0",
"dotenv": "^4.0.0",
"express": "^4.15.2",
"jsonwebtoken": "^7.3.0",
"minimist": "^1.2.0",
"morgan": "^1.8.1",
"mssql": "^4.0.1",
"multer": "^1.3.0",
"nconf": "^0.8.4",
"node-friendly-response": "^3.1.4",
"request": "^2.81.0",
"require-dir": "^0.3.1",
"swagger-node-express": "^2.1.3",
"tedious": "^2.0.0",
"tedious-promises": "^0.4.1",
"underscore": "^1.8.3",
"winston": "^2.3.1"
}
}
Is it because of the node modules which i have used?
Or is it the problem during the loading of modules?
It seems that your package.json is not a valid JSON.
Update:
Kudu uses the following code to read the package.json file, see line 179 of selectNodeVersion.js.
json = existsSync(packageJson) && JSON.parse(fs.readFileSync(packageJson, 'utf8'));
So, before you push the package.json to github, you can use the code below to verify the file on your local:
var fs = require("fs");
var json = JSON.parse(fs.readFileSync("./package.json", 'utf8'));
console.log(json);
For example, I added one more } at line 38 in package.json your provided above, I would get the same error as yours:
Or you can just use the command npm install to check it:

Webpack Breaks Mocha in Node.js App

I have a node.js app that uses Mocha and Expect for testing. All the tests work great, until I installed webpack for react. Now when I run "npm test" I get the following error:
Error: Cannot find module 'should'
at Function.Module._resolveFilename (module.js:469:15)
at Function.Module._load (module.js:417:25)
at Module.require (module.js:497:17)
at require (internal/module.js:20:19)
at Object.<anonymous> (C:\Users\Brian\version-control\tysons-tech-map-redone\node_modules\watchpack\test\DirectoryWatcher.test.js:2:1)
at Module._compile (module.js:570:32)
at Object.Module._extensions..js (module.js:579:10)
at Module.load (module.js:487:32)
at tryModuleLoad (module.js:446:12)
at Function.Module._load (module.js:438:3)
at Module.require (module.js:497:17)
at require (internal/module.js:20:19)
at C:\Users\Brian\version-control\tysons-tech-map-redone\node_modules\mocha\lib\mocha.js:230:27
at Array.forEach (native)
at Mocha.loadFiles (C:\Users\Brian\version-control\tysons-tech-map-redone\node_modules\mocha\lib\mocha.js:227:14)
at Mocha.run (C:\Users\Brian\version-control\tysons-tech-map-redone\node_modules\mocha\lib\mocha.js:495:10)
at Object.<anonymous> (C:\Users\Brian\version-control\tysons-tech-map-redone\node_modules\mocha\bin\_mocha:469:18)
at Module._compile (module.js:570:32)
at Object.Module._extensions..js (module.js:579:10)
at Module.load (module.js:487:32)
at tryModuleLoad (module.js:446:12)
at Function.Module._load (module.js:438:3)
at Module.runMain (module.js:604:10)
at run (bootstrap_node.js:393:7)
at startup (bootstrap_node.js:150:9)
at bootstrap_node.js:508:3
npm ERR! Test failed. See above for more details.
Below is my package.json:
{
"name": "cool-map",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"start": "node server.js",
"test": "export NODE_ENV=test || SET \"NODE_ENV=test\" && mocha **/*.test.js",
"test-watch": "nodemon --exec \"npm test\""
},
"engines": {
"node": "6.2.2"
},
"license": "ISC",
"dependencies": {
"bcryptjs": "^2.3.0",
"body-parser": "^1.15.2",
"express": "^4.14.0",
"jsonwebtoken": "^7.1.9",
"lodash": "^4.15.0",
"mongodb": "^2.2.5",
"mongoose": "^4.5.9",
"validator": "^5.6.0",
"hbs": "^4.0.0",
"babel-preset-stage-0": "^6.24.1",
"express": "^4.15.2",
"react": "^0.14.7",
"react-dom": "^0.14.7"
},
"devDependencies": {
"expect": "^1.20.2",
"mocha": "^3.0.2",
"nodemon": "^1.10.2",
"supertest": "^2.0.0",
"babel-core": "^6.5.1",
"babel-loader": "^6.2.2",
"babel-preset-es2015": "^6.5.0",
"babel-preset-react": "^6.5.0",
"webpack": "^1.12.13"
}
}
I'm not sure if webpack.config is necessary to post, but just in case:
module.exports = {
entry: './app/app.jsx',
output: {
path: __dirname,
filename: './public/bundle.js'
},
resolve: {
root: __dirname,
alias: {
AdminUserTable: 'app/components/AdminUserTable.jsx'
},
extensions: ['', '.js', '.jsx']
},
module: {
loaders: [
{
loader: 'babel-loader',
query: {
presets: ['react', 'es2015']
},
test: /\.jsx?$/,
exclude: /(node_modules|bower_components)/
}
]
}
};
Running the command npm test works great when I uninstall webpack, I'm not sure why It's breaking mocha.
Your package.json is missing should as a dependency.
Install it via;
npm install --save-dev should
Also I would recommend you look into chai which in my opinion provides a slightly different API.
should is an expressive, readable, framework-agnostic assertion library. The main goals of this library are to be expressive and to be helpful. It keeps your test code clean, and your error messages helpful.
By default (when you require('should')) should extends the Object.prototype with a single non-enumerable getter that allows you to express how that object should behave. It also returns itself when required with require.
It is also possible to use should.js without getter (it will not even try to extend Object.prototype), just require('should/as-function'). Or if you already use version that auto add getter, you can call .noConflict function.
Results of (something).should getter and should(something) in most situations are the same
Better u install node dependency should with npm as below
npm install --save should
should-reference

Resources