- 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
Sounds like an old legacy app at our company that uses dBase files. When the thing you want to search for has no index, it's time to iterate record by record (as SQL isn't available).
Admin
...to clarify since that sounds weird, the API used for accessing the xBase files is procedural calls, no SQL. If it was FoxPro, ODBC, or something, yes SQL would be available. I wasn't saying you can't use SQL on xBase tables.
Admin
Sounds like its time to find a new contract.
Admin
This is the point where you frankly just say "go fuck yourself".
Admin
Translation: "Don't EVER make me look bad again by going in and fixing code only a moron like myself would write! My appearance as a great developer is much more important than actually getting things accomplished!"
Sadly, I've had a few encounters like this; fix a problem that was holding up a lot of work, and the problem being someone higher than me wrote crappy code, only to get scolded for "not consulting with me" or "possibly screwing something up". And of course pointing out it was already really screwed up only made them more angry.
Admin
And if I'm reading this correctly, after pulling down millions of rows, and iterating through them, finding the target on, say the 12,384th pass through the loop, doing whatever SendItemToTransmitter does ... It keeps going the rest of the way through the millions of rows. Or was that just a feature of the anonymo ... anonymiz .... the process of making it anonymous?
[Note from Alex: Good obvservation. The code is more of a representation/simplification of what it would have looked liked (Ivan didn't save the original) -- but perhaps that's why the nephew didn't notice the bug? He looked for Item 0000001, while the screw is Item 9999901?]
Admin
Ouch. I hope that was more of a braindead moment than something he would do normally
Admin
Nah, just charge the 1D-10-T tax.
Admin
In my experiance in situations like this, yes it is something he would do normally. The problem then becomes caused by the contractor for working unauthorized hours. The time the contractor started and time the problem occured is not released to the higher ups so this fallacy does not become apparent. It is also stated that the contractor was lucky to get the system back on line.
Remember the first rule of contracting, you are the disposible one.
Admin
That is the short answer, but to be a little more verbose...
This programmer has proved himself to be a liability to his boss. The boss who knowingly hires and retains people who know more than themselves are few and far between. It is time to move on.
Admin
Nah, it wasn't him that wrote the code.. It was the other cousin. Remember ... two cousins.. Yeah.
Admin
My usual response to this: Fine I'll go roll back the change. They immediatly stutter. Of course 5 seconds later I quit, but never have they rolled back the change.
Admin
This might be my favorite WTF ever.
Aside from this website, which is more and more becoming a WTF. Why the crap don't you use some standard blog technology instead of this weird hacked-up forum with captchas and ads shoehorned in?
Admin
So the title is misleading. The screw was not missing, just delayed. Ivan was totally screwed when he got in the next morning.
Admin
That's when you tell them that you included code that checked for today's date. So the same problem could occur again tomorrow morning. No problem then, the system will revert to its intended operation at midnight.
Admin
What better way to demonstrate WTF in action than to have your site loaded with WTFery?
Admin
Yeah, welcome to my world.
It's now to the point where the project manager won't reply to my emails and only speaks in Mandarin.
I get paid either way.
Admin
The WTF goes deeper than that, my friend. After looping through the recordset and finding the record with the correct item ID, THE ENTIRE RECORDSET is passed into the function. No global variable is set and no other parameter is passed to let that function know which record to use. Presumably, SendItemToTransmitter loops through the entire recordset AGAIN.
WTF indeed.
Admin
Translation: Nephew Daryl and the other nephew Daryl didn't want to get out of bed.
Admin
I actually almost clicked the 'Report Abuse' link on this post... because, obviously, Ivan was abused.
I'd apologize to the boss, roll back the fix, and walk out.
Admin
Given the rest of the code, my guess is that "Call SendItemToTransmitter(rsStock)" throws an exception when it works! That way they got out of the loop.
Admin
Aparently, you are not familiar with passing by reference, are you? the entire recordset is not sent anywhere, just a pointer. And a recordset has a "currentRecord" concept, so the current record is available to the function. Passing a recordset object to a function is very, very common and much preferable to using global variables, which is generally considered poor programming style.
Not understanding basic concepts like this is often how many WTF's are born ...
(edited to fix some typos)
Admin
Or they may have even been brothers. We only know that they were both nephews of the CTO.
Admin
Nope. Anyone who has done contracting saw this coming. The correct reponse is to look contrite, apologize, and add the time spent getting criticized to your bill.
Admin
Nail, meet head. This is the LEAST wtf-ish aspect of the post.
Admin
You don't see the calling function so you cannot assume that they where smart enough to use byref. Visual basic defaults to byval passing.
also, upgrade to Firefox 2.0 it has built in spell checking, cause you still have that word spelled wrong.
Admin
How many of TDWTFs go back to the core problem of nepotism. It might as well be a captcha ;-) Whenever a sentence starts with, "He searched high and low to find the most qualified people..." you know he finds a blood relative. When will companies learn.
Captcha: perfection.
Admin
Are you sure you want to be the spelling police, there, chief? :)
Admin
As a contracter once, I got fired for not coming in for the 2am wake up call.
-Adam
Admin
i kept waiting for the "but i got there and all they really needed was to find a screw for the case for one of the servers they had opened up." that would've been classic.
Admin
This, more than anything else, is the mark of an amateur.
Admin
Which is exactly what the database engine would do anyway, SQL or not.
Admin
I actually read it more as "Oh, shit, this guy's been looking at my WTF-ridden code. He might figure out what a loser I am, and I can't have that happening!"
But they may be functionally equivalent.
Admin
Sounds like a fabulous response, and I'll have to keep it in mind in case I'm ever in a situation like this. The one problem: it only works if the client is using source control, which is not a given in WTF-prone workplaces.
Admin
I beg to differ.
Far from truth.
(Emphasis added) Must be a hell of a warehouse. The warehouses I know (and I know a few of them) contain between 5K and 200K stock items.
Admin
I can beat that.
I worked for a book publisher, on a system to keep track of book "adoptions". Big big project. This program was for sales, editorial, and management. You could tell it which book you were interested in, for which particular sales region, and it would tell you all the opportunities for that area. I did the initial design, a little bit of tuning, then left it with the contractors (and I have another story about them for another time) to build the front-end, take the credit, etc. After all, they were "the SQL Experts".
It came out. And it was slow. Gods, was it slow. It would run for hours to get details - and while people were fine with that, "could you make it just a little faster"? So I went looking. Turns out it would take half an hour for each criteria or member thereof. One school & 1 book? Half an hour. Two schools and 1 book? An hour. 50 Books and 50 Schools...
Crud. So I went through and tuned some more. Got it down to 7 minutes, since _this_ was the report that mattered, as opposed to the other ones which I had been told were more important during the design phase.
Seven minutes was better, but I still couldn't figure out why it took so long (the main table wasn't terribly large), so I went and spoke with our inhouse web guy.
It took him about 30 seconds to spot the problem in the code. The contractor's code would do a "select *" on each table involved, join them manually (by slamming them together), and then check to see if it met the criteria. Our web guy estimated it would run 2 million times for 1 book for 1 store.
He changed the VB code to include the criteria in the select clause, and we went to a flat 2 seconds per query. And for once, we were heroes. See? A WTF with a happy ending!
Admin
This is one of the few things that made me glad the company folded a few weeks later…
Admin
he he , posts like this crack me up ... yep, you got me. boy, am I embarrassed.
By the way, I know the topic is proper spelling and grammar on internet forums, but if I can go on a tangent, I might point out that you are STILL wrong: a) due to the usage of the recordset class, we can be sure this is pre .NET, with byRef as default, and more imporantly b) passing object variables by value still results in just passing a reference to the object, not the actual binary data stored with the object. You can't make the variable passed in point to a different object, but you can still access and change the calling object.
Admin
If the site seems slow, it's because it's being farked:
http://forums.fark.com/cgi/fark/comments.pl?IDLink=2479038
Admin
Actually, VB defaults to ByRef.
Admin
Dumb: "SELECT * FROM [Inventory]"
Dumber: Using the above query when you're looking for only one row
TheDailyWTF: Reading through all the way until EOF for every single query regardless of whether or not the row you need has been found already
Admin
I'm farkblocked. What has been deemed worthy of fark attention?
Admin
If it were me..... after getting sh!t for saving the day I would have said "No problem I will never come in again in an emergency" Then I would have gone in and undone the fix and would refuse to offer any insight if asked on how to solve this timing out problem.
Admin
They could speed things up by purchasing more "robust" servers. If it was just failing on a timeout, just change the web server config to increase the script timeout.
Geez, this stuff is easy.
Admin
The contractor got what he deserved, it seems to me. The problem appeared to be caused by a last-minute untested change, but he thinks his own ad-hoc change is infallible. Fixing code in emergency mode is risky, fixing someone else's code even more so. He should have got the warehouse going in as conservative a way as possible.
IMO, minimum risk would be to (1) do an inquiry (using SQL admin tools if necessary) to find the part, (2) advise the warehouse to pick it and ship it without system involvement, if necessary -- there's always a way, (3) advise the warehouse to do whatever inventory and billing adjustments were necessary the following day once authorized coders knew of the work-around, and (4) write up a quick summary of this work-around to submit to the boss the next day.
Some adjustment to this 4-step program might be needed if it seemed that the system would be hanging repeatedly through the night on other parts, but in this particular emergency situation, the principle of minimizing risk seems to trump the principle of minimizing work.
If he plays it that way, likely he doesn't even get reamed for unauthorized hours.
Admin
Ivan put his manager's dick in the dirt. Of course he got reamed for it. Showing up your boss usually doesn't end well. And neither does trying to avoid stepping on his toes. It's a no-win situation.
Admin
I would bet my paycheck that he tested versus a developmental database that had 100 or so rows in it. Since it worked fine there, roll it out and roll on out of there.
Admin
The neural network water system from a few days back.
Admin
<i>Fixing code in emergency mode is risky, fixing someone else's code even more so. He should have got the warehouse going in as conservative a way as possible.</i>
Have to agree on that. Here's my analogue WTF.
Working as a contractor, got called in to fix a little problem with a VB app that a software vendor had sold to a major online brokerage firm. It had been written by really bright guy who'd just finished his MBA, but who had actually never been exposed to programming. To give him credit, he actually produced something that, while clunky and confusing, mostly worked without blowing up.
Every month, the brokerage used the app's batch import feature to add 100,000 to 200,000 customer records to their SQL Server db. The problem was that even though they had let this process run continuously for up to 10 consecutive days, it had never completed and when they finally aborted it, no records were actually imported.
Same kind of deal. The app looped through the import file, built a single new record and then opened up a new connection to insert just that record, never disposing any connections.
The vendor didn't want their customer to think they'd sold them a messed up app, so they wouldn't let me fix the VB app. I wrote them a separete 'optimized batch processor' app that fixed the problem and they cheerily sold it the sucker--I mean client.
Admin
You're kidding, right? Even in VB.NET (or VB6) when is it _ever_ appropriate to do garbage like that? This mentality of coding by banging the keyboard repeatedly until it compiles is a plague that infects all sorts of system. Although I do agree that using a global variable is bad, so it passing a recordset back and forward. Write in _one_ place the method to obtain an item by ItemId.
By the way, I once inherited a C# system where the people who originally coded it "didn't like this new ADO.NET thing" and wrote their own "data layer" which wrapped up ADO.NET and put a record cursor on it so it worked exactly like Recordset. Then they inherited this object into "business object" where they added additional methods to do "business functions". The whole thing was a huge unmaintainable piece of garbage that I did my best to keep running, while suggesting that if their current code couldn't support 10 simultaneous users then perhaps trying to sell to organisations with predicted 100000 simultaneous users is probably not a good idea. It ended up in a very similar situation to this where I fixed something very similar to this WTF, and then got told off for fixing it. My reaction was "Fuck off" and I walked out the door and had a job offer elsewhere by the end of the day. To this day that company are still struggling with that pile of crap.