Same boat: people who hate typescript and therefore ensuring type safety probably also hate unit tests because they are too inconvenient to awesome rockstar developers.
One hundred percent this. It reeks of the kind of ego you get from devs that think their code is so perfect it's inherently easily maintainable.
I know junior devs that don't struggle with types and unit testing—any dev that thinks they're too good for either is immediately sub-junior in my assessment, because they're clearly unable to write code intended to be maintained by a team.
Lmao I’ve literally had conversations with people who have asked me to not be as rigorous with unit tests because you have to change some tests when you make a modification to the business logic.
I know you're joking, but this isn't even true. The feedback loop that you get from pre-written tests in watch mode is pretty much instantaneous. This helps me to arrive at the correct solution much more quickly than trying to validate each case as I go.
I love unit tests but I hate the eternal struggle behind them.
We should make unit tests so we can tell when the build runs that the app is going to be consistent
Everyone cheers
We lose a sprint setting up unit tests
Oh this one test just went yellow, somebody spends a few hours figuring it out and finds that it's a bug in the unit test. No no we're good That's just a bug in the unit test we'll plan to fix that in the next Sprint.
Oh look now this unit test is going red we're blocked. 2 hours later they find out that it's a real problem but it's not so bad that it overrides current feature work. Well we're going to need to override that and we'll have to fix it in the next sprint.
Unit test failures slowly degrade in priority to try to get feature work done. You end up with a backlog full of yellow and red known problems and no one pays any attention to you that tests anymore.
I think it’s more of a JSDoc > TS thing. I need to check the drama, but I don’t believe anyone would want to write vanilla JS without some type declarations..
Honestly I'm surprised Microsoft isn't pushing for that already. They already have a decently popular browser (Edge), they own TS, and they have a history with not giving a shit about standards (IE and ActiveX).
I feel like (and it was created by Microsoft which would support this) the purpose of TypeScript is to make web development palatable for C#/C++/Java developers.
If I'm writing a Go app with a JS frontend component but then I decide to use Typescript, suddenly I have NPM, Node, and realistically probably some JS build system like Grunt as dependencies of my project.
Basically, it just adds more moving parts to the project when I could get away with a) a simpler build process and b) less separation between me and the browser.
To be fair, I've never used TypeScript, but this is what's kept me from using TypeScript.
For your Go code to be useful, you've got to set up the Go compiler right?
As much as I wouldn't recommend it, you can even install the typescript compiler via an OS package manager (at least in most Debian distributions)
At that point (and once you've added it to your makefile, or however else you're triggering your go build), surely then there's zero additional moving parts needed to compile your front end vs your backend?
Not least of all, I'd argue having a compiler tell me I messed up immediately is a bonus too vs poking around for some time until I get an error in the JS console
I'm definitely not saying I don't know how I'd go about adding TypeScript to my build process if I wanted to. (Though I might should mention that I don't usually use any build system that isn't just straight up part of the Go compiler. go generate specifically.) But it's one more thing (actually at least 2 more things -- the TypeScript compiler and Node, and that's if you're not counting the package manager) that I'd need to keep up to date and hunt down backwards incompatible changes or bugs when updating breaks my build.
There are dependencies that are pretty much absolutely necessary (the compiler or interpreter, depending on language, obviously), and if you need a feature badly enough that in practice isn't worth writing yourself (and isn't in the standard library), but beyond that you just kindof have to evaluate what dependencies are worth adding and what aren't. I definitely fall on the side of eschewing dependencies in most optional situations just because adding dependencies willy-nilly has burned me so many times (though I do usually do JS/HTML/CSS minifying).
Meanwhile, build-time type safety isn't a substitute for (automated and/or manual) testing. And whether the benefits of build-time type safety are worth the drawbacks of having TypeScript/Node/whatever is a calculation everyone has to do. Plus, let's be honest, there are plenty of other dependences one could add for which the argument is at least as strong as for TypeScript. If you're using TypeScript, then why not jQuery and Vue and Underscore and Handlebar and Backbone and Grunt and Require and Bower and most importantly these seven jQuery plugins etc? In proactice the alternatives aren't so much "basically no JS-related dependencies" vs "basically no JS-related dependencies other than TypeScript." They're more "basically no JS-related dependencies" vs "a veritable menagerie of JS dependencies."
What I'm going for here is also about opting out of the samsara that is the ever changing fashion-of-the-week in JS development. And about the only way to do that is to just opt not to use JS dependencies. (Not to say one would have to be absolutist about it. You could say "TypeScript and that's all," but if you're drawing a line, why not draw it one dependency earlier?)
You are making a lot of false assumptions about typescript and bringing in a lot of outside problems that don't have anything to do with the language. Try working with typescript. It is a strict super set of javascript. So if you like vanilla JS, you can just keep writing it, then slowly introduce the syntactic sugar that typescript provides. I did the javascript and coffee script thing for a long while, and typescript is just the better way for most use cases at this point.
problems that don’t have anything to do with the language.
My concerns about it don't have anything to do with the language. More the tooling that would come with it.
If browsers natively understood TypeScript, I'd use the type-safety features. But I don't want things like the TypeScript compiler or Node to be a dependency of my build process. Not if the only payoff is type safety.
I usually write Typescript with Vue and SSR so my server and client are using the same tooling. If I was writing a basic frontend with minimal JavaScript I would just (and have) use jsdoc for typing.
But let's be fair, what you mentioned as dependencies are development dependencies and don't impact the end user (outside of poorly optimized build systems causing issues). Build systems can have some great benefits. Such as reducing file size by utilizing methods such as tree shaking to prune out the unused classes in a CSS library.
It just comes down to choosing the tools to suit the job. Sure, you can use a table saw to cut a stick but it's probably easier just to use a handsaw. Whereas if you're cutting a large plywood board you could make do with a handsaw but it'll take longer and the result might not be pretty.
They do if I the developer am spending time maintaining my dependencies rather than implementing feature X that the end user wants.
Build systems can have some great benefits.
As does not having multiple distinct yet interacting build systems in one project.
unused classes in a CSS library.
I have yet to have a use for any CSS libraries. Maybe that has more to do with the problem domain in which I write than anything. Maybe some day I'll run into a situation where I feel I'd be better served using a CSS library, but it hasn't happened yet.