How GitHub Actions 10x my productivity

แชร์
ฝัง
  • เผยแพร่เมื่อ 10 ม.ค. 2025

ความคิดเห็น • 277

  • @StefanoV827
    @StefanoV827 ปีที่แล้ว +317

    Great video! I didn't know about Act, I'm gonna install it RN.
    I would like to add:
    I recommend using paths-ignore (inside push and below branches) to trigger a specific workflow only when a specific path is involved.
    For example if the docs folder is another project, if you push a readme update inside the project, all the workflow will run test again wasting you free minutes. With paths-ignore you can specify which path to ignore.

    • @querela92
      @querela92 ปีที่แล้ว +9

      Yes, I found this trick recently and this was great for only building/testing those modules that changed.

    • @marty0678
      @marty0678 ปีที่แล้ว +11

      Act doesn't run 1:1 to GitHub Actions, doesn't support all third party actions, and is missing a few feature parity things that will crash with Act but works fine on Actions but it's still a huge life saver when testing 80% of things.
      Act also exposes act specific env variables so you can skip steps when running locally for example, which helps getting around some of these issues.

    • @ServetTonga
      @ServetTonga ปีที่แล้ว

      @@marty0678 I agree, something may fail in act but work in actions.

    • @sungjuyea4627
      @sungjuyea4627 ปีที่แล้ว +1

      I tried it several times but it seems like they don't work on macOS? I might be missing sth but from my experience act didn't work for me.

    • @ServetTonga
      @ServetTonga ปีที่แล้ว

      @@sungjuyea4627 I use it on macOS

  • @Sefton.
    @Sefton. ปีที่แล้ว +21

    This is my favourite type of content, covering stuff nearly every developer uses or should be using and showing tips, tricks etc.

  • @snowdane3920
    @snowdane3920 ปีที่แล้ว +283

    The timing of this tutorial... I've been meaning to use GitHub actions to maintain a npm package... This couldn't have come out at a better time

    • @YuriG03042
      @YuriG03042 ปีที่แล้ว +1

      He already did a smaller video about it on the main channel 2 or 3 years ago. The only difference is that he used Node 12 back then which is either deprecated or downright removed now (can't remember what the Github blog post mentioned).

    • @ウタ-u1g
      @ウタ-u1g ปีที่แล้ว +1

      What’s your package about ?

    • @snowdane3920
      @snowdane3920 ปีที่แล้ว

      @@YuriG03042 I seem to have missed that video somehow 🙈

    • @snowdane3920
      @snowdane3920 ปีที่แล้ว

      @@ウタ-u1g it's a fork of unmaintained calendar library for vue which I am slowly modifying for my office's needs

    • @neutron417
      @neutron417 ปีที่แล้ว +1

      I've just used it to add latest blogs to my readme lol

  • @kevinandeleven
    @kevinandeleven ปีที่แล้ว +73

    Hosted runners are life savers.. I basically use them for all my server work.. Once🎉 I push code, a self hosted runner running on the servers pulls the changes and restarts the server

    • @woops30
      @woops30 ปีที่แล้ว

      I configured a self hosted runner on digitalocean. Do you know if it's possible to have multiple self hosted runners on the same VM? maybe with containers or something like that?

    • @kevinandeleven
      @kevinandeleven ปีที่แล้ว

      @@woops30 no idea

    • @paologaleotti8478
      @paologaleotti8478 9 หลายเดือนก่อน

      @@woops30 it is, simply start multiple and make sure they are named differently

  • @NaveenKumar-nw4re
    @NaveenKumar-nw4re ปีที่แล้ว +28

    Currently working on setting CI/CD on a project. what a time to upload the video👌

  • @roaringfork
    @roaringfork ปีที่แล้ว +120

    Github Actions actually spins up a whole vm. There are very specific circumstances in which this is important as I spent two weeks learning.

    • @ZeroYT
      @ZeroYT ปีที่แล้ว +14

      What circumstances?

    • @uuu12343
      @uuu12343 ปีที่แล้ว

      TIL in theory, you can self-hosted github actions if there's a way to redirect the builder
      To be fair, that would mean you are not using github lmao

    • @Bash70
      @Bash70 ปีที่แล้ว +11

      It doesn't have to use a whole vm. I configured a docker container to act as a runner so I could run nested docker containers inside of it.

    • @thekwoka4707
      @thekwoka4707 ปีที่แล้ว +12

      @@Bash70 it still uses a full VM to run your action container.

    • @Bash70
      @Bash70 ปีที่แล้ว

      @@thekwoka4707 Like I said, it depends on how the runner is setup. The runners that Github itself uses are full VMs but you can setup up your own self-hosted runners that are just containers.

  • @arjix8738
    @arjix8738 ปีที่แล้ว +22

    @Beyond Fireship Actually, if the project repo is public, then the workflows are free w/o limit (other than the 6 hour limit that all workflows have)
    the 2000 free minutes are for private repositories

  • @mattd5419
    @mattd5419 ปีที่แล้ว +10

    I had no idea something like act existed, you just saved me a shit ton of time!

  • @alanscodelog
    @alanscodelog ปีที่แล้ว +24

    I've been using this setup (actions/act) but with semantic-release for a while. It's perfection. Don't even have to think about bumping versions / changelogs / publishing. Also you can create a little workflow badge to put on the repo or to keep a link to. Nice for having an overview of the state of several repos.

  • @JavArButt
    @JavArButt ปีที่แล้ว +7

    Within the first 16 seconds, I had to laugh/smile multiple times. Your sense of humor is great. Also, the time and deep thoughts you spend int this work is clearly visible.

  • @wlockuz4467
    @wlockuz4467 ปีที่แล้ว +2

    Calling it life-saver is an understatement to be honest.

  • @tomchapman128
    @tomchapman128 ปีที่แล้ว +14

    The selfhosted runners are super easy to set up, i did it and that way you also dont hsve any rate limits!

    • @Bash70
      @Bash70 ปีที่แล้ว

      It depends. For me, I have a M1 laptop and it wasn't functioning properly when I set it up as a runner so I had to go about configuring a docker container as a runner so I could then run nested containers inside of it, which was excruciating.

    • @bryce.ferenczi
      @bryce.ferenczi ปีที่แล้ว +3

      As long as you recognise the warning they include with the option, if someone makes a pr on your public repo and it triggers some test, then whatever code they submitted will be run on your machine which may include malware.

    • @tomchapman128
      @tomchapman128 ปีที่แล้ว

      @@Bash70 oh yeah I hadn't considered Macs, I ran mine on Linux but yeah I guess other OSs could definitely make things more difficult

  • @jonpon-r6w
    @jonpon-r6w 3 หลายเดือนก่อน +1

    Imagine watching a entire course with this intonation video after video for hours.

  • @abhishekshah11
    @abhishekshah11 ปีที่แล้ว +1

    I had act but never knew how to use it right! Thanks for showing us!

  • @thesleepykoala
    @thesleepykoala ปีที่แล้ว

    I like that fact he is smart and advertises his products.

  • @flyingpanhandle
    @flyingpanhandle ปีที่แล้ว +5

    I like to use Volta in my projects, handily you can then use Volta in your GHA pipeline. No need to specific node or npm/pnpm/yarn versions any more. It will use exactly the version the project was developed on. Which is fantastic when upgrading node version.

  • @wsollers1
    @wsollers1 7 หลายเดือนก่อน +1

    Great video! Taught me enough to get automation on.

  • @georgiosmylonas3892
    @georgiosmylonas3892 9 หลายเดือนก่อน +1

    Love it! Straight and concise! Thank you!

  • @Malephex
    @Malephex ปีที่แล้ว +3

    I can't tell you how much time I've wasted in the past, pushing 1 byte changes to make a CI pipeline run while debugging the flow, all the time wishing I could just run the damn yaml/json/whatever file locally to simulate the CI/CD server ... thanks for the "act" tip!

  • @geeshta
    @geeshta ปีที่แล้ว +1

    I knew about GH actions but I never knew about act! Thanks

  • @emanuelescarsella3124
    @emanuelescarsella3124 ปีที่แล้ว +1

    I would have liked a video like this when I first learned GitHub actions, but still now I have to configure a new more complex project so that's still a good timing for me❤

  • @pedrosantos4368
    @pedrosantos4368 ปีที่แล้ว

    Thanks for sharing! I started looking a bit more into GitHub actions, yesterday

  • @tyreldelaney
    @tyreldelaney ปีที่แล้ว +1

    I did not know about the act package, that's a pretty nifty tool

  • @boro057
    @boro057 ปีที่แล้ว +2

    Cool, I understood some of the words in this one!

  • @blackjackjester
    @blackjackjester ปีที่แล้ว +1

    Master branch keep the faith brother

  • @ExpensivePizza
    @ExpensivePizza ปีที่แล้ว +1

    I didn't know about `act`. That's cool.

  • @CosasCotidianas
    @CosasCotidianas ปีที่แล้ว

    The github YAML files look beautiful, very intuitive.

  • @duhby
    @duhby 10 หลายเดือนก่อน

    7:58 a use case for self-hosted runners is if you run docker containers on a vps and want to automate the creation of images without having to git pull and run the commands yourself every time

  • @DevOpsBoss
    @DevOpsBoss ปีที่แล้ว

    Top-notch tutorial, as always 👏

  • @SamRussell-NL
    @SamRussell-NL 5 หลายเดือนก่อน

    Great video - lots of useful resources and content

  • @ra2enjoyer708
    @ra2enjoyer708 ปีที่แล้ว +3

    6:13
    I fucking love cron magic strings, this for sure won't backfire in the future.

  • @illegalsmirf
    @illegalsmirf ปีที่แล้ว

    For an 'automated' solution that sure sounds complex and convoluted.

  • @islamouda356
    @islamouda356 ปีที่แล้ว +3

    I will debug myself to learn more from you

  • @vasiletolea7586
    @vasiletolea7586 ปีที่แล้ว

    Best video, so far !!!

  • @Kaszanas
    @Kaszanas ปีที่แล้ว +1

    I use a slightly different approach where I run a container inside GitHub Actions and run all of the commands against that container which acts as a development container too. So I achieve a couple of things at the same time. I do not need act to test my actions because all of the logic behind my actions is containerized anyway.

  • @JackNytely
    @JackNytely ปีที่แล้ว

    8.5k views, 685 likes but only 25 comments (as of the time writing this)
    I really appreciate your videos and content, so here, take this free comment to sacrifice to the algorithm gods.

    • @TheSmokedDog
      @TheSmokedDog ปีที่แล้ว +3

      I open these videos out of routine, sometimes I don't even watch, they just play in the background. I like his voice. Sometimes I learn something, but usually I don't.

  • @travel.tales.official
    @travel.tales.official ปีที่แล้ว

    I just love your content. ❤

  • @StudyStreamPlus
    @StudyStreamPlus ปีที่แล้ว

    Love your videos bro. Thanks.

  • @alexanderryndin6686
    @alexanderryndin6686 ปีที่แล้ว

    Super awesome 😎 and informative. Thanks a lot!

  • @cariyaputta
    @cariyaputta ปีที่แล้ว +2

    Thanks. Didn't know Act before, so every time I want to change the workflow I have to wait for the whole run like an idiot.

    • @Bash70
      @Bash70 ปีที่แล้ว +1

      Act is pretty limited though. Doesn't work for trigger inputs and in my case, I had to actually run a nested container for my tests so Act was pretty much useless.

  • @devabdultech
    @devabdultech ปีที่แล้ว

    watched it now, got the basic idea but im currently not using or planning to use or learn it now. I'll be back soon :)

  • @psychonek
    @psychonek ปีที่แล้ว

    Thank you for nektos/act.

  • @Videx89
    @Videx89 ปีที่แล้ว

    svelte is gold but react is gem!

  • @ivandimitrov4410
    @ivandimitrov4410 ปีที่แล้ว +4

    I've been doing some GitHub actions with install-nix-action and then running 'nix build' which covers all dependencies and declaratively builds the project. Maybe you can make a video on nix next.

  • @shateq
    @shateq ปีที่แล้ว

    0:06 is my life motto

  • @whichmann9617
    @whichmann9617 ปีที่แล้ว

    This is truly great but I just wish there was a feature that would automate that one thing I need to manually do every day at my current project

  • @jenewland1999
    @jenewland1999 ปีที่แล้ว +6

    Great video, Jeff! 🔥 Was so great to learn about act - I looked for a solution like this a while back and couldn't find anything. Quick question though: Is there any specific reason for using v2 over v3 of actions/checkout and action/setup-node?

    • @GamesterTheBest7
      @GamesterTheBest7 ปีที่แล้ว

      Yuh much agreed. @v2 is going to give a deprecation warning for node 12.

  • @tannercampbell
    @tannercampbell ปีที่แล้ว +1

    you mean you don’t have like dozen of commits “CI TEST”? would love a breakdown on that act tool!

  • @vishalgaurav4411
    @vishalgaurav4411 ปีที่แล้ว

    right when i needed it!

  • @sigstackfault
    @sigstackfault ปีที่แล้ว +12

    Do GitLab next? Would help a lot of us which have Corporate GitLab servers

    • @lawrencedoliveiro9104
      @lawrencedoliveiro9104 ปีที่แล้ว

      All these features are not compatible between the different services. That’s why I try to stick to common functionality.

  • @VaibhavShewale
    @VaibhavShewale ปีที่แล้ว +1

    ooh damn, thats very cool!

  • @slob5041
    @slob5041 ปีที่แล้ว

    Beyond programming

  • @SoreBrain
    @SoreBrain ปีที่แล้ว +1

    I can't believe I didn't know about act

  • @GeneticsGuy
    @GeneticsGuy ปีที่แล้ว

    Thank you so much for this

  • @stephenson127
    @stephenson127 ปีที่แล้ว +7

    How do you automate versioning? Do you have to version bump manually in yml with each release?

    • @dandogamer
      @dandogamer ปีที่แล้ว +4

      Use semantic versioning, it looks at your conventional commits to determine version based off the commit message

    • @stepansigut1949
      @stepansigut1949 ปีที่แล้ว +1

      Versioning with commit messages is a bad idea - you will run into conflicts during merges. Use git tags to version and inject tag values into your project files during build if you need to access the version from code.
      Git tags can be also used to trigger special actions which do not get triggered otherwise (e.g. run deploy, build docs, run database migrations…)

    • @nandertga
      @nandertga ปีที่แล้ว

      Assuming you're using semantic versioning and conventional commits in your project, you can use a tool like semantic release to automagically determine the next version number.

  • @Im_Ninooo
    @Im_Ninooo ปีที่แล้ว +354

    10x is not a verb, sir

    • @MrAjiii
      @MrAjiii ปีที่แล้ว +34

      *10xed

    • @adamjones7497
      @adamjones7497 ปีที่แล้ว +29

      Did you “google” that?

    • @lawrencedoliveiro9104
      @lawrencedoliveiro9104 ปีที่แล้ว +33

      Somebody is trying to 10x their grammar. And failing ...

    • @s1nistr433
      @s1nistr433 ปีที่แล้ว +12

      10x ur mom

    • @pabindhami
      @pabindhami ปีที่แล้ว +3

      Not a Grammer class😢

  • @oktopus_prime
    @oktopus_prime ปีที่แล้ว +1

    Have you had any experience shortening that feedback loop earlier on the process, let's say at the pre-commit timeframe? I ask because we would commit things up to the repo to fire off a pipeline and then get fredback a few minutes later. It felt nicer (to me) to abort our commit if our tests, or linting failed. Yes there is always the option to force it through, but I liked that immediate feedback locally before something small and dumb was sent up.

    • @thekwoka4707
      @thekwoka4707 ปีที่แล้ว +2

      Yeah, unit tests and linting and formsttkng should be pre-commit since they should be very fast.
      Then they can also be in the PR and the PR can also have the longer processes like e2e tests, builds, etc.

  • @FauzulChowdhury
    @FauzulChowdhury ปีที่แล้ว

    Wright timing. ✅

  • @vitalysuper3193
    @vitalysuper3193 ปีที่แล้ว

    0:00 that sound make subwoofers hit me in the back. aa

  • @offantik
    @offantik ปีที่แล้ว +1

    hi I noticed that you use v2 actions that produce tons of warnings about nodejs deprecating, can you use v3?

  • @thekwoka4707
    @thekwoka4707 ปีที่แล้ว +2

    I disagree with npm CI for these.
    I use pnpm and cache the store (and even node modules itself) to speed up actions (cache key is the package-lock hash)
    Npm is slow, and CI prevents any caching options.

  • @magicking3888
    @magicking3888 ปีที่แล้ว +2

    Is it possible to configure github actions to auto deploy to a custom server instead of big company servers like azure or aws?

    • @vincentnthomas1
      @vincentnthomas1 ปีที่แล้ว

      Ansible?

    • @Medik_0001
      @Medik_0001 ปีที่แล้ว +2

      If you can do it from the command line, yes

  • @frittex
    @frittex ปีที่แล้ว +1

    very wise indeed

  • @wiiznokes2237
    @wiiznokes2237 ปีที่แล้ว

    Please make a video about auto merging

  • @deltadev_official
    @deltadev_official ปีที่แล้ว

    what I don t like about Github Actions is that it doesn t support yml aliases which makes the file quite cluttered for big ci cds pipelines

  • @Raress96
    @Raress96 ปีที่แล้ว

    You have both main and master branches?
    What is this madness branching strategy? :))

  • @PeterKlausSchmelzer
    @PeterKlausSchmelzer ปีที่แล้ว

    tx! awesome video..

  • @AmodeusR
    @AmodeusR ปีที่แล้ว

    Where was written the playwright test code? I only saw you linking it to the actions or something like that, but you never made the code that makes the test. I don't get it.

  • @mohsinejaz6882
    @mohsinejaz6882 ปีที่แล้ว

    Hey fireship do tutorials on legend state for react

  • @sevdalink6676
    @sevdalink6676 ปีที่แล้ว

    I have used github actions to trigger tests on every push. But I experienced very slow behavior. Even for a very small small project it took tens of minutes to complete. Is it normal to take so long?

  • @kirillpenkin1535
    @kirillpenkin1535 ปีที่แล้ว

    Hey) The video is awesome))) Thank you.
    I have a question thought: In a github issue page there s a button "create branch" (inside the Development section of the right panel). Is there a way to trigger an action that changes a state of the corresponding issue to inProgress when a branch is created using this button?
    I use github project to manage issues. Its awesome too)

  • @nemanjazivaljevic1656
    @nemanjazivaljevic1656 ปีที่แล้ว

    Could you do some dewops stack?

  • @uuu12343
    @uuu12343 ปีที่แล้ว

    Brb gonna write-up a guide on Github Actions, am not gonna plow through life without a CI/CD engine

  • @thantzinoo938
    @thantzinoo938 ปีที่แล้ว

    I wonder how firebase functions are work with GitHub actions?

  • @Offe2246
    @Offe2246 9 หลายเดือนก่อน

    If I give gpt the link of the video can build the app automatically?

  • @baychaoz
    @baychaoz ปีที่แล้ว

    Please make a video about nx

  • @yousifakbar
    @yousifakbar ปีที่แล้ว +8

    I don't think it's technically true that GitHub spins up a container when you start a workflow. I believe they connect you to a full VM.

    • @dingus4138
      @dingus4138 ปีที่แล้ว +2

      They use microvms and spin up containers inside them for certain action types. But a lot of it can be done using the base VM.

    • @MrAjiii
      @MrAjiii ปีที่แล้ว +1

      They're all containers!

  • @Hermesiss
    @Hermesiss ปีที่แล้ว

    I think I heard the basement slaves at 7:32 doing animations for the daily code reports

  • @Kingside88
    @Kingside88 ปีที่แล้ว

    Please make a video about web componend

  • @BrazilMentionedHueHue
    @BrazilMentionedHueHue ปีที่แล้ว

    is act stable now? I had so many bad experiences with it in the past :(

  • @DevThought
    @DevThought ปีที่แล้ว +1

    Act is not working on M1 macbook.

  • @yokowasis
    @yokowasis ปีที่แล้ว

    something important missing, you should have explain how to deploy the code on your production machine upon code push.

  • @samuelmorgan-tyghe9136
    @samuelmorgan-tyghe9136 ปีที่แล้ว

    I gave up on making some ai that reads the code / commit messages and finds relevant memes to it and adds it to the or description

  • @omomer3506
    @omomer3506 ปีที่แล้ว

    CV/Resume
    Skills:
    Ci/CD expert

  • @braitschsf
    @braitschsf ปีที่แล้ว

    Here are 27 hoops you can jump through to make your life easier

  • @henrycullen950
    @henrycullen950 ปีที่แล้ว

    Could you please do a video on free tools and services? It would be very handy after the death of heroku

  • @rushikeshsherekar4482
    @rushikeshsherekar4482 ปีที่แล้ว +1

    Dude if I implement the automated test while a release on git i will lose my job 😶… and before ai, i will be the one to make my job absolute 😶

  • @sizur
    @sizur ปีที่แล้ว

    Dude, I need your jokes workflow!!!

  • @plaguemusic9104
    @plaguemusic9104 ปีที่แล้ว

    Im starting with CI/CD

  • @timeflier350
    @timeflier350 3 หลายเดือนก่อน

    Soo many things too install, it's overhwelming

  • @iqmal
    @iqmal ปีที่แล้ว

    Github action ftw

  • @thelinuxlich
    @thelinuxlich ปีที่แล้ว

    The only thing missing here is caching the playwright installation

  • @thomas6502
    @thomas6502 ปีที่แล้ว

    Ah yes, who doesn't love the model: "The first one is free..."

  • @nexovec
    @nexovec ปีที่แล้ว

    It's drone CI all the way for me.

  • @erik-fisher
    @erik-fisher ปีที่แล้ว +5

    Man, this AI voice is good!

  • @blaizeW
    @blaizeW ปีที่แล้ว

    idk i just use the google action lol aka release please

  • @MusicalGeniusBar
    @MusicalGeniusBar ปีที่แล้ว +1

    Wait, this is about testing my project, I’m out 😂

  • @pieter5466
    @pieter5466 ปีที่แล้ว

    I wonder whether anyone has setup completely standardized projects for use cases like "Python3 in a Docker image", including GitHub actions, linting and testing and whatnot.

  • @AdityaKumar-cy2cr
    @AdityaKumar-cy2cr ปีที่แล้ว

    VS code Theme and icon Please

  • @smthngsmthngsmthngdarkside
    @smthngsmthngsmthngdarkside 9 หลายเดือนก่อน

    Use ASDF instead of node setup