Hi, this is a question that popped into my mind when i saw an article about some AWS engineer talking about ai assistants taking over the job of programmers, this reminded me that it’s not the first time that something like this was said.

My software engineering teacher once told me that a few years ago people believed graphical tools like enterprise architect would make it so that a single engineer could just draw a pretty UML diagram and generate 90% of the project without touching any code,
And further back COBOL was supposed to replace programmers by letting accountants write their own programs.

Now i’m curious, were there many other technologies that were supposedly going to replace programmers that you remember?

i hope someone that’s been around much more than me knows something more or has some funny stories to share

  • Avid Amoeba@lemmy.ca
    link
    fedilink
    arrow-up
    79
    ·
    2 months ago

    So far one of the best use cases for AI in software engineering has been identifying idiots and sociopaths.

  • tias@discuss.tchncs.de
    link
    fedilink
    arrow-up
    59
    ·
    edit-2
    2 months ago

    Oracle has a product called Oracle Policy Automation (OPA) that it sells as “you can write the rules in plain English in MS Word documents, you don’t need developers”. I worked for an insurance organization where the business side bought OPA without consulting IT, hoping they wouldn’t have to deal with developers. It totally failed because it doesn’t matter that they get to write “plain English” in Word documents. They still lack the structured, formal thinking to deal with anything except the happiest of happy paths.

    The important difference between a developer and a non-developer isn’t the ability to understand the syntax of a programming language. It’s the willingness and ability to formalize and crystallize requirements and think about all the edge cases. As an architect/programmer when I talk to the business side, they get bored and lose interest from all my questions about what they actually want.

    • trolololol@lemmy.world
      link
      fedilink
      arrow-up
      9
      ·
      2 months ago

      Edge cases are for teams that have internal testing AND care about quality.

      A quick easy way to know if your new job is or isn’t one of those, is when you open a 3 year project and find no unit tests.

  • Scrubbles@poptalk.scrubbles.tech
    link
    fedilink
    English
    arrow-up
    57
    arrow-down
    1
    ·
    2 months ago

    It’s happened a few times in my career where people tell me I’ll be obsolete, but it’s always been some company hyping their new product and suits frothing at the prospect of not having to pay me anymore.

    So far they’re like 0 for 8 or so.

    Now I will say the goalposts move. What I’m doing now is for sure not what I was doing 10 years ago. I’m definitely heavier in devops and infra than where I was before (ironic because they said we’d never have to worry about that stuff again if we moved to the cloud). AI is still basically machine learning, just in a while loop, so I’ve spent time learning that. So, in a way, yes we’re obsolete in the sense that if I was the same engineer I was 10 years ago I wouldn’t be worth nearly this much, I had to grow and evolve with technology.

    • UnsavoryMollusk@lemmy.world
      link
      fedilink
      arrow-up
      24
      ·
      edit-2
      2 months ago

      “Don’t worry the salesman told me I would not need an infra team anymore ! Also do you know what is a vpc ?”

      • Scrubbles@poptalk.scrubbles.tech
        link
        fedilink
        English
        arrow-up
        15
        ·
        2 months ago

        Oh don’t worry, you can just pay <<cloud provider>> 30x what you were your infra team before, or if that’s too expensive just pay a consulting form 10x what you would have before. Then they can go dine on steaks while they have the same infra guy you had hired before doing the same stuff just now in “teh cloud”, but making less money

      • leisesprecher@feddit.org
        link
        fedilink
        arrow-up
        13
        ·
        2 months ago

        And DBAs. I’m currently working on a project where I said from the very start, I can set up this DB in k8s and I can get it to work decently, but I have neither the knowledge nor the time to get it right. Please give me someone who knows how this works.

        No, don’t worry, it’ll be fine, we don’t need that, this kuverneles thing I keep hearing about handles that!!!

        Six months of hard contact with the enemy on production later:

        Well, we’re currently looking for someone who actually knows how DBs work, because we have one of those issues that would cost a proper DBA 5min and me 5 months.

        • Scrubbles@poptalk.scrubbles.tech
          link
          fedilink
          English
          arrow-up
          7
          ·
          2 months ago

          I feel like there is a lost art of DBAs, where in their mystical knowledge rests how to make perfect cheap and scalable databases, and business cast them away because “Why not pay Google twice that amount?”

      • corsicanguppy@lemmy.ca
        link
        fedilink
        English
        arrow-up
        5
        ·
        2 months ago

        It was a fancy lie about their spare time, but especially in dotcom, there IS no spare time to learn architecture.

        What I’ve seen of dev AND ops is that their knowledge is focused well on their own things. And when it comes to the other half of devops they just want the shortest path back to doing their thing. This has caused absolute princess devs to be nearly screaming about the hassle of security and change control and infrastructure and proper code deployment and testing and … Well, a lot of things.

        It doesn’t pay to have people learning to half-ass dev because ops is your thing. You need advocacy on both sides of that line, still.

    • leviticoh@poliverso.orgOP
      link
      fedilink
      arrow-up
      5
      ·
      2 months ago

      @scrubbles
      cool

      but it’s always been some company hyping their new product and suits frothing at the prospect of not having to pay me anymore

      i half expected it, after all it’s what’s happening right now

      What I’m doing now is for sure not what I was doing 10 years ago.

      that’s right, i guess some aspects of programming have really been made obsolete

      • corsicanguppy@lemmy.ca
        link
        fedilink
        English
        arrow-up
        7
        ·
        2 months ago

        some aspects of programming have really been made obsolete

        I’d agree that some specifics have been made obsolete. Some habits and routines are currently being ignored or skipped, but the amount of skill that’s gone away is very small.

        As mentioned before, we downsized brutally after Y2K. The people most affected were the highest-paid who weren’t the best code-grinders, and these were the documenters, the programme people, and the mentor types. We lost our guides, our structure, and our historians. We’ve been growing again like feral children rebuilding society from the wasteland like it’s Mad Max, and there’s a LOT of the Why that we either don’t know, that we ignore, or that we skip in the interests of (insert manufactured urgency here).

        We are re-learning some of the whys, but we haven’t yet seen the half-assedry chickens come home to roost on that. The symptoms are there: Boeing’s Gilligan’s Island in Space, supply-chain sploits in waves, personal information lost weekly, all these things that are clipboard hassles we stopped doing that pelrevent massively expensive things later.

        Crowdstrike may die now, mainly because they were marauding leopards we allowed to eat our face. Solarwinds before that, same issue but they seem to be okay. There are dozens of ohShit moments that could lead to similarly preventable problems, that we knew not to do … once.

        Well get there again but we’ll be rediscovering a lot of what some techbro will claim is obsolete, old-practice, too-cautious, hand-wringing in our neu and moderne go-hard/break-lives paradigm.

  • invertedspear@lemm.ee
    link
    fedilink
    arrow-up
    47
    ·
    2 months ago

    Salesforce advertised “No more developers” for awhile in the mid 2010s. It was great fun trying to clean up the mess all the “not programmers” made of those systems. I really hate Salesforce. They must have some of the best sales people on the planet.

    • jonne@infosec.pub
      link
      fedilink
      arrow-up
      13
      ·
      2 months ago

      And now job boards are full of ads for ‘salesforce developers’ that pay ridiculous amounts because nobody really wants to work on salesforce.

      • Skullgrid@lemmy.world
        link
        fedilink
        arrow-up
        2
        ·
        edit-2
        2 months ago

        Hook me up, I work in outsourcing for salesforce and my current job has failed to find me a client for a while now.

        They keep telling me it’s hard to find a client

  • Phen@lemmy.eco.br
    link
    fedilink
    arrow-up
    20
    ·
    2 months ago

    If a tool were created that properly converted an UML diagram into a project without any need for code, all the programmers that lost their job to this tool would then be hired by the company that offered it, in order to give maintenance and support to everything the customers want in their programs.

    It would be removing programmers from they payroll of some companies but they would still be working for them, just further down in the chain.

    The same is true for AI. If AI could completely replace programmers in some area, it would need a lot of programmers itself to keep dealing with all the edge cases that would show up from being used everywhere that a programmer was needed before.

    • SzethFriendOfNimi@lemmy.world
      link
      fedilink
      arrow-up
      16
      ·
      2 months ago

      Besides. Somebody has to convert customer needs into the diagram. Account for what they’re not saying, etc.

      That’s the real essential skill in software dev, not spitting out lines of code.

    • leisesprecher@feddit.org
      link
      fedilink
      arrow-up
      10
      arrow-down
      1
      ·
      2 months ago

      To be fair, a lot of roles simply disappeared over the years.

      Developers today are much more productive than 30 years ago, mostly because someone automated the boring parts away.

      A modern developer can spin up a simple crud app including infrastructure in a day or so. That’s much much more productive than 1995. We just cram a lot more of the world into software, so we need 20x the amount of developers we needed back then.

  • SavvyWolf@pawb.social
    link
    fedilink
    English
    arrow-up
    18
    ·
    2 months ago

    Was before my time, but iirc C and other (then) high level languages were supposedly able to put programmers out of jobs.

    • tias@discuss.tchncs.de
      link
      fedilink
      arrow-up
      10
      ·
      edit-2
      2 months ago

      SQL was explicitly designed to allow “normal humans” to query the database. Nowadays even “normal developers” aren’t able to use it properly.

  • HStone32@lemmy.world
    link
    fedilink
    arrow-up
    17
    ·
    edit-2
    2 months ago

    sometimes, it feels like managers hate engineers, and are constantly plotting their replacement. maybe its because it hurts their ego to know that the engineers they manage worked harder to get there and deserve a higher salary.

    or else, it could be office politics. anyone who can claim to have removed an entire department from payroll is due a huge raise.

    • tias@discuss.tchncs.de
      link
      fedilink
      arrow-up
      7
      ·
      2 months ago

      sometimes, it feels like managers hate engineers

      They hate engineers because the engineers ask difficult questions that somebody needs to answer in order to really automate a process, and they take the time necessary to do so.

    • LesserAbe@lemmy.world
      link
      fedilink
      arrow-up
      7
      arrow-down
      1
      ·
      2 months ago

      I don’t think it’s just managers saying hey we could automate such and such a thing away. It’s human nature to think “how could I improve this” which almost immediately leads to “if I get this right it could mean no work at all”

      • HStone32@lemmy.world
        link
        fedilink
        arrow-up
        5
        ·
        2 months ago

        that explains why the idea to replace engineers would enter peoples minds, but not why they would try so, so hard to get people to believe it.

        • LesserAbe@lemmy.world
          link
          fedilink
          arrow-up
          8
          ·
          2 months ago

          Every business’s biggest expense is labor. Skilled labor costs more. The people in charge like it when you save money.

          I think it’s wrong. But only because the interests of the people who own the machines and businesses diverge from the worker’s interests. I’d like to see more worker cooperatives. If the workers own the machines, then it’s good when things are automated.

          I also don’t believe anything will ever be truly automated, or that it’s a good idea to try.

          All that to say we don’t have to resort to an explanation of “managers must hate engineers” to understand why they would want to eliminate positions.

  • kameecoding@lemmy.world
    link
    fedilink
    arrow-up
    12
    ·
    2 months ago

    “AI” is just another productivity tool, copilot let’s you remove some of the tedious patterned work you do, like writing all those asserts in Unit tests, it’s decent at guessing html structures too.

    So basically it makes a developer faster, but then so do stuff like a good IDE, good plugins for your workflow, etc.

    i saw somewhere an interesting take, even if AI could generate all the code for all the edge cases, you’d still need people to translate what business wants for the AI to understand properly.

    Writing code is already a small part of a developers job, completely eliminating it won’t eliminate a developers job.

    • JakenVeina@lemm.ee
      link
      fedilink
      English
      arrow-up
      27
      ·
      2 months ago

      Even better quote, I love using this one.

      “So, with AI writing code for us, all we need is an unambiguous way to define, what all our business requirements are for the software, what all the edge cases are, and how it should handle them.”

      “We in the industry call that ‘code.’”

  • BeigeAgenda@lemmy.ca
    link
    fedilink
    arrow-up
    12
    ·
    2 months ago

    Rational Rose etc. could generate code from UML diagrams, then you “only” needed architects.

    In reality it only gave a little help during the design phase, as soon as someone touches the generated code, you have to manually merge changes to UML.

    • leisesprecher@feddit.org
      link
      fedilink
      arrow-up
      1
      ·
      2 months ago

      It’s really weird, though, that nobody really created a language/tool to bridge these two world. It’s always just generating one representation from the other, mostly in a bad way.

      I’d argue, that for many problems, a graphical view of the system can help reasoning. But there simply is nothing in that regard.

      • Ephera@lemmy.ml
        link
        fedilink
        arrow-up
        4
        ·
        2 months ago

        For OOP languages, you can definitely get IDE plugins, which create UML from code.

        Personally, I’ve never found them useful, though, partially because our code was never OOP enough, e.g. we were using the actor pattern, or had important modules with functions, or had lots of small classes for handing data around etc…

        But also because it just makes for bad architecture diagrams.
        It has no sense of what’s important and what should be abstracted away. Or how to structure the diagram to make it readable, e.g. REST API at the top, database at the bottom.

        What I also really don’t like about generated architecture diagrams in general (even when the contents are specified via e.g. PlantUML), is that things jump around every time you make a structural change. This means people looking at the diagram have no chance of learning what it looks like, so they can spot changes or know where to look for what they’re interested in.

  • Python@programming.dev
    link
    fedilink
    arrow-up
    11
    ·
    2 months ago

    Dude I WISH an AI would do all the dumb AWS crap for me so that I could just hang out and build React frontends all day

    • 👍Maximum Derek👍@discuss.tchncs.de
      link
      fedilink
      English
      arrow-up
      3
      ·
      edit-2
      2 months ago

      The thing that made me laugh when I saw the article that OP mentions is that it was coming from AWS.

      In my testing AWS’s Titan AI is the least useful for figuring out how to do things in AWS. It’s so terrible that Amazon just announced they’re using Claude for Alexa’s upcoming “AI” features.

  • Elise@beehaw.org
    link
    fedilink
    arrow-up
    10
    ·
    2 months ago

    Fortran was supposed to replace computers (people). Then the computers became Fortran coders.

    • Maeve@kbin.earth
      link
      fedilink
      arrow-up
      4
      ·
      2 months ago

      Was thinking that may be why it’s taking so long. It’s akin to knowing you have to train your human replacement before you’re fired. You can’t possibly teach a program or human everything you know in a limited time; and a great many don’t want to do.

  • RegalPotoo@lemmy.world
    link
    fedilink
    English
    arrow-up
    9
    ·
    2 months ago

    If only we lived in a world so simple as to allow the whims of managers, customers and third parties to be completely definable in UML