• FizzyOrange@programming.dev
    link
    fedilink
    arrow-up
    8
    arrow-down
    1
    ·
    7 months ago

    You need them in CI anyway to check people have actually done that, but yeah you definitely don’t need to have CI automatically fix formatting and commit the fixes. That’s crazy.

    • lemmeBe@sh.itjust.works
      link
      fedilink
      arrow-up
      1
      arrow-down
      5
      ·
      edit-2
      7 months ago

      No, you don’t.

      To check if people have done what - committed? That’s the only thing they need to do, and they’ll stumble upon a roadblock immediately if the typecheck or lint fails.

      Committing itself won’t be possible… That’s why we have automated pre-commit checks that don’t depend on people remembering to do them manually.

      • FizzyOrange@programming.dev
        link
        fedilink
        arrow-up
        5
        arrow-down
        1
        ·
        7 months ago

        To check that people ran the pre-commit linters.

        Committing itself won’t be possible

        That’s not how pre-commit hooks work. They’re entirely optional and opt-in. You need CI to also run them to ensure people don’t forget.

          • FizzyOrange@programming.dev
            link
            fedilink
            arrow-up
            5
            ·
            7 months ago

            No, they’re inherently optional in Git. There’s no way to “check in” a git hook. You have to put in your README

            Clone the repo and then please run pre-commit install! Oh and whatever you do don’t git commit --no-verify!

            You definitely need to actually check the lints in CI. It’s very easy though, just add pre-commit run -a to your CI script.

            • bamboo@lemm.ee
              link
              fedilink
              arrow-up
              2
              ·
              7 months ago

              pre-commit also has a free service for open source GitHub repos too. They’ll even push an autofix commit for you if your tools are configured for it