Ruby Conf 12 - Boundaries by Gary Bernhardt

Поделиться
HTML-код
  • Опубликовано: 2 янв 2025

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

  • @vosechu
    @vosechu 2 года назад +7

    I watch this each year and get something new every time. Each year I appreciate it more and more.

  • @pmarreck
    @pmarreck 9 лет назад +30

    This is actually one of my favorite tech talks ever and I think it's unfortunately going to be grossly underappreciated until it's too late (years from now after a series of giant software-reliability clusterfucks illustrate the importance of some of the things discussed here)
    It's also part of what convinced me to check out Elixir/Erlang, which embraced Actor model and a lot of these principles already

    • @christhecode8153
      @christhecode8153 8 лет назад +7

      +Peter Marreck I second this comment. I keep coming back to this talk. The first time I saw it I hardly understood anything, but there was something about this that just made me feel that it was important. As I've grown I've come back numerous times and I keep getting something out of it every time. The destroyallsoftware screencasts quite simply fundamentally changed the way I architecture and test applications :)

  • @Cumshoterdotka
    @Cumshoterdotka 6 лет назад +5

    Superb speaker. Enjoyed this talk.

  • @zhandoatosl
    @zhandoatosl 12 лет назад +4

    I was comparing Rich Hickey and Gary who have coded OO languages in a functional style for different motivations, Gary's for stronger, less brittle TDD/BDD (with a side effect of some improved performance) and Rich's for almost solely the desired performance gains with the side effect of hard-to-follow code. It's really funny that Rich Hickey wrote Clojure with NO TESTS (iirc) because his strong conviction that rigorous application of functional style means not needing them.

    • @am0e
      @am0e 7 лет назад +2

      One thing that wasn't mentioned in this talk, and constitutes a slight caveat IMO, is that boundary layers do still need integration tests, and (depending on your domain & design) these may not be trivial. This is kind of related to what Hickey says, because I actually found that when you design this way your pieces of the "functional core" become so small that your unit tests become almost trivial duplications of the code. If you have complex decision logic in the domain, I can see that you'd get more value from this model. IMO, the majority of apps remain CRUD (especially with more logic moving to the frontend), with small often ad-hoc pieces of business logic spliced in around them.

  • @tryptamigo
    @tryptamigo 12 лет назад

    What a great talk. Nice to see Ruby community have conversation like this. You could tell the crowd was curious.

  • @zhandoatosl
    @zhandoatosl 12 лет назад

    I hope that doesn't come off as too snarky because I have genuine affection for all dots connected (however clumsily)..
    Forward!

  • @ivanschuetz9458
    @ivanschuetz9458 6 лет назад +1

    For functions that need to load several things from async resources, the goal would be to extract each tiny piece of non-async code to pure functions and leave the "glue" in the integration shell, right?

    • @vosechu
      @vosechu 2 года назад

      Yes, correct.

  • @stardust6999
    @stardust6999 7 лет назад +3

    "I just used a walrus to make it more concrete." (C) Gary Bernhardt

  • @wjrasmussen666
    @wjrasmussen666 7 лет назад +2

    I know nothing about Ruby. Are all those code examples 100% legit runnable Ruby?

    • @pmarreck
      @pmarreck 6 лет назад

      Yes. Does this surprise you for some reason?

    • @mfgcertainty
      @mfgcertainty 6 лет назад +1

      They're legit but it's not all 1st class language features; for instance the `actor` keyword is a method that's defined somewhere.

  • @zhandoatosl
    @zhandoatosl 12 лет назад +1

    I loves me my Gary Bernhardt - the Fred Astaire of the Software Craft..
    Shorter Gary: I loves me what Rich Hickey did with Java and C sharp in the bad old days before Clojure because I loves me my TDD and syntax. (Gots to look at the stuff, day out, day in ya know).
    Shorter Rich Hickey: I loves me my burning white hot multi-cores so "managing shared state" you gets out of my effing way and syntax? Real men don't needs no stinking syntax!

  • @tryptamigo
    @tryptamigo 12 лет назад

    Ah, cool insight.

  • @tryptamigo
    @tryptamigo 12 лет назад

    What are you even saying?

  • @MichaelQuad
    @MichaelQuad 6 лет назад

    no, it will not work, sorry. abandon this fantasy idea. imperative is core, apis may be (better) functional.

  • @UncleSnottie
    @UncleSnottie 8 лет назад +8

    I watched this video again after recently taking an interest in learning Elixir. I vaguely remember this talk having some actor model information so I wanted a refresher on what was said. I'm very curious if Gary has done any Elixir programming. Elixir has a Ruby like syntax but is funcational and runs on the ErlangVM. It seems like this talk is trying to do some Elixir like things in Ruby. When I can, I will choose Elixir over Ruby.