Contrats, you have discovered why in TDD you write the test, watch the test fail, then make the test pass, then refactor. AKA: Red, Green, Refactor
Contrats, you have discovered why in TDD you write the test, watch the test fail, then make the test pass, then refactor. AKA: Red, Green, Refactor
Yeah… so… after them killing over 5,000 Palestinians, the vast majority of them civilians, everyone they could get their hands on basically, I kinda don’t trust them.
Another option is like in German where you invent some sort of new suffix like “*in”. For example, Lehrer (m), Lerhrerin (w), Lehrer*in (m/w/d). Prounounced as a sort of shorter than space silence.
Geez, feels like just this year that over 64 year olds outnumbered under 14 year olds.
I have done this too. Shit happens.
One of my co-workers used to write UPDATE
statements backwards limit then where etc, to prevent this stuff, feels like a bit of a faff to me.
Choco is pretty good but it does have less packages than say, brew.
As someone who has packaged for Mac’s with brew and RPMs and debs on Linux, packaging for windows is a total pain. Choco uses nuget 2 for self hosted repos which means you need to run a server for your packages, which there are things like the PPAs for Linux and Brew uses GitHub releases so you don’t need to host anything yourself to provide binaries.
This is also on top of windows needing extra work to develop for, because windows filesystem works differently enough to need code specially for windows. All of this means that windows users suffer on the open source software front.
How did they get the orange bit to stay orange when everything else is blackened?
Deployments and deployment frequency pretty squarely a developer’s responsibility…
This is fantastic work to an immediate problem. Thank you.
There is something amazing about someone just sharing a solution like this without expectation of anything back, and even if this isn’t the best right solution, it contributes to the global commons, and improves society.
Sure, so say so you have a requirement to add two numbers
At this point you have no implementation and you use this opportunity to confirm that the test will work, by checking it is failing how you expect. If you are pairing sometime I teach that you should call out what you expect, kinda like in American pool. Sometimes the test passed in this case, this is your opportunity to break the test and confirm it will fail (though this is often a sign you did too much work previously, and might need to check if you really are making the smallest possible change)
At this point you have only implemented the simplest possible code, this makes it really easy to spot if there is a problem with it because of some flaw in the test, and you have confirmed the it matches your test
What’s more you can confirm all, and only behaviours described in the test are implemented
Got to clean the kitchen because if we don’t clean the kitchen we will have to clean the garage and we don’t want that because it’s a bigger job.
Why this works is that the code is developed in a TDD style forces you to move in smaller steps meaning bugs are shallower when they do occur. You aren’t dealing with a 20 complex lines, you are dealing with a return const, or selection, or etc. The scope for the test being wrong is reduced and the amount of implementation is reduced, generally the tests end up more concise and smaller too and the interfaces are user friendly too because you didn’t think how do I calculate this, you thought what would be a nice way to call this.
What’s more it encourages an example driven approach that leads to developers thinking about the most sensible input data over and over again, and what that should output reducing the chance any one wrongly implemented test wouldn’t be picked up by other examples.
TL;DR, the driven word is the key, a test that is illogical will never drive you to the working code