this post was submitted on 05 Jun 2024
406 points (94.3% liked)

Programming

17765 readers
266 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities [email protected]



founded 2 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 16 points 7 months ago* (last edited 7 months ago) (1 children)

I don't disagree with you (on giving devs some creative freedom), but "Agile" as a process methodology isn't about developers working on multiple things to keep their interests up.

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

That's actually a pretty important part of its original premise.

It's a big part of why scrum meetings were a thing, as the expectation was any curious dev could just join in to see what's up, if they like.

Not tying devs down to 1 specific thing is like the cornerstone of agile, and over many years of marketing and corporate bastardization, everyone had completely forgotten that was literally the point.

The whole point of the process was to address 2 things:

  1. That client requirements can't easily be 100% covered day one (But you still need to get as many as you can!)

  2. To avoid silo'ing and tying devs down to specific things, and running into the one bus rule ("how fucked would this project be if got hit by a bus?")

And the prime solution posited is to approach your internal projects the same way open source works. Keep it open and available to the whole company, any dev can check it out, chime in if they're familiar with a challenge, etc.

One big issue often noted in non-agile companies (aka almost all of them) is that a dev slent ages hacking away at an issue with little success, only to find out far too late someone else in the company already has solved that one before.

An actually agile approach should be way more open and free range. Devs should be constantly encouraged to cross pollinate info, tips, help each other, post about their issues, etc. There should be first class supported communication channels for asking for help and tips company wide.

If your company doesn't even have a "ask for help on (common topic)" channel for peeps to imfoshare, you are soooooooo far away from being agile yet.

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

I don't know man. Nothing in the Agile Manifesto talks about not focusing on one project.

In addition, I think most people (and studies) would agree that "focus" is key to building almost anything of quality. Not flittering about working on shiny pennies of the day. I mean, a key tenant of sprints is "Don't interrupt the sprint". The whole concept is about letting developers focus.

Agree to disagree I guess.

[–] [email protected] 2 points 7 months ago

Might wanna read it again, it's right there :)

The best architectures, requirements, and designs emerge from self-organizing teams.

It's an incredibly critical part companies love to completely ignore.

If you assign devs to teams and lock em down, you've violated a core principle

And it's a key role in being able to achieve these two:

Agile processes promote sustainable development.

And

The sponsors, developers, and users should be able to maintain a constant pace indefinitely.

This is talked about at length by the likes of Fowler, who talk about how locking devs down us a super fast way to kill sustainable development. It burns devs out fast as hell.

Note that it's careful not to say on the same project