Never* use git pull

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

ความคิดเห็น • 1.7K

  • @philomatics
    @philomatics  8 หลายเดือนก่อน +533

    A few details that were mentioned in the comments (Thanks!):
    Of course git pull is (by default) just a fetch + merge, but I left out that detail for the sake of brevity. I'd like to explain this a bit better in a future video.
    Also, if you're _sure_ that nobody else is using the branch you're pulling from, it's definitely fine to pull! So the advice from this video doesn't always apply if you're using feature branches that only one dev is working on, or if you're squashing on merge. I've just seen a lot of teams that use different branching strategies (or don't have one in place at all). But it also doesn't really hurt in that case, since doing `git pull --rebase` will just do a regular pull then.
    A common question was: *Why should you abort the rebase?*
    If you already know how to fix merge conflicts during an interactive rebase, by all means, go ahead! You don't _need to_ abort, just fix the conflict. That's even better than aborting and merging. I just thought it would be a bit overwhelming for this video to _also_ explain interactive rebasing and fixing merge conflicts. I do have videos planned on resolving merge conflicts and interactive rebasing, stay tuned!
    One more thing people mentioned is that you can configure git pull so that it will _always_ rebase by default. I was a bit wary of recommending this to people, since it changes the default behavior of a pretty common command, which might cause confusion (especially if you forget about it a few months later). If you want to make pull rebase the default, run `git config --global pull.rebase true`. From then on, `git pull` will rebase, and `git pull --merge` will merge.
    In newer versions of git, it will even ask you upon first use which pull strategy you prefer.
    Also, this video really blew up beyond my wildest imaginations! Thank you all for your support and nice comments! Next video is in the works and will be released on Monday. If you enjoyed this one, please consider subscribing to not miss it.

    • @Misteribel
      @Misteribel 8 หลายเดือนก่อน +31

      It's a good intro video. But most public OSS repositories, and virtually every project I've ever worked on in company settings, require PRs before merging (or rebasing) onto main. Here, you assume people work directly on the main branch and commit to it. I'd strongly advise against that as soon as you work on something with more than one person. Furthermore, PRs give you the added benefit of reviews, discussions, and documenting your change.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +22

      @@Misteribel I think I probably should've clarified in the video better that it doesn't have to be the main branch, but it could be any branch. Of course if you use feature branches that are exclusive to a single person, that shouldn't happen, but I've seen a lot of teams where that isn't the case, where branches are shared.

    • @stjepanmajdak7396
      @stjepanmajdak7396 8 หลายเดือนก่อน +5

      ​@@Misteribelcheck out trunk based development

    • @Carltoffel
      @Carltoffel 8 หลายเดือนก่อน +5

      I really like the brief video + the explanations in the comment. This could become a concept for your channel: A brief video with an overview plus FAQ/more details in the video description or comments.

    • @CJ-eq3bs
      @CJ-eq3bs 8 หลายเดือนก่อน +6

      It's not huge deal but I often don't see why some developers want a clean hist. Not like your viewing it for fun. You only look at it when there is an issue. Having the full history as it was is no big deal may also shed light on why something went wrong on post mordum. Now if you are suggesting to do this on your private branch I absolutely don't mind developers using this approach. On shared branc0hes I think it is best to leave hist as is. 🥂

  • @JannisAdmek
    @JannisAdmek 8 หลายเดือนก่อน +3513

    I'd tell John to get off my branch or create a new branch and rebase it to John's.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +340

      Heh, yup, that also works :) Get off my lawn, John!

    • @moonchildeverlasting9904
      @moonchildeverlasting9904 8 หลายเดือนก่อน +117

      for the love of jesus. nO!!! for every new feature, every new commit, make a branch, then push that branch and work on it until you have the code you require, then push

    • @shawncicoria
      @shawncicoria 8 หลายเดือนก่อน +16

      I have the same John on my team. Keep off my lawn

    • @glhays6832
      @glhays6832 8 หลายเดือนก่อน +19

      John was on my lawn as well, mowing over my work and trying to break my branch. I quickly stashed my mower in the shed, took his work and popped my mower back out and merged our lawn work. Pushed all the good work back onto the branches landscape. Alls good John.

    • @romanstingler435
      @romanstingler435 8 หลายเดือนก่อน

      @@philomatics git push --force with commit message F* U John

  • @toxx1220
    @toxx1220 8 หลายเดือนก่อน +395

    00:38 "But theres an easy fix, ... just use *git push --force* XD

    • @fr9714
      @fr9714 5 หลายเดือนก่อน +9

      You should do force-with-lease imo

    • @nisonatic
      @nisonatic 3 หลายเดือนก่อน +12

      x10 developer move.

    • @mrtbts
      @mrtbts 3 หลายเดือนก่อน +20

      john : where tf did my commit go

    • @AlexRaylight
      @AlexRaylight 3 หลายเดือนก่อน +14

      Haven't you heard? Forcing is frowned upon these days, you need CONSENT!

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

      That's why I forbid force pushes in our repos ;)

  • @qwfp
    @qwfp 8 หลายเดือนก่อน +914

    I think the problem starts at step 0, where you and John are both working on the main branch. Ideally you'd have two separate feature branches, that would be merged to main when they are finished

    • @sauliustb
      @sauliustb 8 หลายเดือนก่อน +40

      not if you're doing trunk based development. then you just don't have feature branches, and you have regular merges with main branch in 2 directions.

    • @ChristianConrad
      @ChristianConrad 8 หลายเดือนก่อน +98

      @@sauliustb : Which is why trunk-based development has always seemed rather weird to me. Why use a workflow where you have to come up with weird workarounds for doing this without branches, when doing this is exactly what branches are for?

    • @sauliustb
      @sauliustb 8 หลายเดือนก่อน +49

      @ChristianConrad because any company I've worked in that used feature branching had issues with merge/rebase, or with long-living branches that were hard to integrate when it was allowed.
      Trunk based makes small, production-safe commits, which reduces the chances of conflicts, as well as ensuring rigorous testing.
      All work must stop if branch on origin is red in the CI/CD tool(though it shouldn't ever be red...)

    • @ttdijkstra
      @ttdijkstra 8 หลายเดือนก่อน +11

      ​​@@ChristianConradIn small teams that work in different parts of the repo merge conflicts are rare and branching is overkill.

    • @IqweoR
      @IqweoR 8 หลายเดือนก่อน +8

      Unfortunately, in the real world, someone might decide they want to push code in your branch. Such people need to stay away from computers, but HRs don't allow criticism or other "offensive" behavior these days

  • @x9wozz
    @x9wozz 8 หลายเดือนก่อน +569

    Man came out of nowhere and started cooking

    • @dj67084
      @dj67084 8 หลายเดือนก่อน +11

      Let the man cook!

    • @nikolacekic4244
      @nikolacekic4244 7 หลายเดือนก่อน +3

      say his name

    • @Feoryc
      @Feoryc 2 หลายเดือนก่อน

      @@nikolacekic4244 Philomatics

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

      Gimme nonsense!

  • @Misteribel
    @Misteribel 8 หลายเดือนก่อน +434

    This process is so much simpler and cleaner if you work from your own branch and use PRs. In that case, you can just rebase the PR onto main after it's reviewed. Or, if there are conflicts, use `git rebase main` locally first.

    • @wombll
      @wombll 8 หลายเดือนก่อน +36

      Yeah most teams will be working on feature branches, what I do depending on how long I'm working on a branch is either rebase every morning to keep my branch up to date with the main branch (or sprint branch in our case) or just do a rebase before I open a PR back to the main branch.

    • @Kugelschrei
      @Kugelschrei 8 หลายเดือนก่อน +7

      @@wombllanother option is CI, just keep your branches short-lived

    • @2Fast4Mellow
      @2Fast4Mellow 8 หลายเดือนก่อน +18

      @@wombll Our developers do no have commit rights on the feature branches, these are locked. Developer create their own branch (based on a feature branch), make their changes and than create a PR. The PR is merged into the feature branch. Every feature branch has a maintainer who is responsible for the branch. It is the feature branch that after reaching a milestone is merged to a release branch, but usually a release consists of multiple feature branch merges.
      Our developers perform a single rebase just before they create the PR. In the past we have lost too much time after daily rebase operations, not to mention that you can pull in changes you were not prepared for or contain bugs...

    • @ruanpingshan
      @ruanpingshan 8 หลายเดือนก่อน +7

      What's the difference between what you suggested and squashing commits when merging the PR?

    • @SirThanksalot_1
      @SirThanksalot_1 8 หลายเดือนก่อน +5

      @@ruanpingshan well for sure, if you squash them, the commits will be merged into one, so you will lose history. As a consequence, if you have a feature branch and you would continue on it after merging it into main, you have to rebase it with main first to avoid merge conflicts.

  • @MrinmoyRoy1990
    @MrinmoyRoy1990 5 หลายเดือนก่อน +7

    First video? Wow! Great quality.
    I always use git pull --rebase. And in case of conflict I just resolve them and do git rebase --continue.

  • @keroy4588
    @keroy4588 8 หลายเดือนก่อน +699

    also if you have uncommitted changes you can use, `git stash` then `git pull` and finally `git stash apply`.

    • @rinner2801
      @rinner2801 8 หลายเดือนก่อน +30

      Visual Studio does this automatically for you now (after asking), it's a nice feature.

    • @darthwalsh1
      @darthwalsh1 8 หลายเดือนก่อน +8

      I configured auto-stash to always get this

    • @FisheyLP
      @FisheyLP 8 หลายเดือนก่อน +84

      git pull --rebase --autostash

    • @kchemutai3483
      @kchemutai3483 8 หลายเดือนก่อน +9

      I have always done this. It works

    • @joshuakb2
      @joshuakb2 8 หลายเดือนก่อน +36

      You should git stash pop instead to avoid cluttering your stash

  • @RabblerouserGT
    @RabblerouserGT 2 หลายเดือนก่อน +1

    Great first video! Short and informative and the graphics help for those of us that are differently-abled in the mental department. Much appreciated! :D

  • @vinicchleme
    @vinicchleme 8 หลายเดือนก่อน +327

    If you want to always use pull with rebase, you can configure `pull.rebase` to true to have it as the default behavior when running `git pull`. Then you can resolve conflicts and continue with the rebase with `git rebase --continue`. As a bonus, you can avoid repeated conflicts by configuring `rerere.enabled` to true, which will Reuse Recorded Resolutions from that point on.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +24

      Thanks for mentioning this, I've added this detail to the top pinned comment!

    • @morosis82
      @morosis82 8 หลายเดือนก่อน +9

      This is the real way. Best of both worlds.

    • @Xewl
      @Xewl 8 หลายเดือนก่อน +1

      Exactly this.

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

      Yes! This is also how we do it at my work.

    • @nekekaminger
      @nekekaminger 7 หลายเดือนก่อน +2

      this.

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

    This is amazing for being your first video. Very clear and concise, with nice visuals.

  • @patrickbg110
    @patrickbg110 8 หลายเดือนก่อน +53

    Just wanted to say your presentation style is amazing! Super clear and easy to follow, as well as really engaging. Nice one!

  • @rmsilva1973
    @rmsilva1973 3 หลายเดือนก่อน +4

    First video? Wow! Great quality, clean animations and clear narration. Congrats, dude!

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

      Thanks man!

  • @minafishi
    @minafishi 8 หลายเดือนก่อน +34

    that's a lot of production value for a first foray into youtube, very clean and to the point. good stuff !

  • @kenneth.topp.
    @kenneth.topp. 8 หลายเดือนก่อน +16

    explaining git in such a simple and well produced way is a banger way to start a channel.

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

    Your Video & Audio is clear and so good for a first youtube video. Content about Git also presented in a lucid way to understand. I saw your video today only. Eager to watch more videos and learn from your channel. Good Work 👍

  • @willow2893
    @willow2893 8 หลายเดือนก่อน +129

    would def be interested in a interactive rebase video or a video where you explain how to handle merge conflicts if you just do the normal git pull

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +7

      Ok cool! Just to clarify, have you ever done an interactive rebase before? Have you fixed merge conflicts before? If yes, what were difficult bits? Just want to make sure I focus on the right things :)

    • @willow2893
      @willow2893 8 หลายเดือนก่อน +13

      @@philomatics i’ve not done an interactive rebase. i’ve edited files to fix merge conflicts before a few times but it’s been a while. i feel like when i do like. git pull and get the merge conflict error im rarely motivated enough to deal with it the way im supposed to. im also pretty confounded by the fast forward / no fast forward / rebase thing.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +15

      Thanks for the response! I have a video in the works on resolving merge conflicts, stay tuned :)

    • @zootsuitpenguin
      @zootsuitpenguin 8 หลายเดือนก่อน

      This seems like the answer to my problems with git :) thanks!!

    • @lilith-2d0
      @lilith-2d0 8 หลายเดือนก่อน +3

      Sometimes conflicts are inevitable, but having a clean git history and having all the people working on a project try to also interactive rebase their own branches as they develop to keep their own commits self-contained and clean helps prevent a ton of a crazy amount of conflict. I end up using rebase in some form at least a handful of times a day, and It's one of my favourite git commands. Beign really good at interactive rebasing will save you a ton of time and headache in the future, but it was also very confusing for me to learn at first.

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

    The best thing about this video is its on point from the very first second. no beating around the bush with bait-ism! good work.

  • @tacokoneko
    @tacokoneko 8 หลายเดือนก่อน +230

    i was going to say "wait but what if we are all making huge amount of changes to the same files so theres tons of merge conflicts" and then he explained that in that case, yeah, we are supposed to use normal git pull.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +27

      Hah! gotcha ;)
      Jokes aside, you can also just fix the conflict in the interactive rebase then (see my pinned comment for more details). Video on that is in the works!

    • @TheStickofWar
      @TheStickofWar 8 หลายเดือนก่อน +3

      @@noomadeno not really. If master has some PRs merged into it then you will likely get a conflict if a separate feature touched some overlapping files or types.

    • @michaelkhalsa
      @michaelkhalsa 8 หลายเดือนก่อน +1

      If lots of people are doing huge amounts of changes to the same files, then something is wrong, I.e., long lived branches, lack of communication, too much in a file, ...

    • @tacokoneko
      @tacokoneko 8 หลายเดือนก่อน +1

      @@michaelkhalsa i maintain some soft forks which is when i edit a lot of things in a repository but my changes are not useful for anyone upstream because they are only needed for users of my builds. one example is, there is Super Mario 64 multiplayer for Windows, sm64ex-coop, and I create and release versions of it that work on Android and can cross play with the PC version. so i have to make a lot of small android specific changes throughout the repository that the maintainers of the Windows version don't want to have to worry about or get confused by.

    • @_topikk_
      @_topikk_ 8 หลายเดือนก่อน

      @@michaelkhalsa Agreed. If the coworkers in this situation aren't working on the same files then there is no reason for them to be on the same branch. If they're working on the same files and tripping over each other, then they should probably just be pairing.

  • @programadorpython
    @programadorpython 8 หลายเดือนก่อน

    this video is AWESOME! Animations, audio, narration, everything.
    Great content, I will share with my subs too. Good luck and success for you!

  • @bennyorthner7223
    @bennyorthner7223 8 หลายเดือนก่อน +27

    Great animations and actually very useful info too!

  • @DanielDogeanu
    @DanielDogeanu 7 หลายเดือนก่อน

    Because this is your first video, and because this is my first time watching one of your videos, and because you provide great value, you won my subscription right from the start! 😊

  • @darbyburbidge8976
    @darbyburbidge8976 8 หลายเดือนก่อน +16

    I just want to say that videos like these are super helpful and I would love a video on git rebase interactive.
    I'm in school right now and I was joking with classmates about how every class is making us use git now (great!), but the only teach us add/pull/status/commit, and they just repeat that over and over. They don't even bother going into any detail on the ones they do bother to teach us either. It's very clearly a required part of the curriculum but it's always an afterthought, not a core part of any of our classes.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +2

      Thank you for your very nice feedback!
      Do you have any specific details or commands you'd like to learn more about?

    • @darbyburbidge8976
      @darbyburbidge8976 8 หลายเดือนก่อน

      @@philomatics I think personally, my biggest hurdle is making sure I know how to resolve conflicts without mangling whatever repo I'm dealing with. With rebase interactive, what happens when I select my code over the other persons code, does it show up as a line deletion in the new commit? I've done solo projects and it's easy to be lazy, or build bad habits. I'm concerned that I won't be familiar enough with git when it comes to multi-person projects. Working with remote repos as well.
      I recently started a project for a class, and I initially suggested a main branch, dev branch, and then we would each have our own dev branch, then we would work on our local personal dev branches. My classmate suggested we just use dev, and I realized that as long as we're careful about pushing to dev I didn't really have a good case for one or the other. In that sense I'd like content geared towards the why things are done the way they are. Why is using main/master branch bad, why dev branches, feature branches, personal branches, and what kinds of problems arise when you don't use them. That way I'm able to have a more informed discussion when negotiating how me and my project partners should handle git/hub.
      Another subject is forking on something like github (I know github is not git, but I thought I'd bring it up anyway). In the example I give above, I hosted the project on my github account. Because of that I have direct access to the dev branch. If I push from my local dev branch, it goes straight to the shared dev branch. My partner on the other hand has direct access via permissions. I considered having him fork it, but then I realized it would create asymmetric contributions (since I have direct access). I see a lot of Open Source or public projects tell people to fork the project first. In my case it's a school project, so it's not a huge deal. My question is: In industry do people fork repos, or do they have permission to push directly? It seems a lot of businesses have a "business" github account, and then all employees/contributors have individual accounts that fork/branch out of that, so there is always at least one layer of indirection. Is that for internal projects or just Open Source? Not really about git, but definitely something where I'm not sure what the best practice is. I imagine understanding something like this from the get-go would be important during hiring.
      I really like that this video goes over what the resulting tree looks like, it helps understand why rebase is better and not just that it is better. I've heard that rebase is better before, but I never knew why, or in this case, what makes pull worse. This video is great and I look forward to more content like this, even if it's not specifically the stuff I said above!

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

    I've been using git ever since I was in 2nd year of college, it's been ~3years. I never knew we could do `git pull --rebase`. It's really clean as you mentioned!

  • @kazkylheku1221
    @kazkylheku1221 8 หลายเดือนก่อน +79

    I've not used the "git pull" command since 2010. For a brief time, I configured repositories to make "git pull" do rebase instead of merge. That was tedious and prone to forgetting. Then I realized the fix is to stop using this stupid "pull" thing, and just do it in two commands. I don't want to fetch objects *and* muck with the local branch in a single command.
    First, git fetch.
    Then, see what you are getting into: git checkout (tells you by how many commits you and upstream are diverging). You may want to do a git log on the upstream branch to go into details, e.g. git log -p origin/master to see what has been happening: do you really want to rebase on top of all that now? And on top of all of it? Maybe there are certain older commits you want to pick up now, but avoid (for the time being) a breaking commit that will disturb your work.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +9

      This sounds like a good workflow, thanks for sharing.

    • @sutirk
      @sutirk 8 หลายเดือนก่อน +8

      Sane advice. For me there sre two global configs that helps immensely. Always do rebase instead of merge, and if there's any conflicts you can solve them and do a manual merge commit.
      git config --global pull.rebase true
      And it's always good to fetch before pulling, so a nice tree of commits helps you to quickly see the full picture.
      git config --global alias.tree "log --all --decorate --oneline --graph"
      Of course in some cases you might want to diff here and there, cherry pick something, or only rebase partially, but those are not everyday scenarios

    • @chilversc
      @chilversc 8 หลายเดือนก่อน +2

      Yup, fetch, then check what changed and decide on a case by case basis if you want to merge or rebase depending on what's happened and what will make the best history. Only thing to watch for is if you plan to rebase the history onto the latest main, or submit the changes as a sequence of independent patches. Then merges can be a bit annoying as they make rebasing, or reapplying the patches to a different branch awkward.

    • @akison1980
      @akison1980 8 หลายเดือนก่อน

      I still use git pull when returning to a project that others have committed to, otherwise fetch + rebase all the way. It's a nice and fast "catch me up" command

    • @g3ff01
      @g3ff01 8 หลายเดือนก่อน

      git checkout what?

  • @Olodus
    @Olodus 8 หลายเดือนก่อน +1

    Great video. Tip for another video: 'git rebase --interactive' - a command too few know about and use but that is super useful to handle tricky merges or just when you want to rearrange your own commits before pushing.
    In general great that more people try to describe and teach the concepts behind Git to make it easier for those not as experienced to understand what the different commands actually do and why they exist.

  • @randelventura987
    @randelventura987 8 หลายเดือนก่อน +5

    To be your first video this was awesome! The animations were engaging and the minimal explanation was on point. Good work mate!

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

    Really good video (information and editing), especially because it's your first. Please keep them coming, you just got a new subscriber. Wish you all the best ❤

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

      Thanks for the super nice comment! :) Made my day!

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

      @@philomatics I'm really glad to know that, my friend. It was an honest, unfiltered opinion. It's always so nice to meet good content creators from our field, you know? You'll undoubtedly receive more attention for your videos, because quality will always prevail and that you've proven to have. Greetings from Brazil 🙂

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

      @@moacirsouza Obrigado!

  • @xenotimeyt
    @xenotimeyt 8 หลายเดือนก่อน +10

    These animations are *really* good, but it's also definitely good advice. I've been anti-merge-commits for a while, it's cool to see other people spreading the word! :)

  • @olge1355
    @olge1355 8 หลายเดือนก่อน +1

    great explanation and neat visuals, well done. thank you!
    edit: wrote the comment before the video ended, I'd never thought that this was your first video. keep it up, subscribed!

  • @etamluos4928
    @etamluos4928 8 หลายเดือนก่อน +7

    I really hope you will continue with your channel, I've watched many videos on git and this one was one of the best (and it's just 4 minutes, can't even imagine if you'll do a 15-20 minutes+ video)

  • @schrodinger6393
    @schrodinger6393 7 หลายเดือนก่อน

    Really appreciate the whole explaining-through-visualisation approach. It's easy for me to understand that way.
    Looking forward to learning more from your channel.

  • @rerere1569
    @rerere1569 8 หลายเดือนก่อน +63

    Nothing wrong with git pull in the example you've made.
    In all projects I've worked on we usually followed the rule of using squash before merging any pull requests. This way it doesn't matter what kind of git history in your branch you have, it all gets squashed to a single commit and the git history of the main branch stays very clean, so you can just merge which usually way easier if you have to deal with conflicts compared to rebase (even if you use -rerere). I still use rebase from time to time but using it often gives me headache

    • @bepisdevs
      @bepisdevs 8 หลายเดือนก่อน +16

      I agree. I do think rebase keeps the history cleaner but my team basically never looks at or cares about the git history quality and it was not worth the hassle of the trickier merge conflicts when we tried to ditch merge commits.

    • @sergeyivanov3607
      @sergeyivanov3607 8 หลายเดือนก่อน +4

      git log --graph --online… Now add --first-parent, and you won't need squash anymore if you're using it for purely aesthetic purposes.

    • @sikhswim
      @sikhswim 8 หลายเดือนก่อน +1

      Came here looking for this comment, I’ve converted several teams to this model too! Squash and merge prs is easy to understand and gets you a nice clean history on the main branch

    • @SourceOfViews
      @SourceOfViews 8 หลายเดือนก่อน +4

      Why would you squash it? You're only removing information for no reason?

    • @rerere1569
      @rerere1569 8 หลายเดือนก่อน +11

      @@SourceOfViews I mean, all of the I information I usually need is in PR: typically there is much more than the commit message. When you squash and merge you automatically leave the PR number so you can easily find what you're looking for.
      Also most commits aren't really useful on its own: "fix: lint" wouldn't probably help you to determine why this line has been changed in the first place.
      But whatever works for you honestly, I'm just saying my experience

  • @JacobJNilsson
    @JacobJNilsson 2 หลายเดือนก่อน +2

    I always do interactive rebase, it's extremely simple, and working with fixups becomes really easy, keeping the git history super clean.

  • @snivels
    @snivels 8 หลายเดือนก่อน +71

    I've had to search for something in git history once, perhaps twice, in my entire 20 year career. Teams of mostly 10 to 20 people. To me, personally, the ease of just fixing the conflict and merge-commiting is just easier. Not only that, but the history will actually be more accurate. The misconception is that rebasing is more accurate. It's not. Rebasing is rewriting history, for a bug or issue you might or might not have to search the history for at some point.

    • @Drewer
      @Drewer 7 หลายเดือนก่อน +4

      sam,e i thinks its overrated, if you work in enterprise teams, you are screwed either way,

    • @SXsoft99
      @SXsoft99 5 หลายเดือนก่อน

      Same, but people as always have preferences. I for one don't mind having merge commits but some people feel that it pollutes the history... Like who is going to look At it? The only thing I think of is phpstorm select code and show history for selection

    • @CaptainWumbo
      @CaptainWumbo 5 หลายเดือนก่อน +5

      I don't think merge messes up git history but you don't use git blame? I think I use it a few times a day to figure out who I need to talk to or when something was added / how it fits into the timeline and on some occasions you will even be working with someone smart who leaves good commit messages that explain their reasoning or why a piece of code resolves some edgecase (or at least you can find the pr from that commit that does).
      It's a very important tool IMO or else we'd just flatten the commit history every few months to make pulls faster.

    • @UC9o5XrlWjXFOZayVA5JCXcg
      @UC9o5XrlWjXFOZayVA5JCXcg 4 หลายเดือนก่อน +6

      I search git history all the time, and that's why I'd rather have git history reflect what actually happened - ie not people rebasing to make the repo "clean".

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

      I've seen effectively this exact same video by a dozen people at this point and don't understand.
      This is pointless OCD that maybe makes things look cleaner, but it is just worse.
      Waiting for tomorrow for the next vid from Jr Dev 37482929383 that learns about rebase.

  • @嘻嘻哈哈欸米奇
    @嘻嘻哈哈欸米奇 8 หลายเดือนก่อน

    Wow! Your content is pure gold. I wish I had discovered ur channel before working with git. Ur channel should shine with elaborative explanation, especially the gorgeous animation!

  • @aakashs1806
    @aakashs1806 8 หลายเดือนก่อน +3

    I follow these
    1. git fetch --prune to clean the tree of remote history , It also shows how much the remote is ahead of your local repo
    2. git pull --rebase, rectify the merge conflits.
    3. git push

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

      Get out of my effing REPO!
      hehehe ,... This is a different approach to the problem;P
      (Like if people cannot talk anymore ... with each other. Holy Crypto-Bro F )

  • @David_Groves
    @David_Groves 7 หลายเดือนก่อน

    Excellent video. I've sent it to several team members as we had a bunch of messy stuff like this and I'm awful at explaining things without waving my hands all over the place and drawing diagrams on whiteboards, which is hard when you work 4000km from your nearest colleague.
    Thanks !

  • @etchbhatia
    @etchbhatia 8 หลายเดือนก่อน +27

    Please do a video on interactive rebase 3:23

  • @lambmaster
    @lambmaster 8 หลายเดือนก่อน

    thank you for this validation! I've always done this, and my coworkers thought I was crazy to use rebase. They were too scared of rebase (those wussies haha!).
    Also, I alias it to "pure" (PU-ll RE-base), since "pr" actually means something in git, even though it's not an actual command :). Also I like how you're keeping a "PURE" timeline by rebasing

  • @GreenClover0
    @GreenClover0 8 หลายเดือนก่อน +42

    There already is a shortcut for git pull --rebase, it's "git pull -r" ("git pr" alias is of course still shorter :^))

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +6

      Oh cool, didn't know there is a shorthand, thanks for sharing!

    • @TokyoXtreme
      @TokyoXtreme 8 หลายเดือนก่อน +2

      I can't remember offhand, but I think I set the git global setting to always use the rebase strategy when using git pull.

    • @AugustoCabrera
      @AugustoCabrera 8 หลายเดือนก่อน

      this is great thanks

    • @gerke_kok
      @gerke_kok 8 หลายเดือนก่อน

      Or just update you ~/.gitconfig to add:
      [pull]
      rebase = true
      To make sure you always get rebase.
      After this (when it 'fails') you can fix the challenges using "git mergetool". (Yes, brace yourself: it's often a UI)

    • @matthijshebly
      @matthijshebly 8 หลายเดือนก่อน +6

      Wouldn't the "pr" letter combination be potentially confusing (to noobs, at least), because PR can also mean "Pull Request"?

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

    Great editing. Best rebase explanation i found so far.
    Though I personally really abort at the first sign of a conflict and just pull regulary.
    I think you can make a strong point for NEVER rebasing. It just beautifies the git history, which is mostly a pointless artifact - all you are interested in 99% of cases are the results (e.g. your branches).
    The big upside is that no one can fuck it up. Seems like every other project someone actually rebases the wrong thing and creates some sort of mess that takes hours of developer time to resolve.
    If you have 100% confidence in all developers: go for it. If not: regular merges can make your lives so much easier

  • @VEKTOR_87
    @VEKTOR_87 8 หลายเดือนก่อน +7

    Now this is how you make a tutorial videos , simple , clear and straight to the point , keep it up

  • @cryticone6403
    @cryticone6403 8 หลายเดือนก่อน

    Your way you presented it was brilliant. I've always used it, but only because I was told to, but I could never figure out how it worked and the conflicts involved. Thanks! Really cool, well-paced explanation

  • @AbdullahKhadimGo
    @AbdullahKhadimGo 8 หลายเดือนก่อน +47

    Perfect! git pull in this situation does introduce bad history. I would just do a git rebase, resolve all the conflicts, --continue, and then push..
    Git rebase is better than pull in this sort of situation.

    • @rickymort135
      @rickymort135 5 หลายเดือนก่อน +1

      Git pull --rebase is a rebase. It does a fetch and rebase instead of fetch and merge

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

      theoretically ...

  • @ishaankapoor933
    @ishaankapoor933 8 หลายเดือนก่อน +1

    Very helpful, Congratulations on your 1st post. Keep posting!!

  • @ashiqurrahman-nu7ik
    @ashiqurrahman-nu7ik 7 หลายเดือนก่อน +60

    I never find it a good idea when two people work on the same branch in the first place. Every once in a while you should always pull in the latest main and then rebase your branch with it. This will make sure your branch keeps staying mergeable with the current main.

    • @gasparsigma
      @gasparsigma 7 หลายเดือนก่อน +2

      But sometimes you need to, usually helping someone fix an issue they couldn't on their own or dividing UI changes and business logic on a larger feature

    • @ashiqurrahman-nu7ik
      @ashiqurrahman-nu7ik 7 หลายเดือนก่อน +5

      @@gasparsigma I dont mind helping someone with ideas or reviewing their code suggesting changes here and there. But, that shouldnt require me to directly push sth on their branch. That’s too invasive for me. For the other case, it really gets down to how well you plan and size your tickets.

    • @tomiyokasensei
      @tomiyokasensei 5 หลายเดือนก่อน +4

      I don’t think its a issue with working on the same branch, eg john creates his own branch from main for his feature development and you created your own branch from main for your feature development and John finishes first and gets his feature merged, you will end up in the same situation.

    • @ashiqurrahman-nu7ik
      @ashiqurrahman-nu7ik 5 หลายเดือนก่อน +2

      @@tomiyokasensei not really. Since, john got his feature merged in main and considering main is the source of truth, its your responsibility to pull the latest main and rebase your branch with it. The idea is to consistently keep your branch mergeable with the source of truth (e.g main)

    • @bbravoo
      @bbravoo 5 หลายเดือนก่อน +1

      Wait until you read about trunk based development.
      Everybody pushing to main. And honestly much happier. Once you manage to work like this you never go back

  • @stoorps
    @stoorps 8 หลายเดือนก่อน

    Really good video, especially for your first!
    I'm somewhat embarrassed to admit that I never tried to understand rebase and the benefits, and feel terrible for leaving a long line of terrible (and aviodable) git histories.I started on TFS over a decade ago and learned "just enough" to get by in git.
    Thanks for the quick lesson :)

  • @riceontopofbeans534
    @riceontopofbeans534 8 หลายเดือนก่อน +7

    What an amazing video, i knew about the --rebase argument but had no idea of what it did, thanks! it's also so cool to see small programming youtubers rising!

  • @igor-rp5mw
    @igor-rp5mw 7 หลายเดือนก่อน

    Really good intro, straight to the meat! I am leaving a comment here so that we can expand our knowledge in the world of development and operations. Good job!

  • @derekchan1570
    @derekchan1570 7 หลายเดือนก่อน +3

    In most cases you will be working on different branches/PR and the main branch is usually locked from direct push. When finishing the PR most hosts offer "squash merge" that no matter how many commits in your PR, there will be one commit in master after merging.

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

      Though the same. There are barely ever cases where several people would work on the same branch locally.

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

      @@martynasbaltutis6916 unless they work on a small project, local utilities etc where there doesn't seams like the need for the extra work with PR.
      But of course, for larger serious projects you lock the main branch and use PR to merge to main.
      And for noobs like me 🙂this is great information (or when I am called in to save some ones screw ups in a git repository 🙂)

  • @nicejungle
    @nicejungle 8 หลายเดือนก่อน

    Thanks for the tip
    I've always used git pull --ff-only and if it cannot fast forward, I create a temporary branch, fetch and make a rebase before the fast-forward merge.
    This shortcut is doing the same process in a single command : very useful !

  • @netanelkomm5636
    @netanelkomm5636 8 หลายเดือนก่อน +18

    This kind of videos, specifically ones about git just helps me realize again and again how complex of a software git is. Like how did people even come up with all these features, how they know that exactly THAT was needed. This blows my mind. And the fact that the whole thing was written in C is just another level.

    • @Fe22234
      @Fe22234 8 หลายเดือนก่อน

      If you want even more mind blowing complex explanations of git look up handmade hero introduction to git.

    • @getweirdwes
      @getweirdwes 8 หลายเดือนก่อน +3

      By people, you mean Linus Torvalds lol

    • @getweirdwes
      @getweirdwes 8 หลายเดือนก่อน

      Oh okay i guess he had help

    • @netanelkomm5636
      @netanelkomm5636 8 หลายเดือนก่อน

      @@getweirdwes Yeah of course lol

    • @netanelkomm5636
      @netanelkomm5636 8 หลายเดือนก่อน

      @@getweirdwes But Linus is amazing nevertheless

  • @zygote846
    @zygote846 7 หลายเดือนก่อน

    I am used to using git pull and I ran into this conflict where i updated the remote from github and had a similar issue on my local, I think this is a great video and it helps solve an important issue.

  • @redolentofmark
    @redolentofmark 8 หลายเดือนก่อน +21

    I would say, never use git pull, always use git pull --ff-only instead and then handle the merge separately.
    Great video by the way

    • @abdullahX001
      @abdullahX001 8 หลายเดือนก่อน

      What does that do?

    • @redolentofmark
      @redolentofmark 8 หลายเดือนก่อน +1

      @@abdullahX001 It prevents any merging.

    • @maleldil1
      @maleldil1 8 หลายเดือนก่อน

      ​@@abdullahX001--ff-only only applies changes if they're fast-forwar; ie they can cleanly merge your local work with the remote if it wouldn't cause any conflicts. You might see the words "can be fast-forward" in git status or other places in the git CLI.
      My workflow is to always start with git pull --ff-only, and if it fails, I'll check out why the branches are different.

    • @zeeeeeman
      @zeeeeeman 6 หลายเดือนก่อน +2

      This should be the answer. No cognitive overhead, just pull and get on with your day.

  • @leoj_anidem
    @leoj_anidem 8 หลายเดือนก่อน

    Me encanto tu video! Solo usaba lo básico de Git hasta ahora como git pull, git merge, git push y git commit, pero me has inspirado a tratar de mejorar mi entendimiento de git. Sigue asi!

  • @br3nto
    @br3nto 7 หลายเดือนก่อน +21

    3:49 an alias is not needed for ‘git merge -rebase’. Just set the global config ‘pull.rebase’ to true with the command: ‘git config --global pull.rebase true’

    • @chinmayp00
      @chinmayp00 4 หลายเดือนก่อน +2

      Yes. My configuration 😊

  • @forestcat512
    @forestcat512 5 หลายเดือนก่อน +1

    Whaaat, that was your first video ever? Wow it was really professional and understanding. I will try using git pull --rebase first in the future

  • @Piasek16
    @Piasek16 8 หลายเดือนก่อน +13

    Why do you recommend running "git rebase --abort" and merging normally on conflict instead of proceeding with the rebase and resolving conflicts there? Does it have something to do with the apply backend that git rebase uses by default?
    Also great video btw, it's nice to see such high quality dev content on TH-cam.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +6

      That's a great question!
      I actually do recommend proceeding with the rebase if you already know how - I just thought that also explaining rebasing _and_ resolving conflicts during rebase would've been a bit overwhelming for this video. I might do a video on rebasing in the future though.
      Thanks for the nice feedback, made my day :)

    • @Fe22234
      @Fe22234 8 หลายเดือนก่อน +1

      ​@@philomaticsyes please do!

  • @tarotdactyl752
    @tarotdactyl752 7 หลายเดือนก่อน

    First video!? Excellent start! Can't wait to see more nice work.

  • @Aaku13
    @Aaku13 8 หลายเดือนก่อน +9

    Should be using feature branches and squash on merge.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +1

      Generally I agree. Couldn't this problem happen with a feature branch workflow as well? For example when multiple people are working simultaneously on the same feature branch?

    • @gigantedocil
      @gigantedocil 8 หลายเดือนก่อน +1

      @@philomatics , yes. But it won't matter because even if there are tons of merge commits on the feature branch they are all squashed into one when it is merged to the main branch.

    • @philomatics
      @philomatics  8 หลายเดือนก่อน +1

      ​@@gigantedocil That's a good point. I guess in the end it depends on how long the feature branch lives and how many people are working on it simultaneously.
      I'm honestly a bit on the fence about feature branches in general. Maybe I'll make a video on branching strategies in the future (also for my own sanity ;))

    • @DMSBrian24
      @DMSBrian24 8 หลายเดือนก่อน +3

      @@gigantedocil but branch history is not preserved which really sucks if you're adding major features or refactors, unless your feature branches are very small and short lived, you should likely still be rebasing and preserving history

    • @gigantedocil
      @gigantedocil 8 หลายเดือนก่อน

      @@DMSBrian24 it's still preserved on the PR, if you really need it you can go there and see it.

  • @FredWhosDead
    @FredWhosDead 8 หลายเดือนก่อน

    Good vid. Thank you for creating it. Not all people using git yet appreciate reducing the number of redundant merge commits.

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

    3:02 even when there are conflicts you should ‘rebase -pull’. You have to resolve the conflicts anyways, the only difference is you may get conflicts for each commit in your branch as each gets re-applied, but that’s also what rerere is for. This is also why we should prefer smaller changes/features and merge back to develop often.

  • @JagdeepSinghKalsi
    @JagdeepSinghKalsi 8 หลายเดือนก่อน

    If this is your first video, then trust me, I am going to subscribe you till the end of the world!
    I have been trying to create a video on the exact same topic, but somehow I was unable to get the "visual" element of explaining "just right" - you nailed it, and it looks awesome!
    Been using `git pull --rebase` from around 4 years now - living in a "merge-commit free" world!

  •  8 หลายเดือนก่อน +4

    This really mostly works in simple cases where there's only one or few, mostly conflict-free commits, otherwise rebase conflicts tend to be annoying to resolve.
    In more complex scenarios, it's always better to have your own branch and then do squash merge. This allows you to have multiple commits on your branch and not worry too much about their description until the moment you actually want to push the changes to main branch.

  • @874D8
    @874D8 8 หลายเดือนก่อน

    first TH-cam video? wow this was awesome! Thank you. I instantly subscribed!

  • @prayer4675
    @prayer4675 8 หลายเดือนก่อน +8

    You can configure your Git to do rebase instead of merge during the simple 'git pull' command and use this without making any alias.
    git config --global pull.rebase true
    The 'git pull' command is just a shorter command that does two other commands: 'git fetch' and then either 'git merge' or 'git rebase'. So the ultimate option is running them separately by you and not by the 'git pull' command.

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

    Just saw this in my feed and subscribed,my guy came out of nowhere cooking git💯

  • @Metruzanca
    @Metruzanca 8 หลายเดือนก่อน +16

    Was initially going to comment "you're crazy" then I realized this video is about the exact workflow I use. `git pull --rebase origin main` is your best friend :)

  • @vijay_you
    @vijay_you 5 หลายเดือนก่อน

    Really great video, simple and on to the point, couldn't have known if you didn't tell it was your first video. Keep it up 👍

  • @thethiny
    @thethiny 8 หลายเดือนก่อน +9

    @ 1:20, this might be confusing in some scenarios yes, but in general, I'm gonna have 40-something commits, so 1 "merge commit" is not a big deal.

  • @abdulrahmanalamoudi9903
    @abdulrahmanalamoudi9903 5 หลายเดือนก่อน

    This is the first time I watched a video from your channel and I found this video really useful. Thank you for your hard work and please keep on❤

  • @aleksandrpetrosyan1140
    @aleksandrpetrosyan1140 8 หลายเดือนก่อน +16

    I will say that some projects prefer `rebase`, actually the majority of projects that I worked on. From that perspective, I will say that your video is highly opinionated, provides no real justification, and eludes an important point. REBASING IS ALWAYS DESTRUCTIVE. It is impossible to reconstruct the work that you and your colleague had been working on, post-factum, and if the merge conflicts are resolved incorrectly (much more likely given that a rebase has to resolve conflicts for each commit) good luck trying to get anything to work. The only thing that you do avoid is ... for lack of a better word... useless merge commits. But it is a well-known fact, that you can make useful merge commits, and Linus has made a great point of demanding good merge commit messages.
    Don't mean to sound rude, but this guidance is at best of modest educational value.

    • @dan-bz7dz
      @dan-bz7dz 5 หลายเดือนก่อน

      What part of messing up your commit history did you not understand? Also, if you have multiple commits on the same lines of code, you're committing incorrectly. It's really a PITA code reviewing from people who do that. Plus it tends to not convey what the commit is doing

    • @aleksandrpetrosyan1140
      @aleksandrpetrosyan1140 4 หลายเดือนก่อน +2

      @@dan-bz7dz Given that you have the writing skills of a toddler, I would suggest refraining from advising people on what commits should look like.

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

      Very much in agreement. A "clean history" is more or less just a personal preference. I don't see a history with merge commits as messy. In my opinion, if you can't make sense of a history with merge commits, you just need more practice.

  • @oswaldoolea2889
    @oswaldoolea2889 8 หลายเดือนก่อน

    I have being trying to understand rebase for a long time, but hadnt being able to. Now I think I do finally thanks to your video!

  • @alphago9397
    @alphago9397 7 หลายเดือนก่อน

    Congrats on your first yt video! This was very interesting and useful; thanks.

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

    Wow, first video! So surprised, it is of very nice quality

  • @cloud3x3
    @cloud3x3 7 หลายเดือนก่อน

    I have always done rebase because I guess that's just how I learned it. Thanks for explaining why. Something that helps with the rebasing is if you rebase your branch and squash all of your changes before doing the main branch rebase, so then it looks, for all intents, like a normal merge.

  • @semicolon99
    @semicolon99 8 หลายเดือนก่อน

    For a first video you got the quality of well established TH-camr, keep up the excellent work!

  • @Uid767
    @Uid767 7 หลายเดือนก่อน

    This video is so informative, and the animation was of such help! This doesn't look like your first video at all!

  • @gnanaprakash-ravi
    @gnanaprakash-ravi 8 หลายเดือนก่อน

    Wow, Best illustration, I never understood this concept this clear before!! Keep it up

  • @adrianswebvideos
    @adrianswebvideos 8 หลายเดือนก่อน

    Thanks for the video. Loved the clear, concise explanation and the great visual to support it. I'd love to see resolving conflicts during a rebase 😁

  • @gxurma
    @gxurma 8 หลายเดือนก่อน

    This is your first YT thing? Loved your animations! Just continue!

  • @usoppgostoso
    @usoppgostoso 5 หลายเดือนก่อน +1

    I honestly never knew what those useless commits were about, so that’s it. Thanks.

  • @giovanni_siciliano_ivano
    @giovanni_siciliano_ivano 8 หลายเดือนก่อน

    do not know how many bugs i saw in people solving conflicts. Clear explanation wish you all the best on yt

  • @simplyblunder
    @simplyblunder 8 หลายเดือนก่อน

    Definitely do a video git pull interactive rebase video! Loved your explanation here, so would be super into watching you cover this!

  • @AlirezaTabasi7
    @AlirezaTabasi7 8 หลายเดือนก่อน

    I've been trying to explain this to my teammates for too long and you did really well!

  • @macot79
    @macot79 7 หลายเดือนก่อน

    Great work on this, hard to believe it’s your first video!

  • @arkadianriver
    @arkadianriver 7 หลายเดือนก่อน

    You're a great teacher. I love the pace, clarity, length, and visualization used. I was always scared to use rebase in a shared repo, but to see the remote and both locals, and understand that the rebase is happening locally first, makes it less daunting. I look forward to seeing what a rebase interactive would do, since it rewrites commits as they're edited. I'm assuming you rewrite only your own history before stacking it on top of the existing one.

  • @cassiano.matos231
    @cassiano.matos231 5 หลายเดือนก่อน

    Awesome content, dude, and nice way of explaining stuff as well, straight to the point!
    You just popped out in my feed and got a new subscriber 👊

  • @manishbabbar9969
    @manishbabbar9969 8 หลายเดือนก่อน

    Awesome video man! Been trying to find some answer around this since so long. Appreciate the effort of making me understand the simple topic with memes.

  • @kdurgiya
    @kdurgiya 8 หลายเดือนก่อน

    First ever video on TH-cam, and a whopping 189k views already, Kudos !
    Nice crisp, clear and concise video though !

  • @bombacloutk
    @bombacloutk 8 หลายเดือนก่อน

    bro, this is amazing very good editing and very educational. Good shit, keep it going.

  • @navneetsharma3150
    @navneetsharma3150 8 หลายเดือนก่อน

    Having used all of these options and still somewhat confused on what would cause conflicts and what kind of conflict resolving I have to do, this video was very helpful in helping out with the same. Thanks!

  • @xeno9585
    @xeno9585 7 หลายเดือนก่อน

    nice video man, my friend then did it to me and now I understand the defference between git pull and git pull --rebase! Hope I will learn for thank to you

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

    rebasing the current git is my all time favourite , good work mate

  • @programmingchannel9739
    @programmingchannel9739 8 หลายเดือนก่อน

    I like your explanation! direct, clean, and quiet.

  • @gohanmineiro
    @gohanmineiro 8 หลายเดือนก่อน

    fastest and easiest way i've ever seen common git workaround explained, thanks!

  • @MarcinPLBlog
    @MarcinPLBlog 5 หลายเดือนก่อน

    Really high quality video and clear explanations! Keep it up! 👏🏻👏🏻👏🏻

  • @BlueEmb3r
    @BlueEmb3r 8 หลายเดือนก่อน

    This was an awesome video. I'd love to learn more about interactive rebase and branches with your explanation format. Keep it up!!!

  • @alancabrera7116
    @alancabrera7116 8 หลายเดือนก่อน

    Thanks for this wonderful video. It’s now part of the on boarding boot camp where I work.