this post was submitted on 17 Aug 2023
1138 points (99.0% liked)

Programmer Humor

32557 readers
292 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS
 
top 50 comments
sorted by: hot top controversial new old
[–] [email protected] 62 points 1 year ago (1 children)

Ah yes the forgotten land of uncompleted tasks. Slated to be a hotfix when it becomes a problem.

[–] [email protected] 9 points 1 year ago

And one that requires several people to give up a weekend, too.

[–] [email protected] 41 points 1 year ago

I don't know when this meme was originally made, but my boss unironically has this taped to his office door, and it's glorious

[–] [email protected] 29 points 1 year ago (2 children)

Everywhere I've ever been,

If it's lower than "High" or "2", it's as good as "backlog" :)

(There can never be a priority "1" and seldom "Highest", never "Blocker", otherwise the CEO gets a text or something.)

[–] [email protected] 28 points 1 year ago (2 children)

Scrum Master: "Do we really have to make it a blocker?"

Me: "Uh yeah. It's blocking these three other tasks."

Scrum Master: "But is it really?"

Me: "Yes."

Scrum Master: "Let's just leave it on in development and we can review the progress tomorrow."

Me: "That's what you said yesterday."

Scrum Master: "Alright guys. I'm going to give you back five minutes of your time today."

[–] [email protected] 11 points 1 year ago

Holy shit that’s too real. I come here to get away from work!

[–] [email protected] 3 points 1 year ago

Don't forget breaking everything up into ever-smaller tasks just so that something, anything, can be closed every day. 😂 Because the process matters, not the work.

[–] [email protected] 27 points 1 year ago (1 children)

At every company I've worked at there were basically 3 priority levels - normal, stuff the client says is urgent, and the stuff that's actually urgent. "We'll fix it later" is basically for the week in December that everyone's on vacation and the juniors have nothing to do.

[–] [email protected] 19 points 1 year ago (1 children)

Lol, I love that week. Feels so productive working on low priority shit that's been around forever

[–] [email protected] 8 points 1 year ago (1 children)

Refactoring that parser you did for the internal DSL in 2011.

load more comments (1 replies)
[–] [email protected] 25 points 1 year ago* (last edited 1 year ago) (2 children)

Yet the solution is so simple. Let the them spend 20 – 35 % of their paid time on backlog. Let them refactor the architecture. Let them improve the code base. You know, that thing the Lean book talks about, the part that everyone overlooks, the part so critical yet so often overlooked that others wrote books that ride that one aspect home. Oh, unless you want them to spend overtime on a production problem whose root cause a scrum master added to the backlog 5 years prior to the incident, of course. Oh, unless you want them to give you one year estimates for changes as simple as translation changes 'cause the architecture is so ass-backwards and never improved upon that everything depends on everything and everything breaks with one simple change. And who needs tests, right? Waste of time and money! Just live in fear that one change can break the entire software, like a real man.

[–] [email protected] 11 points 1 year ago

Backlog isn't sexy. Management wants sexy. Nobody's boss wants to hear about how the DB schema was improved - they want to see some new, flashy widget.

And the whole product line suffers because of it.

load more comments (1 replies)
[–] [email protected] 21 points 1 year ago

I'm a Senior developer, and I'm still playing the part of the Junior in this meme.

I hate it when people insist on leaving their trash lying around where I work.

[–] [email protected] 21 points 1 year ago* (last edited 1 year ago)

Backlogs are great. Sometimes while working on prioritized tasks the depriorized backlog tasks are made irrelevant and thus you never have to do them and you don't waste effort. Call it strategic deprioritization or perhaps even tactical laziness.

[–] [email protected] 18 points 1 year ago

Ummm yeah it will be in “Phase 2” of the project.

[–] [email protected] 15 points 1 year ago (2 children)

Honestly why do jr devs want to do work so bad, I'm literally just like "yo chill" and they keep pestering me for work

[–] [email protected] 48 points 1 year ago (2 children)

They probably spent a year looking for a job and they're suffering from imposter syndrome so they feel like if they aren't constantly getting stuff done they might be fired, plus they haven't worked enough to hit burnout and don't know how to pace themselves.

[–] [email protected] 10 points 1 year ago

Yeah as a junior this is accurate

[–] [email protected] 6 points 1 year ago (1 children)
[–] [email protected] 8 points 1 year ago (2 children)

Or, possibly, that? Who knows.

[–] [email protected] 6 points 1 year ago

That seems rather unreasonable.

[–] [email protected] 4 points 1 year ago

This > that

[–] [email protected] 3 points 1 year ago

Reminds me of the joke about the old bull and the young bull. Young bull says to the old bull "hey pops, let's run down into the valley and fuck one of those cows". Old bull says "I've got a better idea: let's walk down and fuck them all."

[–] [email protected] 15 points 1 year ago (4 children)

My longest lived backlog task is 3 years old

[–] [email protected] 20 points 1 year ago (1 children)
[–] [email protected] 18 points 1 year ago

Somehow their company is only 2 years old 🤔

[–] [email protected] 11 points 1 year ago

I completed a ticket made in 2011 today!

[–] [email protected] 5 points 1 year ago

Good for you. My oldest backlog task is from 2012. And that was imported from the previous ticketing system (AKA an Excel Sheet).

[–] [email protected] 2 points 1 year ago

We let a bot close our backlogs after 60 days of inactivity. It has a valuable "get it done or let it go" effect.

[–] [email protected] 13 points 1 year ago* (last edited 1 year ago) (4 children)

Our solutions architect is like this. Not because we’re working on anything important at the moment, but because we keep pushing back important upgrades further and further, making each day a more challenging operation to keep our rickety-ass distributed monolith alive.

We were supposed to upgrade from Java 8 on Springboot 2.1 to 17 on Springboot 3. That got wiped off the table because the bosses think shoving our inefficient solution into a cloud product is what will attract customers.

[–] [email protected] 6 points 1 year ago (1 children)

Do we work for the same company lol

[–] [email protected] 2 points 1 year ago

Likely not, but I’m happy and sad that this seems to be a common scenario.

[–] [email protected] 2 points 1 year ago* (last edited 1 year ago) (1 children)

I'm not too familiar with Spring, so excuse my ignorance, but could you sell Spring Cloud ✨ to management? If I understood the docs correctly, Spring Cloud requires Springboot 3, so you can migrate to Springboot 3 while management can claim that your monolith is very cloud. Or is this a “dump it in ec2 and claim it's cloud” situation?

load more comments (1 replies)
load more comments (2 replies)
[–] [email protected] 13 points 1 year ago (2 children)

IMO it's good to have a "shadow backlog" for stuff like this. Keep the actual backlog for prioritised product work, "ideas" and tech debt can be kept in GitHub Issues or even just a wiki page somewhere.

[–] [email protected] 4 points 1 year ago* (last edited 1 year ago) (1 children)

I have two levels of backlog. The first level is my curated list of tickets that are highly worth doing in the near future and is limited in size. It's currently larger than I'd like at 30-something (for a team of a little under 10), but I'm trying to get the team to focus on it more after historically neglecting it.

The second level is literally just everything else. Hundreds upon hundreds of tickets, ranging from restructuring unit tests (which will frankly never happen unless the structure of the tests somehow became a major barrier) to cool features that just aren't important enough yet (or would take too long). Plus all the super low risk bugs, often in edge cases that nobody really cares about yet or aren't worth the time to fix yet. And then there's all the automation style tickets about improving the handling of something (commonly edge cases of things already automated for the happy path), but often that something just isn't common enough to be worth it.

Tickets in the second level sometimes do get done. Usually because some issue becomes more common, enough people ask for it, or we simply finally have time for a new feature (can only do so many of those at a time). A common theme I have is I'll encounter a problem, file a ticket, then eventually encounter the problem enough times that I go, "fuck it, I'll do it myself".

[–] [email protected] 2 points 1 year ago

This is the way 🤝

[–] [email protected] 2 points 1 year ago (1 children)

Meh, I prefer to call it trash. What's the point of a backlog nobody works on, and so hopelessly irrelevant that the issues themselves may no longer exist or are otherwise outdated?

load more comments (1 replies)
[–] [email protected] 13 points 1 year ago (1 children)

ugh Jira. At my first job in 2006 I was the Jira administrator. Every project wanted their own custom fields. We had a Jira project for “infra” problems it had 3 fields yall Title/Description/priority and it worked so well. Moved to a company with a simple ticket system with not much more but the concept of “tags” it was heavily

[–] [email protected] 3 points 1 year ago

Ah, but is this a double blocker or a triple blocker?

[–] [email protected] 11 points 1 year ago (1 children)

"I archived them all Padme. They're gone...every single one of them. And not just the minor tickets."

[–] hellishharlot 2 points 1 year ago

But the stories and epics too

[–] [email protected] 10 points 1 year ago

In our case, tossing stuff in the backlog to never get done is just part of trying to get through life.

We have an... eccentric colleague who demands the craziest stuff that no one else wants. Now in a sane world, we explain that his requests are either extremely costly for a minor thing no one cares about, or, like 90% of his requests, run explicitly counter to what our customers want even if we could trivially do it. He is not a customer nor is he in contact with customers or marketing or sales, he's in a different technical team but has an "armchair enthusiast" interest in my teams product.

We used to try to have that discussion to reject items to make it clear they will never ever get worked on. However whenever we did that he would demand hour after hour after hour of meeting to discuss each request that we want to reject and convince us why his requirement is the most awesome thing in the planet, and with enough meetings maybe we'd stop being so clueless and come around to recognize the brilliance.

So now we toss it in the backlog, and there's always a point of comparison like "Customer giving us $40M asks for feature X", and he has to rationally accept why X jumps ahead of his backlog items, even if he is displeased. One new project manager made the mistake of trying to close out the backlog items and the meeting invites flew about us daring to ignore his awesome requests.

So we have a chunk of backlog that every one knows will never happen, and in fact if our backlog ever dried up, then we'd have a big problem because then we'd actually have to have that tough conversation about why his ideas are bad. At this point some of his wacky stories have been on the backlog for over five years.

[–] [email protected] 9 points 1 year ago (3 children)

That's why scrum teams need aggressive POs and scrum masters.

[–] [email protected] 24 points 1 year ago* (last edited 1 year ago) (4 children)

I'm the Sr. Dev in this meme.

I usually just do this when a jr has fallen in love with a piece of work and wants to keep polishing it. They start to confuse "I could do X" with "I should do X"... And confuse "less than perfect but still acceptable" with "bug".

I tell them to slap it on the backlog and to move on.

We have backlog grooming meetings every few weeks. If they still actually want to do it, we can talk, but like 19 times out of 20 they've found a new shiny rock by then anyways, and we're now in a position where we can both agree it isn't a good use of our time, and close it out as a "will not do".

You don't need aggressive POs or scrum masters to operate as a pragmatic team. I far prefer having a lean overhead. When there are more people shouting directions than people actually coding you've got too many cooks.

[–] [email protected] 11 points 1 year ago (1 children)

It's interesting how people have different interpretations of mwmes. You took it as a reflection of a perfectly normal good thing, while I took it as a perfectly normal bad thing.

Iny experience, "put it on the backlog (and never look at it again)" is the response to someone raising a serious architectural problem.

[–] [email protected] 3 points 1 year ago (1 children)

Yeah exactly. I think you hit the nail on the head with the "(and never look at it again)".

It's not explicit in the meme. "Not doing it" and "never look at it" are totally different things... But I think you'll fill it in based on your personal experience.

I'm sorry your backlog doesn't get regularly revisited.

If I were you, I'd push for setting aside time to get it under control.

If your backlog is gigantic, I expect there will be pushback just because once the problem gets sufficiently large nobody is brave enough to broach it.

But, you can apply story slicing skills to these kinds of problems too. Break it down into smaller bits with clear and realistic objectives. Setting aside 30 minutes with the goal of, say, picking 5 items on your backlog that you know you won't ever do because they're super low value? Pick 5 items and close them off as won't do. Baby steps.

load more comments (1 replies)
[–] [email protected] 4 points 1 year ago (1 children)

I mean "imperfect" is a bug oftentimes. The other version of imperfect is "missing a feature"

[–] [email protected] 4 points 1 year ago

Sometimes. Sometimes it's just "I can refactor this to use X pattern". Or "I COULD push X logic to some other layer"

[–] [email protected] 2 points 1 year ago* (last edited 1 year ago)

When there are more people shouting directions than people actually coding you've got too many cooks.

Ha ha what about when the shouters:coders ratio hits 10:1?

load more comments (1 replies)
[–] [email protected] 4 points 1 year ago

No matter how aggressive PO & SM are they don't get to decide priority.

load more comments (1 replies)
load more comments
view more: next ›