I saw an issue today on a fairly popular project (better-auth, see the link to the issue attached). No repro, no context, just a wall of caps and profanity ending in “fuck you”. The maintainers ship this for free. People run production businesses on top of it, for free. And the thanks is someone raging into a text box because a minor bump cost them an afternoon.

I maintain and contribute to a few projects myself, so this hits a nerve a bit. Something people don’t see from the outside: it’s not enough to know how to build the thing. You also have to know how to defuse a thread where someone’s insulting you and not fire back, even though most of us aren’t paid for any of it, let alone the work of staying civil while being told to get fucked.

I’m not pretending breaking changes don’t cause real pain (that’s what the issue is about). But I keep coming back to a boundary question: if you’re not paying for it, do you actually get to demand anything? (Obviously yes, but we still need some boundaries)

  • belated_frog_pants@beehaw.org
    link
    fedilink
    arrow-up
    2
    ·
    2 hours ago

    Agree we should treat people better but also: for the love of god learn semver. Breaking changes in minor and patches is so sloppy.

    But still complainers fault for not pinning, because you cannot trust semver at all. Vicious cycle

  • chunes@lemmy.world
    link
    fedilink
    arrow-up
    2
    ·
    4 hours ago

    Let me preface this by saying that you should never, ever be rude to open source maintainers.

    But good god, if you are writing software for other programmers, stop making breaking changes. By all means, break your software. Don’t break mine.

  • baltakatei@sopuli.xyz
    link
    fedilink
    arrow-up
    3
    ·
    5 hours ago

    Imagine the chaos if all the FOSS maintainers collectively went on strike until their demands were met. They could demand so, so much despite being volunteers.

  • architect@thelemmy.club
    link
    fedilink
    arrow-up
    9
    ·
    edit-2
    8 hours ago

    I mean, I told a paying customer to get fucked yesterday over demands so you can definitely say it to a non-paying person.

    • 0x0@infosec.pub
      link
      fedilink
      arrow-up
      1
      ·
      5 hours ago

      If he was a paying customer of mine i would void the purchase and tell him to go fuck himself

  • supersquirrel@sopuli.xyz
    link
    fedilink
    arrow-up
    1
    arrow-down
    1
    ·
    6 hours ago

    Open source development/maintenance is not a thankless job, it is a job that society has not committed to normalizing materially supporting. Those might feel the same, but they are not and it is childish to pretend they are.

  • placebo@lemmy.zip
    link
    fedilink
    English
    arrow-up
    3
    arrow-down
    1
    ·
    9 hours ago

    I’m not pretending breaking changes don’t cause real pain (that’s what the issue is about). But I keep coming back to a boundary question: if you’re not paying for it, do you actually get to demand anything? (Obviously yes, but we still need some boundaries)

    And if the issue makes you lose face, it’s clear you’ve been dealing with it for quite some time and should’ve learned to lock your dependencies and test after updates. Unacceptable.

  • ExLisper@lemmy.curiana.net
    link
    fedilink
    arrow-up
    23
    ·
    16 hours ago

    Not so long ago someone here argued with me that open source devs have a lot of responsibilities and if they can’t make their project easy to contribute they should be banned from open source community (no idea what it would look like). They got upvotes too. Nice to see some sanity here again.

    • wonderingwanderer@sopuli.xyz
      link
      fedilink
      arrow-up
      5
      ·
      8 hours ago

      When that whole rsync stuff came out, I remember arguing with someone about this too.

      Like, I’m not defending AI or the use thereof. I also don’t know the full details of that situation, or how much AI the dev actually used, or for what. That’s not the subject of the argument I was making.

      Basically, I was saying that it’s a FOSS project and the guy has been maintaining it more or less by himself for decades at this point, and it’s become a critical infrastructure that an enormous number of projects (both professional and hobbyist) rely on.

      I said if these people didn’t like how the guy was maintaining his project (for free, and thanklessly at that), then they could either contribute, fork it, or make their own.

      A couple people in that thread were doubling down about how the dev somehow apparently has some sort of responsibility or duty or obligation to run his project the way they think he should. They just didn’t seem to get the fact that he’s doing it for free, it’s his own project, and it’s not his fault that the majority of linux users decided to make it an indispensable part of their backup processes.

      But these people said everything from “you can’t just fork a major project like this, that’s an enormous task with xyz responsibilities” (as if that doesn’t strengthen the point that it is an enormous task which this guy is choosing to do for free) to “if so much critical infrastructure depends on it, then it does oblige the developer to maintain it in such-and-such a way.”

      In the end, I didn’t get through to them. Not that I expected to, but sometimes arguing with these people is more for the lurkers who will read the chain rather than for the people I’m actually arguing with…

      • heartSagan5@lemmy.zip
        link
        fedilink
        arrow-up
        1
        ·
        7 hours ago

        Contribute, fork it, or make their own

        Except this is a bit silly. So, for example, rsync does have an alternative already on the market; it’s called openrsync, but I tried to just “s/rsync/openrsync/“ (in a script) and it is not a 1:1 replacement. And it’s not even close.

        Contributing requires the project maintainer to not be a dick, but with rsync, people have probably been “oh, he’s been doing so good as they are.”

        I might fork rsync (to version freeze) before the AI adds, but it complicates system administration. System administration is easiest using the package management systems. I, personally, believe there are like four Linux versions: pacman, dnf/yum, aptitude, and source.

        • wonderingwanderer@sopuli.xyz
          link
          fedilink
          arrow-up
          1
          ·
          5 hours ago

          Maybe it’s silly to make your own fork, but unless someone else does it and you opt for their alternative, those are your options.

          Complaining about how the dev decides to maintain his own project that he does for free is not one of them.

          He’s been maintaining critical infrastructure for decades. Maybe if you make him a billionaire then he’ll have to run his project however you demand, but as long as this is just a passion project of his, it’s no one else’s business. They can submit bug reports, they can contribute PRs, but cussing him out because you don’t like how he manages his own project is just dumb.

    • TehPers@beehaw.org
      link
      fedilink
      English
      arrow-up
      3
      ·
      15 hours ago

      Having been on the maintainer side of a popular project once before, I’ve pretty much just taken the mindset of “if you owe them nothing, then they owe you nothing”. Basically, pay them, or stop making demands (though suggestions and bug reports are usually welcome by maintainers).

      Incidentally, this is why I didn’t accept donations for that project (though I have nothing against donations in general, of course). I didn’t want to even feel a sense of responsibility to maintain a project I knew I’d eventually burn out from.

      • G_M0N3Y_2503@lemmy.zip
        link
        fedilink
        arrow-up
        4
        ·
        edit-2
        14 hours ago

        I wouldn’t take it as far as paying allows demands. If I decided to pick up some litter in my way in public and some sees it. Just because they shoves a $20 in my face, doesn’t mean they can demand and expect I’ll pick up all the other trash around. There would need to be contract (even just Social) negotiations at the least!

        • TehPers@beehaw.org
          link
          fedilink
          English
          arrow-up
          2
          ·
          14 hours ago

          I wouldn’t take it as far as paying allows demands.

          Neither would I.

          Paying implies exchanging money for something the other party is selling, and would require the other party (the maintainer) to sell it. Shoving $20 in someone’s face is a donation, not a payment.

          I just refused donations for myself. I would never claim a donation gives someone any special right to demand something.

  • carg@feddit.org
    link
    fedilink
    English
    arrow-up
    17
    ·
    edit-2
    17 hours ago

    if you’re not paying for it, do you actually get to demand anything? (Obviously yes, but we still need some boundaries)

    Wrong!! Obviously no. You’re not entitled to demand anything. You can ask politely.

    You don’t like the project? Go and use another alternative.

    There is no alternative? Go and write your own.

    You don’t have the skills? Go and pay somebody with the skills. And if you want the most skilled for the job, probably is the person maintaining that project that you don’t like but still keep using for free.

    • mic_check_one_two@lemmy.dbzer0.com
      link
      fedilink
      English
      arrow-up
      4
      ·
      edit-2
      6 hours ago

      No, they are wrong because they should be pinning a specific version of their dependencies, and then reading patch notes before upgrading. This chud lost face because they didn’t pin their dependencies. Their project was broken for an afternoon, and they were mad that their own ineptitude was put in the spotlight. They flamed a maintainer because they couldn’t be bothered to RTFM before they upgraded.

    • fruitcantfly@programming.dev
      link
      fedilink
      arrow-up
      9
      ·
      14 hours ago

      No, he is wrong. He blindly assumed that the project followed semver, and kept insisting that it did despite the obvious evidence to the contrary. That’s entirely on him

  • Kissaki@programming.dev
    link
    fedilink
    English
    arrow-up
    39
    ·
    edit-2
    1 day ago

    I don’t think there’s a particular need to defuse into a productive discussion. Something like that, with no repro or respect - lock and close, with a comment on why/that onproductive and disrespectful/what it could have been.

    Tone should always be respectful. Something like this should have been a respectful, open suggestion, explaining the issues no clear semver causes.

    If they don’t respond to your needs - you can accept it or leave/fork.

  • kibiz0r@midwest.social
    link
    fedilink
    English
    arrow-up
    37
    arrow-down
    3
    ·
    1 day ago

    Complains about improper release management.

    Apparently not using lockfiles for prod.

    This is not a serious developer.

    • Kissaki@programming.dev
      link
      fedilink
      English
      arrow-up
      3
      ·
      edit-2
      1 day ago

      What makes you think it’s a lockfile issue? If they sighted a patch upgrade then updated the lockfiles but then noticed a breaking change, then lockfiles are irrelevant.

      If it’s actually like they claim, I understand the frustration. (Not that I know this project in particular or how it gets integrated.) Without clear versioning and/or changelogs/release notes managing upgrades is cumbersome, sometimes impossible.

      In some cases I’ve had to ask for clarification in PRs because release notes were not clear, PR was not clear, and resolved ticket was also not clear on the thing or solution.

      Apparently they had issues before, so maybe they could have expected “patch may not be patch-only”.

      • kibiz0r@midwest.social
        link
        fedilink
        English
        arrow-up
        15
        ·
        1 day ago

        It’s the combination of “breaking changes on minor releases” and “disregard for … production environments”.

        Can you stop releasing breaking changes on minor releases? It’s absolutely infuriating that you guys keep doing this over and over again with complete disregard for people downstream using this package in production environments.

        By the time you’re deploying to production, you should already have your versions locked in, so semver does not factor into resolving dependencies for production deployments at all.

        I can understand it being annoying for development processes. Like, if you have a dependabot-style tool that tests against new releases and submits PRs for them, that can definitely be a waste of time and attention if it fails frequently on patch-level updates.

        But in between that “eager testing” step and a production rollout, there needs to be a moment where a human reviews the updates and signs off on updating the lockfile.

        And at that moment, reading the changelog, it really doesn’t matter if it says “1.0.1: breaking changes!” or “2.0.0: breaking changes!”, because you need to be looking at the substance of the update.

        The only way semver violations burn you in a prod env is if you’re YOLOing new versions out there, either by forgoing a lockfile or by merging lockfile updates without review.

        • Feyd@programming.dev
          link
          fedilink
          arrow-up
          4
          ·
          edit-2
          1 day ago

          The reasonableness of your assertion kind of comes down to environment. Say NPM where people go nuts with dependencies (and is the subject here). If for instance there is a security issue in a package used by the package in question and you must update the package in question to get the package with the security warning updated, then you must update the package in question, and there is every expectation in the NPM ecosystem that semver is followed.

          That said, being rude to the developers is immature and counterproductive, and moving to a different solution if a package repeatedly causes problems would be the sane course of action.

  • auzy1@lemmy.world
    link
    fedilink
    arrow-up
    13
    ·
    1 day ago

    Yeah, I started a major project 20 years that got a lot of attention.

    I gave it up after a few months because whilst there was a lot of support, you have to constantly fight against a holes who will tell you how much you suck compared to other options, or how unnecessary you are