itsnotits,

paid_bill*

threelonmusketeers,

Where is paid_not_payed bot when we need them?

eager_eagle,
@eager_eagle@lemmy.world avatar

some heroes don’t wear caypes

Natanael,

Some heroes don’t wear capex

mindbleach,

Deleted by GCP.

eletes,
@eletes@sh.itjust.works avatar

Holy fuck whoever was in charge of setting up that disaster recovery needs a million dollar bonus. I get that they’re managing $80B and this should all be standard but people usually don’t listen to IT and take DR seriously. And even if you do set it up, are you going back to check that your backups are functioning properly and have alarms for when it messes up

TechNerdWizard42,

Absolutely.

But something tells me they will at most get a recognition award printed from MSWord and a pizza party day at their local office.

UxyIVrljPeRl,

Time to update my off site cold backup(private)

UnRelatedBurner,

can I get a copy if I ask very nicely?

Tryptaminev,

Friendly reminder to every CEO that this could have been a situation where a disgruntled employee accidentally fucks up the off site backup too.

FiniteBanjo,

TBF a lot of the people I’ve been associated with in finance solutions, including one of my best friends of almost 2 decades who has been in the career path his entire adult life, do have complicated backup and restore systems with multiple layers of redundancy in place, but it can still fail especially when it isn’t frequently tested. A lot of businesses don’t know about problems in their backup system until they need it.

MangoPenguin,
@MangoPenguin@lemmy.blahaj.zone avatar

IMO backups on the same provider aren’t really backups. Good that they had some at a different one.

Emma_Gold_Man,

That wasn’t luck - it was best practice backup strategy.

IWantToFuckSpez,

So this just proves that when your off-site backups are outsourced you should use at least 2 different companies. So 4-2-2

Carighan,
@Carighan@lemmy.world avatar

I mean I was originally angry about this toss-up, but since it hit an investment company… good guy Google?

I’m confused now.

IWantToFuckSpez,

Investment company doesn’t automatically mean greedy private equity or Wall Street bank you dingus. A pension fund is also an investment company.

Carighan,
@Carighan@lemmy.world avatar

Not over here, but TIL that this works different in other parts of the world.

520,

This company wasn't exactly targeted. It could have happened to literally anyone.

galoisghost,
@galoisghost@aussie.zone avatar

UniSuper is a superannuation fund (think 401k), it’s one of the good ones in that it doesn’t take commissions and profits go to members

Stay confounded at Google’s incompetence.

prof,
@prof@infosec.pub avatar

Meme is funny, but that exception used as flow control hurts.

wizardbeard,
@wizardbeard@lemmy.dbzer0.com avatar

Still hurts, but sometimes it’s the only option.

If you’re trying to confirm things like account existence/deletion, there’s often no “account exists” function to return true or false. You just have to figure out the specific exception thrown and catch that specific one.

The worst are libraries that don’t give specific exceptions, so you have to catch all exceptions then do extra work to tell what the specific situation is. Does the account not exist, or is the system unreachable?

prof,
@prof@infosec.pub avatar

Yeah, I had a similar case with some authentication middleware I used that was part of a library.

It would always throw an exception when a user wasn’t authenticated instead of just giving me some flag I could check.

Wouldn’t have done it that way, but it was okay for an API controller.

firelizzard,
@firelizzard@programming.dev avatar

so you have to catch all exceptions then do extra work to tell what the specific situation is

That’s horrifying. That’s a solid reason to avoid Python like the plague.

Lightfire228,

While i also disagree with python’s tendency to use exceptions as control flow

Python is a pretty stellar scripting language. I wouldn’t use it for app dev, but it’s quite handy for the odd automation or CLI task

firelizzard,
@firelizzard@programming.dev avatar

I’ve done a little bit of Python in the past, the biggest thing being an automation task that borderline became an app. I certainly can imagine using it for scripts, though I default to bash because that’s almost always available but TBH mostly because inertia. Beyond that my default is Go because inertia (and I love Go). I watched a video by the Primeagen (on YT) - in his view, Rust is better for text/data pipelines and CLI tools. Being very familiar with Go and not at all familiar with Rust, that’s an interesting take because honestly writing a CLI in Go is kind of meh.

snekmuffin,

Tbf python guidelines encourage it over if/else in cases like this. “Easier to ask for forgiveness than for permission” or something along the lines

rwhitisissle,

python guidelines

Do you have a specific PEP you’re referencing or is this one of those “I assume this must be the case because of how common using try/except statements for flow control are” kind of things?

snekmuffin,

Pretty sure its not a PEP, but the python glossary mentions it. Searching ‘python EAFP’ brings up a lot of discussion on the topic too, so if nothing else its definitely a widespread phenomenon

rwhitisissle,

I think there’s a difference between “python guidelines encourage” something and “this is a common coding pattern.” Yes, you can use try/except for flow control, but there’s a lot of people, myself included, who try to use that style sparingly.

NeatNit,

Like most things in life, context matters. In the OP it seems like the check function is used specifically so it could raise a PaymentException if the payment hasn’t been received… That’s not a “forgiveness/permission” context, this is a yes or no question, hence should have been an if.

bjornsno,

Day 598 of asking for a way to tell which functions throw exceptions in Python so I can know when to wrap in try catch. Seems to me that every other language has this, but when I’ve asked for at least a linter that can tell me I’m calling a function that throws, the general answer has been “why would you want that?”

How am I supposed to ask for forgiveness if it’s impossible to know that I’m doing something risky in the first place?

NeatNit,

Is this feature common in scripting/interpreted languages? Feels like those two things don’t work together.

bjornsno,

Well at least php has it, which is a JITed scripting language just like Python. Although saying php has it is wrong, it’s just a special doc tag that the linters pick up. Which is exactly what I want for Python. The only other scripting language I’m very comfortable with is typescript, which can also support @throws via jsdoc and eslint.

So to answer your question, I don’t know if it’s common, but from my minimal sample pool it’s at least not unheard of.

You may not know this (just guessing because you commented on the nature of scripting/interpreted languages) but static analysis of dynamic languages has come really far and is an indispensable part of any reasonably sized project written in them these days. That’s another reason why I’m so surprised and frustrated by the lack of this in Python.

skullgiver,
@skullgiver@popplesburger.hilciferous.nl avatar

I’m not sure if the ability to tell would help. Just like typing hints are very much optional in Python, I don’t expect many libraries to get their exception declarations right. Especially if there are transitive dependencies

I write Java code for my day job and while throws has been part of the language for ages, Java developers seem intent on avoiding it at all costs.

I would welcome a throws in Python so that libraries and coworkers that do the right thing are easier to work with, but I don’t think it’d solve the underlying issue in most cases.

bjornsno,

I believe raises is the de facto Python version of throws, but no tools seem to exist to actually handle it.

eager_eagle,
@eager_eagle@lemmy.world avatar

that’s still a docstring, idk of linters that take docstrings into account at all. We need a semantic approach for this kind of annotation.

bjornsno,

That’s way harder to ask for. A docstring solution is fine so long as the linters know to pick it up.

eager_eagle, (edited )
@eager_eagle@lemmy.world avatar

I don’t think so. A half-measure using docstrings would likely take more processing power and require an ad-hoc implementation because comments are not broken down into ast components afaik. It would also be more costly in the long run if they decide to convert it into a proper syntax, as a result of docstrings not having a single standard way of being written.

Python has introduced several syntactic changes for type annotations, this is not unreasonable.

sqw,
@sqw@lemmy.sdf.org avatar

cant practically anything throw an exception given the right (sometimes extremely remotely possible) circumstances?

prof,
@prof@infosec.pub avatar

Not really. Exceptions are a controlled way of indicating something went wrong in an application.

The only point where you wouldn’t know about the possibility of one is when you don’t know enough about the language features you’re using or when you use a badly documented library or framework.

sqw,
@sqw@lemmy.sdf.org avatar

dont many of the language primitives confer the possibility of thrown exceptions?

ScreaminOctopus,

Yeah, for this reason I would pretty much never encourage exceptions in Python over some other form of error handling. It’s so frustrating when called code throws some random exceptions that are completely undocumented. This is one of the few things Java got (sort of) right

crispy_kilt,

Check out Rust

bjornsno,

Respectfully, no. Rust is great for some things and Python is great for other things. Switching to rust is not a solution to missing exception linting in another language.

crispy_kilt,

Check it out anyways

lseif,

pythonic != good

snekmuffin,

Truers, just mentioning it

eager_eagle,
@eager_eagle@lemmy.world avatar

nothing wrong with that - it is an exception, as in, the customer is likely lost after that anyway.

  • All
  • Subscribed
  • Moderated
  • Favorites
  • programmerhumor@lemmy.ml
  • DreamBathrooms
  • ngwrru68w68
  • mdbf
  • tacticalgear
  • Youngstown
  • rosin
  • slotface
  • Durango
  • kavyap
  • everett
  • thenastyranch
  • InstantRegret
  • khanakhh
  • magazineikmin
  • megavids
  • anitta
  • GTA5RPClips
  • modclub
  • cisconetworking
  • cubers
  • osvaldo12
  • ethstaker
  • provamag3
  • normalnudes
  • Leos
  • tester
  • JUstTest
  • lostlight
  • All magazines