Hi, I am the developer of PdfDing. One thing I am not sure about is the frequency of my releases. What do you folks prefer in self-hosted projects? More releases in order to get new features as fast as possible or fewer releases with bigger feature additions?

  • Axum@lemmy.blahaj.zone
    link
    fedilink
    English
    arrow-up
    27
    ·
    3 days ago

    This isn’t something that should really be set by users of an app. It should be set by you, as you will be the one to handle user feedback and bug reports.

    That being said, bigger releases are a challenge from a debugging report standpoint because you are introducing many more changes in each release compared to a smaller number of charges in more frequent releases. This is why many devops teams in corporate land try to keep releases smaller and more frequent (see also: Agile Development)

    • Onomatopoeia@lemmy.cafe
      link
      fedilink
      English
      arrow-up
      3
      ·
      3 days ago

      Very good point about Agile.

      As an end-user (that is, the IT staff that will be deploying/managing things), I prefer less-frequent releases. I’d love to see 1 or 2 releases a year for all software (pipe dream, I know). Once you have a handful of packages, you end up with constant change to manage.

      I suspect what we end up with is early adopters embracing the frequent releases, and providing feedback/error reporting, while people like me benefit from them while choosing to upgrade less frequently.

      There are about 3 apps that I’m a beta tester for, so even I’m part of that early-adopter group.

    • folkrav@lemmy.ca
      link
      fedilink
      English
      arrow-up
      1
      ·
      3 days ago

      From experience shipping releases, “bigger updates” and “more tested” are more or less antithetical. The testing surface area tends to grow exponentially with the amount of features you ship with a given release, to the point I tend to see small, regular releases, as a better sign of stability.

  • sugar_in_your_tea@sh.itjust.works
    link
    fedilink
    English
    arrow-up
    5
    ·
    3 days ago

    As long as updates work between any two versions, or there’s a clear upgrade path, I don’t really care. I don’t update my services on any particular schedule, so it doesn’t matter much to me.

    However, you should have a mechanism to inform users of important updates, like patches to known exploits. Don’t spam me, but a nudge if I’m outside of some support window will probably get me to upgrade.

    My upgrade cadence is probably every 3-6 months. I’ll do system upgrades more often, but I try to avoid breaking my docker stuff.

  • gencha@lemm.ee
    link
    fedilink
    English
    arrow-up
    5
    ·
    3 days ago

    I’ve been maintaining multiple release channels for most of my projects. I always have a nightly build and a dev build that I run manually or on every push. Actually versioned releases either happen directly after completing a milestone or when the release schedule calls for it.

  • Ferawyn@lemmy.world
    link
    fedilink
    English
    arrow-up
    4
    ·
    edit-2
    3 days ago

    Security and bugfixes, after one or two rounds of testing by early adopters/key users. Preferably through some form of automatic updates.

    New features and breaking changes, or anything that requires the end-user to pay attention, I’d say no more than 4 times a year, and using a non-automatic form of update. The hard thing is getting the user’s attention on the changes, and not just clicking next and then having a broken or insecure installation.

  • catloaf@lemm.ee
    link
    fedilink
    English
    arrow-up
    4
    ·
    3 days ago

    Most of my updates are automated so I don’t even notice. Release whenever you think it’s appropriate. Fixed a typo? Not worth a release. Critical security issue? Release immediately.

  • Higgs boson@dubvee.org
    link
    fedilink
    English
    arrow-up
    3
    ·
    edit-2
    3 days ago

    My background is in enterprise software, so that is obviously different than a desktop tool for individual use, but it informs my opinions.

    In general it depends on the use (is it “production” critical, etc) as well as the update and distribution mechanisms.

    I have several (mostly for windows) FOSS projects i have stopped using or just rarely update because they require too many steps to update, and/or do so too often.Or they require a reboot. Some of them prompt for an update every time I start them. Feh.

    That said, if there isn’t much friction like testing cycles or manual steps to update, I want faster updates.

    Most of my self-hosted stuff falls into the category of getting updates via package managers or docker. Those are often seemless and do not require manual steps.

  • Stefano Prenna@lemmy.stefanoprenna.com
    link
    fedilink
    English
    arrow-up
    3
    ·
    3 days ago

    Less releases with more testing. I normally wait some time before upgrading (no matter the application) as I prefer stability over extra/new features that I may use or not.

    • poVoq@slrpnk.net
      link
      fedilink
      English
      arrow-up
      1
      ·
      3 days ago

      I think the better option is to have many releases that are clearly marked as beta-test releases or release candidates for those that don’t mind testing stuff.

  • nnullzz@lemmy.world
    link
    fedilink
    English
    arrow-up
    1
    ·
    edit-2
    3 days ago

    I personally prefer consistent and smaller releases. It offers less opportunity for big bugs to creep in along with smaller fixes and features.

    I saw agile mentioned here but here’s another suggestion. Agile can be helpful in the right situations but for solo devs/tiny teams, I really recommend looking into Basecamps “Shape Up” method. It uses longer cycles vs shorter sprints with a cool down period in between.

    So in the case of OP, they could set a 6 week cycle and plan for things that can definitely be completed during that time period. Right at the end of the cycle you release. The goal is to finish before the cooldown to give yourself time to breathe and plan what to do for your next cycle. Play around with a fun feature, learn about a new tool or technique you wanna try, organizing your backlog, etc. You don’t want to spill tasks into the cooldown. Else it’s not a cooldown.

    The online version of the Shape Up book is free and can be found here.