Note about vite and checkTypes
Closed this issue · 4 comments
I found a gotcha when using sanctuary and vite, that makes sanctuary about a hundred times slower ;)
According to vite - Env Variables and sanctuary - Type checking, it looks like you automatically disable type checking when you create a vite build using npm run build
. But due to the way that vite substitute process.env.NODE_ENV
with either development
or production
and how sanctuary is detecting process.env.NODE_ENV
, you will not disable type checking!
The work-around is:
import sanctuary from 'sanctuary';
const S = sanctuary.create ({ checkTypes: import.meta.env.DEV, env: sanctuary.env });
You can not currently set process.env.NODE_ENV
manually in vite. As of writing, vite is version 2.9.6.
I wanted to create a PR for this to update the type-checking or installation section but checking that it looks good is a little more involved than I have time for currently. So this is serve as a reminder :)
BTW. I'm using latest versions of the sanctuary projects, as listed below:
"dependencies": {
"fluture": "fluture-js/Fluture#25cbb445250039ac2e1add982264670986f9df45",
"fluture-sanctuary-types": "^7.1.0",
"sanctuary": "sanctuary-js/sanctuary#72bc20ad02c5944b661efdcdd14ab60ceb92c7b3",
"sanctuary-def": "sanctuary-js/sanctuary-def#deadb523c488e8e7bbc988a662c62435be38a380",
"sanctuary-either": "sanctuary-js/sanctuary-either#18f6238f1d1e8e36d3dcdb44732255b3349eef46",
"sanctuary-identity": "sanctuary-js/sanctuary-identity#b0df277c80e562616ccd526b56a3d9af69ace56f",
"sanctuary-maybe": "sanctuary-js/sanctuary-maybe#2d14d53f939c0a81e081d93dc4bda5622ca517a1",
"sanctuary-pair": "sanctuary-js/sanctuary-pair#829187679afceec52e889f884bdc6e9b0c0d0a18",
"sanctuary-show": "^3.0.0"
},
"overrides": {
"sanctuary-type-classes": "^13.0.0",
"sanctuary-show": "^3.0.0",
},
Does the documentation need to be updated? This seems to be in line with what's documented:
There is a performance cost to run-time type checking. Type checking is disabled by default if
process.env.NODE_ENV
is'production'
. If this rule is unsuitable for a given program, one may usecreate
to create a Sanctuary module based on a different rule.
Two things that are not covered is that setting process.env.NODE_ENV
in an esm file will not carry over to sanctuary. But will remain undefined
. When using esm, environment variables really has to be an environment variable.
Second, in conjunction with vite process.env.NODE_ENV
is replaced with the string "production"
or "development"
. That should seemingly work with how sanctuary detect process.env.NODE_ENV
:
return create ({
checkTypes: typeof process === 'undefined'
|| process == null
|| process.env == null
|| process.env.NODE_ENV !== 'production',
env: $.env
});
It gets transpiled into:
pt({
checkTypes: typeof process == "undefined" || process == null || process.env == null || !1,
env: t.env
})
🤔 seems legit. I was probably bitten by using process.env.NODE_ENV = 'production'
in esm. But that would still set checkTypes
to false
. I'm honestly not sure what happen when I filed this bug report... 🤷
PS. typeof process === 'undefined'
and process == null
looks like a duplication of logic...
PS.
typeof process === 'undefined'
andprocess == null
looks like a duplication of logic...
I agree that it looks duplicative, but we cannot just use process == null
because it would fail if process
is not defined. We could make the second clause process === null
for clarity, but that is not consistent with our ESLint configuration.