After 17 years of development and 8 years of management I've come to the conclusion that developers are delusional about the relative importance of their role. I shall be the first to admit that - I used to be one myself.
Your run of the mile non-technical manager sure is not very good at understanding the intricate complexity of all the moving parts of creating software.
Developers on the other hand appears blind to the fact that they play only a minor role in the bigger picture. While technology is difficult it pales in comparison to orchestrating people across sales, strategy, business transformation, creative, development, QA, operations and infrastructure.
That's just the horizontal alignment. In a single entity. In a single timezone. With a single vendor. A scenario which never happens because in real life you have at least 3 levels of technical management, multiple divisions/departments involved, spread across continents and multiple vendors participating.
You need competent people to align, coordinate, communicate and pick up the stuff which falls through the cracks. Developers are not good at this work.
You need a manager. And of course they must be competent.
EDIT: I don't actually think developers are delusional. I worded the phrase to mirror the absolutism of the statement "I've come to the conclusion that software managers are not needed" which is just plain silly.
> Developers .. appears blind to the fact that they play only a minor role in the bigger picture.
> Developers are not good at this work.
Developers aren't some special creatures with one dimensional fixed mindset. They can do whatever that needs to be done.
This is kind of silly stereotyping precisely why makes developers hate managers. I hate managers who think of their team as mere code monkeys that are "not good at" some mythical management work.
I am a manager myself but I never diminish role of my team members as "minor players", "not good at work" ect. They are my peers and partners who are equally as "major players" as anyone else.
> They are my peers and partners who are equally as "major players" as anyone else.
I love this. The best teams I've been a part of are those that had a mutual respect for everyone else's work. I was an engineer on those teams, and thank god for the product manager, tech lead, design work, ux researchers, etc. Things work so much better when there's a real culture of "we're all in this together, and we all have important roles to play".
My reply was worded to mirror "...I've come to the conclusion that software managers are not needed." which is obviously nonsense.
"Developers aren't some special creatures with one dimensional fixed mindset. They can do whatever that needs to be done."
Yes, but it is ok to generalize in a broad discussion like this one. Otherwise we can have no meaningful conversation. In general managers do not understand developers. And in general developers do not understand management. Those that are good have been exposed to both sides.
I never diminish anyone but it is naive to think that everyone contributes equally.
I think I've observed enough of this sentiment over the years, from some very smart and successful people, to come to the conclusion that, if it is nonsense, it is non-obvious.
> I never diminish anyone
Perhaps you never _intend_ to diminish anyone, but to some, your statements may reasonably appear to be diminishing some cohort.
but in the end, you decide who gets promoted or not, you decide who has to put the "extra effort" to satisfy whoever you work for. So of course everyone is a major player, it's your best interest.
but you're also the one who gets the time to see the big picture and hopefully realize that, yes, the development side of a project, while the most fundamental, is also just one of the part. The other being : handling customer expectations, making sure the budget use can be explained, making sure people stay happy even when confronted to "absurd" customer's request, making sure to understand the project ecosystem to make sure you get the right customer contact person in front of your team, making sure the one dev with a broken back gets a proper chair, making sure good project are rewarded, you make sure HR's department craziness don't alienate your devs, you-f*g-name-it (been there, done that, got the tshirt : I've been in dev, business consulting and management :-))
Yeah, I work in an industry where software enables things, so it is central. But even in my industry (business apps), we could just go on with pen and paper like before. So programs are not "absolutely fundamental" but in the 21th century, well, they are :-)
But I can admit it's not like that everywhere, sure. But I've yet to see industries where people pay programmers to work on IT project which are not fundamental in a way or another or in the process of becoming fundamental. The point is when programs get deployed, they usually transform (and hopefully improve) a situation. Once the transformation is accomplished, the program becomes fundamental...
You understand, that company goal is not to "build a good product", even less to "write a good code", it's to increase a company value (in the sense that "good code" is orthogonal to the goal)? It might be unfortunate for developers, but quite often (almost always from what I've seen) developers' role _is_ minor here. Not in derogatory sense, just money don't come from writing code, they come from sales. Also no, not everybody can be a good manager, and not everybody can be a good developer, as those two roles require different mindsets and different training, so very few people can effectively do either (and not at the same time). So a good developer normally can't do "whatever needs to be done". You don't want a developer to do your surgery, do you?
As a CEO and long time developer before then... its complicated. High performance teams are killed by managers unless they stay out of the way and then whats the point right? Managers are great for managing clients, but not devs.
Low performance, bare minimum devs, sure need reminding and pro-ding to get anything done... yes, you need managers to babysit.
Companies with heavy management usually have mediocre at best devs and little to no innovation. They have great sales and support - this keeps them alive.
Captain obvious here - there is no one size fits all. Do what makes sense at your org and take home a paycheck or leave and start your own business - there has never been a better time!
'High performance teams are killed by managers unless they stay out of the way and then whats the point right'
The point is two-fold. First, creation and maintenance of a high performance team as the company grows is worth someone focusing on, not just hoping it happens organically (sometimes people, especially new hires, need to know "yes. You are really free to make this decision yourself. I'll back you on it." Likewise, sometimes people doing good work need someone who can spend the time to highlight the value of it to the rest of the business, to effect a promotion). Second, ensuring other needs of the business inform that high performance team, WITHOUT interrupting it, are also worth focusing on.
These are both true regardless of the environment, but become bigger needs the larger the company is.
"creation and maintenance of a high performance team"
Managers do this? right, right. I would say managers at best dont mess it up. Creation and maintenance of high performance team comes from within. The surrounding support certainly helps, but to say a manager creates and maintains this is a bit of a stretch.
"ensuring other needs of the business inform that high performance team"
I have found if it needs to be known or communicated it will happen. High performance teams are not just coders (another fail from managers) they are intelligent people who can read and write emails and know how to speak to other humans. This may be the stereotype of some hot pocket eating teenager in a closet from the movies but that is certainly not the case in most professional environments.
So for the first, I am explicitly describing managers in an agile, team lead style. But, yes. Managers, first and foremost, hire the team. Ideally from feedback, but ultimately the manager is responsible for the team's formation. But then the manager also has to help smooth out bumps along the way. Having someone objective who can help smooth out disagreements can be HUGE. Likewise someone who can give feedback to individuals; a large personality can be a huge asset to the team, but can also leave others feeling alienated; someone who can help carve out space for those others to speak up, and to help coach the person filling the room how to recognize that and also to carve out space for others, is immensely helpful. And maintenance includes progression, both for individuals and the team; devs are often focused on what they're working on, they're not evaluating how to get their work recognized, and more junior ones often aren't evaluating how to grow themselves. It also includes HR issues; having someone who can do the legwork for your Visa sponsorship, for instance, frees you to do real work. A good manager is basically the team's admin assistant as well.
For the second, of course they are. You have to take the two statements I made together. There is a spectrum; at one end are devs working on what they feel is important, but not knowing they're not working on what the business feels is important. At the other is the business deciding everything the devs do, oftentimes changing priorities every week. Having one person as a middleman there can be immensely helpful. That may look like a manager saying "Hey Bob. Jane has this need; work with her to understand and implement it", and handling everything off to a dev, but the point is that the manager, A. Gave Jane (and everyone else) one person to reach out to initially when it came to their needs of the team, B. Helped determine that Jane's need was a priority against all the other needs, and C. Gave Bob permission to ignore all other incoming requests and direct them back to the manager, to focus on Jane's need. That is not to say Bob is not reading and writing; it IS to say that Bob can benefit from someone keeping him from being interrupted by every person in the business with a need who thinks he might help.
This feels right. I also believe that what people need are LEADERS and not MANAGERS. I'm sure there are plenty of examples of the two on the web.
The challenge I see a lot of managers have is that they look to much at an engineer as a widget and not literal human that is just as capable as the manager (most the time). There are often times no lines between roles and responsibilities and every shop does that slightly different, and not based on some framework they masterly put together, but just something based on how the pieces fell in place with some help from previous experiences.
I just wanted to say also - _most_ engineering managers are not good managers. They were good engineers that are in the unfortunate process of the Peter Principle.
This is very true. Most shops have an R&D team for long term innovation and other devs like myself who love customer feedback and want to deliver solutions now.
I have not heard this about "most shops", in fact I have never worked in an org with a functioning software R&D team (unless you count enterprise architects choosing vendors).
No but I've seen similar dynamics play out at most companies. Broadly, "product teams" focus on customer feedback and delivering value to customers, at the expense of technical debt and lots of fickle requests. "Infrastructure" teams are heavily insulated from customers and deal with a more long-term roadmap and fewer changing requirements.
just an observation: if you moved from developer to CEO without significant time as a Dev or Eng manager you have very different skills and focus. CEOs of all but the smallest companies are playing checkers; Dev Managers play chess. This isn't some sort of insult; we need to focus on individuals with distinct skill sets and characteristics. CEOs can't and shouldn't be concerned with this level of detail.
It's also uncharitable to split teams into either high-performance special ops teams vs. mediocre, low skill / low potential teams. Two trends make this distinction meaningless: GROWTH and SCALE. If these don't apply then you can totally let the team self-manage. FANG companies typically have all those rockstars you're looking for and multiple levels of technical management.
Even if CEOs "can't and shouldn't be concerned with [individuals with distinct skill sets and characters]" (not a point I'm conceding, what makes you think a CEO's job is "checkers" compared to the chess of a Dev Manager who is realistically 2-4 levels below them in the organization?
High performance teams are usually created by good management. If you change the management then bad management can easily undo that. My best managers have been deeply technical people with good people skills, an interest in management, and willingness to get out of the way and no longer make the decisions they made when they were a developer. Management is a lot more than babysitting it generally involves a lot of coordination up and down the organization to ensure the team is doing the right work in terms of organizational and customer priorities. Good management can give you what to work on while leaving you to decide the how.
The role of the manager is to ensure the team can get on with their jobs, to celebrate their success and have their back when things don't go according to plan. Unfortunately most manager can't help to start interfering with the team and go for a top down driven management style.
oh, and any given dev can switch from high performance to bare minimum depending on the project, week of the month, what they ate for dinner last night, etc.
Same could be said for a manager.. or a manager that gets bad devs or devs that get a bad manager. This is the value of a hands-on ceo that does not have their head in the sand.
This is true but I've also seen developers add ten percent more revenue to an organization on a rewrite of an existing billing system and it wasn't due to any insights from management. It was many conversations with key business users and developers. Management knew enough to step back and loosen the reigns. Everyone can make a huge difference on a project, and a team of non hero's that just care about learning the business and the craft can deliver greatness.
Sometimes you can plan for success/heroic actions (in the good way) but often it happens by accident.
The right person digging into a weird problem they encountered, two people sitting together to review a design or someone doing a firmware update that fixes a bug in the RAID controller giving you double the IOps...
I have tons of anecdotes from colleagues who did some unplanned work just because they talked with someone else and that work then turned out to have massive positive impact.
The results are lauded but it wasn't even clear when the "little" project started that it would actually be a massive boon.
At a prior job (some website selling hotels online) I was responsible for the project that ended up giving the whole fleet a 25% capacity boost. Instead of 2000 machines we only bought 1500 next quarter. If we calculate that in perpetuity my project was a massive success. Millions of EUR saved since 2011.
The project initially started out as "tons of people tried building a decent perl RPM but couldn't get it to work, could you have a look?". The guy originally tasked with it was busy fixing a broken LDAP server.
So I built some RPMs, wrote a bit of tooling around it and we ended up with a Perl environment separate from the system perl which was great because the business was nearly exclusively running on Perl 5.8.9. At that point I looked into using that to get us off CentOS4. With the help of two colleagues we got a CentOS5 environment running and could migrate to a x86_64 environment.
That migration than gave us a 25% capacity boost and happiness ensued all around. The OS upgrade wasn't part of the original project scope, we just went with it because it made sense and management understood that it's a good idea.
I guess the problem are not managers per se, but non-technical managers. Somehow it is OK to have a pure salesperson / MBA manage engineers, but you would never put a developer in charge of the sales department.
I think many developers (not just coders, but in general technical people who make the actual product, designers, engineers, ...) feel there is an unfair primacy of managers / business people over developers / technical people. This is even reflected in the job descriptions: I hate the term "individual contributor" for example, it implies replacability and that non-ICs (managers) contribute more than one person.
Not every company has "bullshit" managers and for sure some developers are delusional. But these bullshit managers exist, and I believe this happens when you put people who are far away from making the product in charge. If the managers and executives are not intimately familiar with the product and the customers, then the product becomes some interchangable thing that you hustle. This can be disastrous for the work climate but also for the success of the company.
I always wondered if it was possible to build an inverted company organization, where developers/engineers were formally at the head of things, and much of the administrative tasks that management works on were subbed to specialists reporting to the developers.
If you look at a lot of pretty incredible projects that often were finished ahead of schedule or with groundbreaking capability, they often happen to be led by a deeply technical person. e.g. Hoover Dam, the SR-71, etc.
If you look at CEOs of tech companies, I believe a majority of them have an engineering undergrad degree of some form.
I work at a company that operates much like this. I've passed up on more lucrative opportunities in the past because it's such a great place to work as a developer as a result.
Actually, it implies that managers are multiplicative. You -hope- that it's a value > 1.0. I quite like the term individual contributor - it implies you're actually doing work (and that it falls on the rest of the business to make sure you know what work will be valuable).
But, yes. Bullshit managers invariably choose to take empowerment onto themselves, despite a lack of knowledge, and oftentimes without any real responsibility, either (i.e., they don't bear the consequences of their decisions).
I even worked at one incredibly toxic organization for a year, before I left, where sales people would literally roam the office, grab a dev, and task them with a customer request.
This company was in a very specialized niche market, and was basically the only player. The only thing I couldn't figure out is why someone else hadn't come along and eaten their lunch, because they were suffering from chronic under-funding. Getting them to commit to migrating to AWS was a major eye opener for them; since they suddenly had to actually pay bills or they'd lose the whole operation.
It sounds like you've gone from one extreme to another. None of the things you mention pale in comparison to software engineering at all. They are all solvable problems that many people can do. Sometime they are difficult, often they are not. Managers are certainly not useless and do work for certain types of organizations. They are not always needed though. Believe it or not there are people capable of managing and programming at the same time. You seem to be one of them so your view point is very strange.
No, I've actually mostly worked in well balanced places. It is my experience that technology is the lesser issue and the one with the smallest impact. That's not to diminish the highly skilled developers - the work just have less impact that we seem to believe.
I do not believe in self organizing teams. I have not seem them work. Without direction the team will fumble until someone assumes control. I have also not seen many happy in such an environment.
The opposite is strict top-down control, such as what is often described and lamented on HN, is equally bad. No one wants to work under a dictator.
There's a balance to be struck between authority and autonomy.
Large scale software development without management is proven to be possible by the existence of functioning FLOSS projects like the Linux kernel, various GNU tools, KDE and plenty of other examples.
I have not heard of a single software development company with 0 software developers. Not even Oracle manages that.
Managers are necessary for the parts of the company other than development. You can have a FLOSS project developed organically, and separately a company in the business of support, services, etc. Managers are also necessary in order for the company to exercise control over the development and extract value. And this may be needed for a company to survive. But they are not needed for software development itself.
Even FLOSS enthusiasts need to eat. Money don't come from writing code by itself, they come from sales. Or from donations. In both cases there is a lot of non-coding work. Do you want to do it? I don't. How do we call those guys who organize donations or sales? Collect requirements? Yes, there are requirements in FLOSS too, otherwise you wouldn't get donations, or support contracts, and those requirements are coming from the people who pay. Let's call everybody developers, only some won't write code and would organize coders, gather requirements, distribute payments. Wait, those people are currently called managers.
I'm reading: "You need a manager to coordinate a deeply hierarchical and separated structure with production at the bottom and the clients at the outside."
I mean no disrespect, but from my perspective I see a deeper problem here that is being patched over by exceptional people like yourself. Shouldn't the creators and clients have a major, high impact role and the coordinators a supporting role in terms of decision making?
To make an exaggerated joke it looks a bit like a dictator complaining about all their responsibilities and the hard decisions they have to make. Well maybe they shouldn't even be in that position to begin with.
And yes I've seen the diagrams and the theory behind this. But I've become more and more suspicious of bureaucracy and process that tries to fight the symptoms of lack of trust and human connection.
>And yes I've seen the diagrams and the theory behind this. But I've become more and more suspicious of bureaucracy and process that tries to fight the symptoms of lack of trust and human connection.
This resonates but what I have seen is when you engage a company that has this model you have to emulate their model to fit within their needs, then you get infected with it.
Ha - yes, you're right it sounds like a tautology. I worded my answer to reflect the absolute statement of no manager is ever needed.
"Shouldn't the creators and clients have a major, high impact role and the coordinators a supporting role in terms of decision making?"
No. The creators usually answer "how to do it". The more important question is "what to do". Both groups are important but doing the right thing is more important than how you do it.
Then make sure developers are deeply aware of all the concerns you listed. A large part of why developers think they are the center of the world is because they are meticulously isolated from said world. This is exactly what the article addresses as one of the main concerns.
As a developer, I’ve noticed a pattern: devs complain about too many meetings -> devs are left alone (aka isolated) -> devs complain about being left out of decision making process/chain of comm.
It's a good observation. IME you can't be in all the meetings you need to be in to obtain alignment on complex problems in a changing environment AND be effective in writing code, very generally speaking. My most frustrating career points have been when I was a tech lead, doing a bit of both. Being more purely IC or purely managerial, it is much easier to get important work done.
Its also a grass is geener issue. Work is generally more enjoyable as an IC, you get to focus and write code. Until you end up having to build something really stupid, and you want more control over product direction. Then you end up as manager, and long for the simplicity of being able to focus and write code. At least that's how I've felt at times.
Meetings are to align people. Complaining about too many of them can be a sign of many different things, but one of the biggest is needing to align with so many people to get anything done.
If you hold the same number of meetings but stop inviting some stakeholders, those stakeholders are going to be upset. If instead you remove some meetings from the process entirely, by e.g. not requiring multiple design reviews for internal products, or by not letting platform teams force everyone else to use their software, or by letting teams spin up their own low capacity services without meeting with ops, or anything else that lowers the complexity of getting work done, then your team will be happy and the previous gatekeepers will be complaining.
I agree. And then if the same devs have reduced meetings, are included in more cross dept initiatives, and included in decision making, they end up upset that their freedom is suddenly gone. Its not even just devs this is a common thing from call center reps to the top of the broken pyramid. Everyone is the linchpin in their perceived contribution to the world.
Both of those problems can be solved to a degree with more efficient communication. Async communication channels like email and other messaging are great at not wasting peoples time while keeping everyone in the loop who needs to be, properly used. Sometimes I think phpbb style forums would work better than the usual tools. But overall I find people don't experiment enough or put enough effort into optimizing communication and it leads to this false dichotomy of either isolation or time wasting. There's a middle ground of optional participation where you communicate widely but don't force peoples attention, and that's how you can reduce meetings without reducing valuable communication. You can always put a time limit on feedback if needed, mark some things important... Just find what works!
That isolation is often as much self-imposed as not. While the GP may have been a bit aggressive in his/her characterization of it, I agree with the general thrust that developers tend to be both narrowly focused on their own technical work and prone to inflation of its worth.
Of course it isn't: most individuals tend to inflate their contributions' importance. There are matters of degree, though. My experience is that developers tend to overestimate more often and by larger amounts.
My answer was intentionally phrased to mirror the absolutism of the GP. A large part of my time is spent explaining why certain process is in place or why we cannot get a license for this or that tool or why one needs to be considerate of the other crafts.
> Your run of the mile non-technical manager sure is not very good at understanding the intricate complexity of all the moving parts of creating software.
> Developers on the other hand appears blind to the fact that they play only a minor role in the bigger picture.
Y Combinator was largely founded as a rejection of this premise. Paul Graham believed it was much easier to teach great Software Hackers how to business, than it was to teach business folks how to software. I think it turned out pretty well.
> A scenario which never happens because in real life you have at least 3 levels of technical management, multiple divisions/departments involved, spread across continents and multiple vendors participating.
And your organization with 3 levels of technical management and all those divisions and departments will often get their lunch eaten by a very small group of people working in a startup, moving faster and accomplishing more in less time.
"Paul Graham believed it was much easier to teach great Software Hackers how to business..."
I agree
"And your organization with 3 levels of technical management and all those divisions and departments will often get their lunch eaten by a very small group of people working in a startup, moving faster and accomplishing more in less time."
You misunderstand. It is not my org - it is the client orgs. And none of those are software companies. The speed with which you can move is irrelevant because you are constrained by the pace of the org you're working for.
I'd like to make a wild inference and suggest that you and the parent poster are talking straight past each other, because you're drawing your experience from two different business paradigms.
kbmunchkin wrote:
> The lead developer handled communication with the IT Director about project status
The fact that the ultimate person being reported to was the head of IT strongly implies to me that it was an in-house development team working on in-house projects.
Your list,
> orchestrating people across sales, strategy, business transformation, creative, development, QA, operations and infrastructure.
Strongly implies that your experience comes from building consumer products.
Personally, I've spent time working on both successful and unsuccessful projects on both sides of the fence. What I've seen is that the most straightforward way to create a dysfunctional team is to try to take what works from one context, and apply it uncritically to the other. I personally hate working with a dedicated product manager on an in-house project every bit as much as I hate working without a dedicated product manager on consumer-facing stuff.
Consider that those two statements may be about in the same wheelhouse, but "developers aren't needed" is way, way more rediculous than "managers aren't needed".
> developers are delusional about the relative importance of their role
I think it's that developers fail to grasp that they are in the enterprise world. Web development and SaaS has blurred the lines, but at its core it's the same: the product you work on is a tool for another business. It's a bit more sexy because it's not mainframes, cubicles and suites anymore, but in the end the job is the same. And in that setting, the role of a developer is indeed minor in the bigger picture. There are exceptions in R&D, cutting edge projects, or in an early stage startup, but for the vast majority of developers the above is true.
Strongly agree with this. I've been in situations where my team had no manager, a bad manager, and a great manager. The situation where I had no manager was the worst, by far.
I've found that if you throw a bunch of Alpha Geeks together without constraints you may as well be herding cats. They'll want to work on their individual wishlists of strategic research problems (throw in this new tool! new methodologies I saw at this conference!) with less concern for the unromantic tactics, socialization, and alignment that makes a project succeed.
The issue with this argument is that a significant part of the "bigger picture" is artificial bloat which emerges from the fact of having layers of management. Managers spend much time actually managing themselves. It's of course not all black or white.
I don't think it's an issue with my argument but I do think the difficulty of grasping the bigger picture is a major issue.
It can be reluctance to understand why you're doing what you're doing. It can also be because no one cares to explain it to you. Most of the time it's probably between those two extremes.
And yes some times it's bloat. But rarely all of it. I don't have a solution to this.
A delusion is a sincerely-held false belief. Please consider: If all of the developers left your organization, could it still produce products? How about if all of the managers left? Your implicit devaluation of labor is not congruent with the actual reality of whose hands work the keyboard.
(And before you write a knee-jerk response, double-check your reasoning. Without managers, developers produced the Free Software ecosystem. Without developers, what did managers produce?)
I tend to believe these arguments just curve right into confirmation bias.
I’ve been on teams that worked fine with managers and those that did not. It depends on the commitment of the actors in question.
Anything else is reading what we want to in the tea leaves.
Edit: Been working on distributed systems since the late 90s, from public uni to big corp, to day 1 startups. It’s just computer configuration. Not magic.
Clearly some management is required somewhere in the chain, and if they're any good then they're important. But certain tiers of management seem to largely be pointless intermediaries; especially if they're not as technical as the developers.
I've stopped being skeptical of the general concept of management. I'm no fan of LinkedIn, but Reed Hoffman said something in a talk that instantly changed my entire opinion about the idea of a developer moving up in the hierarchy and no longer writing code. Paraphrased from memory: "You're still programming; just at a higher level of abstraction."
Regarding selling - I've know amazing people who could sell all kinds of products that don't even exist. So selling by itself doesn't seem to be the hardest thing - selling something that relates to the reality of the product is far more difficult.
Drain a company of managers, and the devs will self organize and save the company. Drain the company of devs, and the managers will desperately try to hire anyone to replace them. Devs are vastly, vastly, more important than management. Any given manager could leave a company and literally no metric would move.
I agree, you need a manager, but through my limited experience I feel as though the issue is developers are mostly detached from the buisness end of things. When things go wrong or some issue occurs I've always had managers step in to aid from the buisness side. You almost need a manager who has developer experience like yourself to make for a good manager. I suppose even a manager who is able to understand the general overview of what the developers are doing would be good.
Basically it seems the average manager in buisness would be a bad fit to manage developers. overall a manager is still needed for sure. I guess its the same everywhere though a bad manager vs a good manager makes a world of difference.
This is a similar mentality of people who get very upset over incentives sales gets and/or "company provided trips".
We all forget, at least in a for profit company, that we are all employed by selling things. Like it or not without the good salespeople, some of us don't have jobs.
This is all true, but reads more like a PM-type role, which is absolutely critical.
I understood GP's point as more directed towards "pure Eng. manager" type positions, often when there's also already a PM present. And I've witnessed first hand how his criticism rings true in that case.
That's not the point. The point is the disingenuous, and sadly socially acceptable, argument that something is bad/wrong because it is made by men or white people
Probably because those who scream the loudest influence the view on the following group. Is this different than any other situation such as Trump and his supporters?
I don't think so - at least I am not. I am however against the narrative that men, as a group, are inherently sexist. Or that white people are, inherently, racist.
No, the poster is correctly identifying cancel and woke culture as dogmatic.
From their point of view there are two options: You are either enlightened and agree with their cause or you have yet to see the light. There is no difference between this and dogmatic interpretation of religion. The cancel part is a social inquisition carried out by public shaming and a goal of ostracization
This is a mythical view of cancel culture, and it's driven entirely by arseholes who have realised that people are now prepared to call them arseholes.
"I'm being cancelled" they yell, from the front page of a national newspaper.
It's telling that the small number of white people denied jobs because they behave like cunts get all the attention.
The very many people denied jobs because they're women or because they're black or because they're LGBT+ don't ever meet your threshold for attention, do they? Why is that?
It is my interpretation on seeing people (who I don't necessarily agree with) being silenced. I see from the other comments that there is no consensus on the term "cancel culture" itself so that certainly doesn't help the conversation.
I dislike the notion of a mob and public shaming. Regardless of the individual receiving the attention. And I am appalled by the current direction of legal censorship in our democracies.
Hate will not go away by outlawing hateful speech. Racism will not go away by outlawing racist speech. Freedom of speech is, and must be, absolute.
You possibility to get a job should not be determined by the way you look and your sexual preference. It also shouldn't be determined by corporations fearful of reprisals caused by a momentarily stir on social media.
My attention is not an the individual being discriminated but on the downwards slope of categorizing, in ever smaller groups, based on skin color or similar.
I am an individual. You are an individual. I demand to be seen as one and I demand to see you as one.
Your run of the mile non-technical manager sure is not very good at understanding the intricate complexity of all the moving parts of creating software.
Developers on the other hand appears blind to the fact that they play only a minor role in the bigger picture. While technology is difficult it pales in comparison to orchestrating people across sales, strategy, business transformation, creative, development, QA, operations and infrastructure.
That's just the horizontal alignment. In a single entity. In a single timezone. With a single vendor. A scenario which never happens because in real life you have at least 3 levels of technical management, multiple divisions/departments involved, spread across continents and multiple vendors participating.
You need competent people to align, coordinate, communicate and pick up the stuff which falls through the cracks. Developers are not good at this work.
You need a manager. And of course they must be competent.
EDIT: I don't actually think developers are delusional. I worded the phrase to mirror the absolutism of the statement "I've come to the conclusion that software managers are not needed" which is just plain silly.