How GitHub Actions 10x my productivity

Поделиться
HTML-код
  • Опубликовано: 30 июл 2023
  • Learn how to use GitHub actions continuous integration and delivery in a software development project. In this quick tutorial, we look at 7 powerful ways to automate code with CI/CD.
    #programming #automation
    - My GitHub Actions in SvelteFire github.com/codediodeio/svelte...
    - GitHub Actions Docs github.com/features/actions
    - act cli github.com/nektos/act

Комментарии • 263

  • @snowdane3920
    @snowdane3920 9 месяцев назад +260

    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 9 месяцев назад +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).

    • @user-py8mr3be5e
      @user-py8mr3be5e 9 месяцев назад

      What’s your package about ?

    • @snowdane3920
      @snowdane3920 9 месяцев назад

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

    • @snowdane3920
      @snowdane3920 9 месяцев назад

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

    • @neutron417
      @neutron417 9 месяцев назад +1

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

  • @StefanoV827
    @StefanoV827 9 месяцев назад +284

    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 месяцев назад +7

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

    • @marty0678
      @marty0678 9 месяцев назад +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 9 месяцев назад

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

    • @sungjuyea4627
      @sungjuyea4627 9 месяцев назад +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 9 месяцев назад

      @@sungjuyea4627 I use it on macOS

  • @Sefton.
    @Sefton. 9 месяцев назад +6

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

  • @NaveenKumar-nw4re
    @NaveenKumar-nw4re 9 месяцев назад +23

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

  • @arjix8738
    @arjix8738 9 месяцев назад +19

    @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

  • @JavArButt
    @JavArButt 9 месяцев назад +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.

  • @alanscodelog
    @alanscodelog 9 месяцев назад +22

    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.

  • @kevinandeleven
    @kevinandeleven 9 месяцев назад +65

    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

    • @waldemarperalta2204
      @waldemarperalta2204 9 месяцев назад

      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 7 месяцев назад

      @@waldemarperalta2204 no idea

    • @paologaleotti8478
      @paologaleotti8478 Месяц назад

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

  • @roaringfork
    @roaringfork 9 месяцев назад +109

    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 9 месяцев назад +12

      What circumstances?

    • @uuu12343
      @uuu12343 9 месяцев назад

      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 9 месяцев назад +9

      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 9 месяцев назад +11

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

    • @Bash70
      @Bash70 9 месяцев назад

      @@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.

  • @mattd5419
    @mattd5419 9 месяцев назад +8

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

  • @abhishekshah11
    @abhishekshah11 9 месяцев назад

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

  • @pedrosantos4368
    @pedrosantos4368 9 месяцев назад

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

  • @DevOpsBoss
    @DevOpsBoss 9 месяцев назад

    Top-notch tutorial, as always 👏

  • @emanuelescarsella3124
    @emanuelescarsella3124 9 месяцев назад +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❤

  • @georgiosmylonas3892
    @georgiosmylonas3892 Месяц назад

    Love it! Straight and concise! Thank you!

  • @flyingpanhandle
    @flyingpanhandle 9 месяцев назад +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.

  • @geeshta
    @geeshta 9 месяцев назад

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

  • @CosasCotidianas
    @CosasCotidianas 9 месяцев назад

    The github YAML files look beautiful, very intuitive.

  • @alexanderryndin6686
    @alexanderryndin6686 9 месяцев назад

    Super awesome 😎 and informative. Thanks a lot!

  • @thesleepykoala
    @thesleepykoala 9 месяцев назад

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

  • @psychonek
    @psychonek 9 месяцев назад

    Thank you for nektos/act.

  • @boro057
    @boro057 9 месяцев назад +1

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

  • @wlockuz4467
    @wlockuz4467 9 месяцев назад +1

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

  • @vasiletolea7586
    @vasiletolea7586 9 месяцев назад

    Best video, so far !!!

  • @tomchapman128
    @tomchapman128 9 месяцев назад +12

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

    • @Bash70
      @Bash70 9 месяцев назад

      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 9 месяцев назад +1

      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 9 месяцев назад

      @@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

  • @travel.tales.official
    @travel.tales.official 9 месяцев назад

    I just love your content. ❤

  • @vishalgaurav4411
    @vishalgaurav4411 9 месяцев назад

    right when i needed it!

  • @tyreldelaney
    @tyreldelaney 9 месяцев назад +1

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

  • @blackjackjester
    @blackjackjester 9 месяцев назад +1

    Master branch keep the faith brother

  • @GeneticsGuy
    @GeneticsGuy 9 месяцев назад

    Thank you so much for this

  • @jenewland1999
    @jenewland1999 9 месяцев назад +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 9 месяцев назад

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

  • @frittex
    @frittex 9 месяцев назад +1

    very wise indeed

  • @StudyStreamPlus
    @StudyStreamPlus 4 месяца назад

    Love your videos bro. Thanks.

  • @islamouda356
    @islamouda356 9 месяцев назад +2

    I will debug myself to learn more from you

  • @devabdultech
    @devabdultech 9 месяцев назад

    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 :)

  • @Malephex
    @Malephex 9 месяцев назад +2

    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!

  • @ivandimitrov4410
    @ivandimitrov4410 9 месяцев назад +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.

  • @ExpensivePizza
    @ExpensivePizza 9 месяцев назад

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

  • @kirillpenkin1535
    @kirillpenkin1535 9 месяцев назад

    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)

  • @FauzulChowdhury
    @FauzulChowdhury 9 месяцев назад

    Wright timing. ✅

  • @slob5041
    @slob5041 9 месяцев назад

    Beyond programming

  • @illegalsmirf
    @illegalsmirf 9 месяцев назад

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

  • @VaibhavShewale
    @VaibhavShewale 9 месяцев назад +1

    ooh damn, thats very cool!

  • @PeterKlausSchmelzer
    @PeterKlausSchmelzer 9 месяцев назад

    tx! awesome video..

  • @whichmann9617
    @whichmann9617 9 месяцев назад

    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

  • @Pscytlk
    @Pscytlk 9 месяцев назад

    svelte is gold but react is gem!

  • @shateq
    @shateq 9 месяцев назад

    0:06 is my life motto

  • @ra2enjoyer708
    @ra2enjoyer708 9 месяцев назад +3

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

  • @Kaszanas
    @Kaszanas 4 месяца назад +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.

  • @tannercampbell
    @tannercampbell 9 месяцев назад +1

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

  • @09487abc
    @09487abc 2 месяца назад

    謝謝分享

  • @oktopus_prime
    @oktopus_prime 9 месяцев назад +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 9 месяцев назад +1

      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.

  • @duhby
    @duhby 2 месяца назад

    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

  • @offantik
    @offantik 9 месяцев назад +1

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

  • @wiiznokes2237
    @wiiznokes2237 9 месяцев назад

    Please make a video about auto merging

  • @sofuno863
    @sofuno863 2 месяца назад

    so many fancy names and tools

  • @VintageCOD
    @VintageCOD 9 месяцев назад

    sick

  • @SoreBrain
    @SoreBrain 9 месяцев назад +1

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

  • @sevdalink6676
    @sevdalink6676 9 месяцев назад

    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?

  • @muhammadumarsotvoldiev8768
    @muhammadumarsotvoldiev8768 2 месяца назад

    Thanks

  • @sigstackfault
    @sigstackfault 9 месяцев назад +12

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

    • @lawrencedoliveiro9104
      @lawrencedoliveiro9104 9 месяцев назад

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

  • @cariyaputta
    @cariyaputta 9 месяцев назад +1

    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 9 месяцев назад +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.

  • @iqmal
    @iqmal 9 месяцев назад

    Github action ftw

  • @JackNytely
    @JackNytely 9 месяцев назад

    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 9 месяцев назад +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.

  • @Kingside88
    @Kingside88 9 месяцев назад

    Please make a video about web componend

  • @thantzinoo938
    @thantzinoo938 9 месяцев назад

    I wonder how firebase functions are work with GitHub actions?

  • @DanniDuck
    @DanniDuck 4 месяца назад

    Good enough for me

  • @Raress96
    @Raress96 9 месяцев назад

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

  • @nemanjazivaljevic1656
    @nemanjazivaljevic1656 9 месяцев назад

    Could you do some dewops stack?

  • @stephenson127
    @stephenson127 9 месяцев назад +7

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

    • @dandogamer
      @dandogamer 9 месяцев назад +4

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

    • @stepansigut1949
      @stepansigut1949 9 месяцев назад +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 8 месяцев назад

      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.

  • @mohsinejaz6882
    @mohsinejaz6882 9 месяцев назад

    Hey fireship do tutorials on legend state for react

  • @thekwoka4707
    @thekwoka4707 9 месяцев назад +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 9 месяцев назад +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 9 месяцев назад

      Ansible?

    • @Medik_0001
      @Medik_0001 9 месяцев назад +2

      If you can do it from the command line, yes

  • @uuu12343
    @uuu12343 9 месяцев назад

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

  • @baychaoz
    @baychaoz 9 месяцев назад

    Please make a video about nx

  • @vitalysuper3193
    @vitalysuper3193 9 месяцев назад

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

  • @AmodeusR
    @AmodeusR 9 месяцев назад

    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.

  • @yokowasis
    @yokowasis 9 месяцев назад

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

  • @netlemon
    @netlemon 9 месяцев назад

    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

  • @plaguemusic9104
    @plaguemusic9104 9 месяцев назад

    Im starting with CI/CD

  • @llFike
    @llFike 9 месяцев назад

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

  • @samuelmorgan-tyghe9136
    @samuelmorgan-tyghe9136 9 месяцев назад

    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

  • @henrycullen950
    @henrycullen950 9 месяцев назад

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

  • @brandonwinston
    @brandonwinston 9 месяцев назад +1

    thanks

  • @Offe2246
    @Offe2246 Месяц назад

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

  • @erik-fisher
    @erik-fisher 9 месяцев назад +5

    Man, this AI voice is good!

  • @nexovec
    @nexovec 9 месяцев назад

    It's drone CI all the way for me.

  • @thelinuxlich
    @thelinuxlich 9 месяцев назад

    The only thing missing here is caching the playwright installation

  • @sizur
    @sizur 9 месяцев назад

    Dude, I need your jokes workflow!!!

  • @kazaakas
    @kazaakas 9 месяцев назад

    All good practices, but these can be achieved with a number of SaaS CI/CD tools, not just github actions.

  • @pieter5466
    @pieter5466 9 месяцев назад

    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 9 месяцев назад

    VS code Theme and icon Please

  • @Beryesa.
    @Beryesa. 9 месяцев назад +3

    GitLab CI 😏

  • @blaizeW
    @blaizeW 9 месяцев назад

    idk i just use the google action lol aka release please

  • @thomas6502
    @thomas6502 9 месяцев назад

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

  • @Hermesiss
    @Hermesiss 9 месяцев назад

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

  • @Caringal_Tech
    @Caringal_Tech 9 месяцев назад

    Make GitHub Actions with AWS ECS with EC2

  • @stanleybacklund5614
    @stanleybacklund5614 9 месяцев назад

    I wish it were true that actions fail for no reason "occasionally"

  • @MusicalGeniusBar
    @MusicalGeniusBar 9 месяцев назад +1

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

  • @keyboard_g
    @keyboard_g 8 месяцев назад

    Fireship runs Windows. Interesting.