Feed aggregator
An Electric Racecar Drives Upside Down
Read more of this story at Slashdot.
A Single Mortgage
We talked about singletons a bit last week. That reminded John of a story from the long ago dark ages where we didn't have always accessible mobile Internet access.
At the time, John worked for a bank. The bank, as all banks do, wanted to sell mortgages. This often meant sending an agent out to meet with customers face to face, and those agents needed to show the customer what their future would look like with that mortgage- payment calculations, and pretty little graphs about equity and interest.
Today, this would be a simple website, but again, reliable Internet access wasn't a thing. So they built a client side application. They tested the heck out of it, and it worked well. Sales agents were happy. Customers were happy. The bank itself was happy.
Time passed, as it has a way of doing, and the agents started clamoring for a mobile web version, that they could use on their phones. Now, the first thought was, "Wire it up to the backend!" but the backend they had was a mainframe, and there was a dearth of mainframe developers. And while the mainframe was the source of truth, and the one place where mortgages actually lived, building a mortgage calculator that could do pretty visualizations was far easier- and they already had one.
The client app was in .NET, and it was easy enough to wrap the mortgage calculation objects up in a web service. A quick round of testing of the service proved that it worked just as well as the old client app, and everyone was happy - for awhile.
Sometimes, agents would run a calculation and get absolute absurd results. Developers, putting in exactly the same values into their test environment wouldn't see the bad output. Testing the errors in production didn't help either- it usually worked just fine. There was a Heisenbug, but how could a simple math calculation that had already been tested and used for years have a Heisenbug?
Well, the calculation ran by simulation- it simply iteratively applied payments and interest to generate the entire history of the loan. And as it turns out, because the client application which started this whole thing only ever needed one instance of the calculator, someone had made it a singleton. And in their web environment, this singleton wasn't scoped to a single request, it was a true global object, which meant when simultaneous requests were getting processed, they'd step on each other and throw off the iteration. And testing didn't find it right away, because none of their tests were simulating the effect of multiple simultaneous users.
The fix was simple- stop being a singleton, and ensure every request got its own instance. But it's also a good example of misapplication of patterns- there was no need in the client app to enforce uniqueness via the singleton pattern. A calculator that holds state probably shouldn't be a singleton in the first place.
[Advertisement] Utilize BuildMaster to release your software with confidence, at the pace your business demands. Download today!The EFF's 'Certbot' Now Supports Six-Day Certs
Read more of this story at Slashdot.
Trump Denies Tariff 'Exception' for Electronics, Promises New Electronics Tariffs Soon
Read more of this story at Slashdot.
Palantir's 'Meritocracy Fellowship' Urges High School Grads to Skip College's 'Indoctrination' and Debt
Read more of this story at Slashdot.
After Meta Cheating Allegations, 'Unmodified' Llama 4 Maverick Model Tested - Ranks #32
Read more of this story at Slashdot.
Three Million Child Deaths Linked To Drug Resistance, Study Shows
Read more of this story at Slashdot.
33-year-old AmigaOS for Commodore Computers Gets an Unexpected Update
Read more of this story at Slashdot.
How a Secretive Gambler Called 'The Joker' Beat the Texas Lottery
Read more of this story at Slashdot.
America's Dirtiest Coal Power Plants Given Exemptions from Pollution Rules to Help Power AI
Read more of this story at Slashdot.
'Linux Mint Debian Edition 7' Gets OEM Support
Read more of this story at Slashdot.
FreeDOS Celebrates More Than 30 Years of Command Prompts With New Release
Read more of this story at Slashdot.
New Supercomputing Record Set - Using AMD's Instinct GPUs
Read more of this story at Slashdot.
Do Cognitive Abilities Predict Performance in Everyday Computer Tasks?
Read more of this story at Slashdot.
Torvalds Celebrates Git's 20th Anniversay. Is It More Famous Than Linux?
Read more of this story at Slashdot.
WSJ Says China 'Acknowledged Its Role in U.S. Infrastructure Hacks'
Read more of this story at Slashdot.
Original 1977 'Star Wars' Cut Will Be Shown at a Theater for First Time in Decades
Read more of this story at Slashdot.
Chrome To Patch Decades-Old 'Browser History Sniffing' Flaw That Let Sites Peek At Your History
Read more of this story at Slashdot.
America's Justice Department Shuts Down Its Cryptocurrency Fraud Unit
Read more of this story at Slashdot.
For the First Time Astronomers Watch a Black Hole 'Wake Up' in Real-Time
Read more of this story at Slashdot.