- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
first
Admin
We have a joke on out team, whoever uses the blame tool only ever finds out that they were the one who committed the bad code.
Admin
Technically the last one is not a "Fail".... The resultant value will be globally unique and can be used as an identifier, even though it does not conform to the 128 bit number format...
Admin
The first one looks more like a bit of a brain fart. Perhaps the block previously had other bits in too, which were later deleted and only the assert remained.
I've also done/seen
Assert.True(false)
in the absence ofAssert.Fail()
or in an "impossible" arm of a largematch
block.Admin
And then here's me not reading the title or even the first paragraph.
Admin
TRWTF is that they mention the function
generateUUID()
, but then post the functiongenerateGUID()
.Admin
I've written code like the first one only last week! Mine was of the form:
The idea here is to put a breakpoint on the assert, which allows you to step into foo() only if it is known to fail.
Admin
If only modern IDEs allowed you to set conditional breakpoints...
Admin
So, what's the opposite of 'cerebral flatulence'? 'sigmoid colonic cogitation'?
Admin
Conditional breakpoints are orders of magnitude slower than an if statement. If you're going to hit it a lot, sometimes you have no choice but to alter the code, or your timing gets corrupted to the point of being unusable, especially on embedded systems.
Admin
My first thought on the last one is that the developer responsible didn't trust that UUIDs are actually UUIDs and so they added this clever "guarantee" part at the end of it.
Admin
Sigmoid Colonic Cogitation = management
Admin
Remy, where are the unicorns today?
Admin
So "he who smelt it, dealt it" applies to brain farts too?
Admin
So you're using one of the half-dozen languages that has a full-featured bells-and-whistles IDE built specifically for it? Congratulations.
Admin
I don't know on what platform you're working, so this may not be available, but on macOS and windows there are calls to break into the debugger.
Admin
The last one isn't generating UUIDs, its generating GUIDs... And they seem to contain meatsack readable information, so I'd wager a guess that it's for ease of tracking down problems from log entries. And they are also still perfectly unique, but with added information. They also don't need to follow a UUID format, since it's not a UUID.
I wouldn't quite count that as a brain fart on the side of the code author, but rather on the side of the code reader and blog post author.
Admin
I am the guy that submitted the last one ... the code 'worked' but it was completely useless I just noticed it was showing up as a uuid column of our audit table (tracks event logs). That already has a unique id (primary key of the database) but this developer has this method to generate a uuid .. with this method that for some reason makes it 'more unique' by adding the server name (auditlog.getContext) and time. The Context and request time that is appended to this ... are already part of the auditLog data that gets persisted to the table ... it is just weird and redundant (the author user has many such entries in our code base)
Admin
I am the guy that submitted the last one ... the code 'worked' but it was completely useless I just noticed it was showing up as a uuid column of our audit table (tracks event logs). That already has a unique id (primary key of the database) but this developer has this method to generate a uuid .. with this method that for some reason makes it 'more unique' by adding the server name (auditlog.getContext) and time. The Context and request time that is appended to this ... are already part of the auditLog data that gets persisted to the table ... it is just weird and redundant (the author user has many such entries in our code base)