Cypress in 100 Seconds

Sdílet
Vložit
  • čas přidán 21. 08. 2024

Komentáře • 412

  • @leoaso6984
    @leoaso6984 Před 2 lety +1642

    Ah yes, automated UI testing. That thing I'm definitely absolutely positively going to start doing... one of these days.

    • @ASDFG856
      @ASDFG856 Před 2 lety +28

      I have never seen a comment I relate more with.

    • @SpongeAndLeo
      @SpongeAndLeo Před 2 lety +3

      I basically exclusively test network calls using cypress these days. Powerful framework.

    • @daniel29009
      @daniel29009 Před 2 lety +1

      Meet converted pyramid, tapes server and unit size discovery.

    • @attila2246
      @attila2246 Před 2 lety +1

      So all your PR's get accepted with 0 unit tests?

    • @leoaso6984
      @leoaso6984 Před 2 lety +23

      @@attila2246
      Me: Hey, I just created a new button component. Pls review.
      Me: OK, but you didn't add any unit tests.
      Me: uhhh yeah, but... when I opened the browser and clicked it, it did the thing.
      Me: ...........eh, good enough for me **merges PR**

  • @andreas543
    @andreas543 Před 2 lety +560

    Suggestions for 100 second tuts:
    - Oauth2/OpenID Connect
    - Swagger/OpenAPI 3
    - Logging/Monitoring
    - Caching solutions
    - Phaser 3

  • @recnepSpencar
    @recnepSpencar Před 2 lety +519

    Been using Cypress for a year. Absolute game-changer over Selenium, webdriverio, and protractor.

    • @StEvUgnIn
      @StEvUgnIn Před 2 lety +23

      Those tools are not for testing but for scraping

    • @riddixdan5572
      @riddixdan5572 Před 2 lety +26

      have you ever looked into Playwright? if so, what are your thoughts?

    • @rasmusfalk-jensen8221
      @rasmusfalk-jensen8221 Před 2 lety +35

      @@StEvUgnIn That is just not true.
      Both WebdriverIO and Protractor were built for testing purposes. While Selenium might just be a tool for browser automation, it has seen wide use for testing purposes as well.

    • @recnepSpencar
      @recnepSpencar Před 2 lety +12

      @@StEvUgnIn You’re not wrong that it can be used for scraping. Any E2E tool would do the trick well. It’s primary purpose thing is testing. Puppeteer is more what you’re thinking of for scraping.

    • @SpinnedRock
      @SpinnedRock Před 2 lety +7

      So if I am still using selenium, you would recommend me to change to cypress? ;-)

  • @negary666
    @negary666 Před 2 lety +376

    I don’t even do web development but these videos are just too entertaining

    • @dmiradakis
      @dmiradakis Před 2 lety +5

      Can confirm, I’ve been sucked in.

    • @SirusStarTV
      @SirusStarTV Před 2 lety +18

      It's interesting that for someone it's entertainment but for others it's boring af

    • @n3vin192
      @n3vin192 Před 2 lety

      Same.

  • @Tygrysek_
    @Tygrysek_ Před 2 lety +56

    Cypress is pretty fun, but sometimes really tricky.
    The funniest part of it for me was when I had to do conditional testing, and I was new to Cypress. I relied on the docs and I found a section for conditional testing. It states:
    "don't worry, there are ways you can do with conditional testing! for example, you can... remove the need to do conditional testing!"
    Thank you Cypress, very cool.
    PS: No, I couldn't do that

  • @MisterAndreSafari
    @MisterAndreSafari Před 2 lety +16

    I have to say it again: your „video-editing“ and „story-telling“ skill is OUT of this world 😄
    Thank you so much for your work 🙏

  • @vicradon
    @vicradon Před 2 lety +29

    Thank you Jeff for another amazing 100-second tutorial. Anytime Jeff explains a concept, it becomes easier and more approachable for me.

  • @MrBloodySpirit
    @MrBloodySpirit Před 2 lety +46

    For me, I moved from Cypress to Playwright. It's much faster and can do almost everything Cypress can!

    • @JPeetjuh
      @JPeetjuh Před 2 lety +10

      That, and, so much of Cypress bugs me. Its Promises are not actual native browser Promises and can't be awaited. The magic strings for assertions. And if I wanted to see how many rows a table has, then submit a form and check if that table now has count + 1 rows, Cypress seems to actively hinder me. I found Playwright much more intuitive, friendly and robust. The only thing I really liked about Cypress was its execution window where you could "time travel" as Jeff says.

    • @threewestwinds
      @threewestwinds Před 2 lety +6

      ​@@JPeetjuh The promises thing is super annoying, and agree that the magic strings are not my favorite way of doing assertions.
      Even though it has a promises-like API, Cypress is actually a command queue, not a promise chain. The use of promise-like syntax (and especially the docs trying to say it's promise-based) is very misleading, 100%.

    • @graffhyrum
      @graffhyrum Před 2 lety +2

      The cross domain restrictions and local single threading are also pretty annoying.

  • @PfhorShark
    @PfhorShark Před 2 lety +10

    Been using cypress for 3 years after using selenium for god knows how long. I highly recommend this for TDD, your feedback cycle is almost immediate, you aren't coupled to chrome/driver versions, it's altogether the best way to write your integration tests first, see them not work, then repeatedly do the next thing it said didn't work. Simple.

    • @erick289777
      @erick289777 Před rokem +1

      Did you solve the lack of support of iFrame and multitab from Cypress?

  • @deathlight128
    @deathlight128 Před 2 lety +82

    Cypress is awesome! I've spent more time debugging the jest config than testing the code base !

  • @JohnBrandon
    @JohnBrandon Před 2 lety +14

    I will almost certainly never use this, but the clarity and quality of your videos is so outstanding that I can’t get enough. Thanks!

  • @nathanlamaire
    @nathanlamaire Před 2 lety +8

    Good thing about using these tools is that it also helps you to narrow down use-case of the application you make and only implement essentials.

  • @shaneckel
    @shaneckel Před 2 lety +1

    This is the first time I've ever responded to a CZcamsr request ever in the decade of watching CZcams videos but yes, I would like to see more algorithm videos. Excellent explanation of the search. This feels weird. Great work on everything you post.

  • @darkknightdks
    @darkknightdks Před 2 lety +1

    Absolutely love your videos.
    I have been using Cypress for over a year now and I don't want to go back to those Protactor, Selenium stuff.
    Also, Cypress has something called `data-cy`, which is added to the elements that you want to loop up in your tests. `data-cy` parameter can have a unique name and enables the test to directly find the element in the dom. This is an amazing feature that we use everyday and avoid looking up using html and css tags as they can change.

  • @reallynotfamilyfriendly
    @reallynotfamilyfriendly Před 2 lety +5

    the line "to figure out precisely why your code sucks" is so hilarious to me

  • @nicolasramos7084
    @nicolasramos7084 Před 2 lety +2

    I've literally started working with cypress for our application at work this morning. Awesome timing as usual

  • @CodingWithLewis
    @CodingWithLewis Před 2 lety +1

    Cypress is seriously such a game changer

  • @seantillman7490
    @seantillman7490 Před 2 lety +10

    I just started testing with Cypress this year, it's been real cool to use. Thanks for the videos as always!

  • @konnilol4
    @konnilol4 Před 2 lety

    I like how it just isn't "if" or even "when" anymore but straight up "why your code sucks"

  • @OfficeArcade
    @OfficeArcade Před 2 lety +2

    I’m a big cypress advocate. Absolute game changer!

  • @RemX405
    @RemX405 Před 2 lety +6

    This and TestCafe make E2E an absolute breeze for any web dev.

    • @aylictal
      @aylictal Před 4 měsíci

      I had to make the choice of using testcafe over cypress for my company 3 years ago. Main reason was cypress didn't support safari, nor s.

  • @aryasaktiflister_aw
    @aryasaktiflister_aw Před 2 lety

    idk what a rails dev like me is watching this for but that looks cool

  • @mstjepan7237
    @mstjepan7237 Před 2 lety +2

    Litteraly started learning Cypress yesterday, its so amazing for testing

  • @SoreBrain
    @SoreBrain Před 2 lety

    Starting into web development is great especially when you are able to enjoy such amazing content

  • @damar1967
    @damar1967 Před 2 lety

    100 Seconds video ideas:
    - Backing up hard drive
    - Wiping history
    - Getting some RAM a few megabytes
    - Logging in and logging out

  • @TomDoesTech
    @TomDoesTech Před 2 lety +2

    You forgot to add the part about nobody ever maintaining the tests

  • @kristofgilicze
    @kristofgilicze Před 2 lety +6

    I like Cypress, it really does work like a charm.
    One thing to note is that the Electron runtime is bundled / baked in, which arguably is pretty stupid.
    There is no way to install Cypress headless, even though most people use a real browser to run tests.

    • @DaraulHarris
      @DaraulHarris Před 2 lety +2

      > There is no way to install Cypress headless
      I was wondering how I might use it to do my automated testing in gitlab-ci. The docs mention being able to do this, though.

    • @threewestwinds
      @threewestwinds Před 2 lety +2

      @@DaraulHarris Cy can absolutely run in CI. Doing an npm install also downloads the cypress binary, which is fairly large, and comes with electron baked in.

    • @davloche6763
      @davloche6763 Před 2 lety

      There is a headless mode for your tests 😉

    • @kristofgilicze
      @kristofgilicze Před 2 lety

      There is headless mode, though Electron included no matter what.
      The "slim" docker CI image is roughly 600 mb. To be fair this includes Chrome and FF also.

  • @MineToaster12
    @MineToaster12 Před 2 lety +12

    I prefer playwright over cypress, it's more robust though ofc looks less fancy than cypress.
    What cypress killed for me is them not support any http/3

    • @HankyAd
      @HankyAd Před 2 lety +1

      I really like using Playwright, but it just doesn't work in CI for more than a week before something explodes and it stops building
      I should look into putting it into a docker container

    • @EricSundquistKC
      @EricSundquistKC Před 2 lety

      Also left Cypress for Playwright, as getting our auth in all the tests was a nightmare in Cypress

    • @threewestwinds
      @threewestwinds Před 2 lety +1

      Cypress's coming support for cross-domain communication (and the Sessions API) should make auth a lot less painful. Of course, "It's coming" is not the most useful answer. ^^;;

  • @SpongeAndLeo
    @SpongeAndLeo Před 2 lety

    Been using cypress for 4 years. It's incredibly powerful and I love it.

  • @joshuaokoro9447
    @joshuaokoro9447 Před 2 lety

    From my experience using Cypress, I can see it really makes testing fun. For me, the fun part is watching Cypress run the test and everything passes. Definitely give it a try if you haven’t. Might end up loving it

    • @galgrunfeld9954
      @galgrunfeld9954 Před 2 lety

      I've been avoiding learning testing for years just because it was so boring for me. Even when I sat down with myself and asked myself what technologies I should learn to become a better well-rounded full-stack developer, testing was in there, but was always the last one I wanted to do.
      So I learned a few technologies, but never picked up testing. But this framework makes me actually want to learn it, seems so cool!

    • @joshuaokoro9447
      @joshuaokoro9447 Před 2 lety

      @@galgrunfeld9954 I ran away from testing for so long until I started seeing the importance. Especially working with a team with constant update, testing would catch a lot of bugs before it gets to staging or production. These frameworks have made it enjoyable so that’s a bonus. Funny thing, I’m the one now rooting for testing

    • @galgrunfeld9954
      @galgrunfeld9954 Před 2 lety

      @@joshuaokoro9447 yeah, I'm very much aware of the benefits. Luckily, or maybe not, I so far worked only in small teams and did a lot of things independently so TDD wasn't much of a necessity, but I can definitely see it being crucial in so many places.

  • @jon1867
    @jon1867 Před 2 lety +4

    If it were me, I wouldn't use it for unit or integration tests. But it's amazing for UI or E2E tests

  • @WebDevYTLearningAccount
    @WebDevYTLearningAccount Před 6 měsíci

    Thank you for the quick video. I am on a different team temporarily and this helps me better understand the purpose since I have mostly written backend code.

  • @skriptkid4292
    @skriptkid4292 Před 2 lety

    this is awesome, i didnt even know what cypress was 100 seconds ago

  • @vnm_8945
    @vnm_8945 Před 2 lety

    I worked as an automation tester using Cypress, it was cool.

  • @Zandercraft
    @Zandercraft Před 2 lety

    "To figure out precisely why your code sucks..."
    Lol! I feel called out for some reason.

  • @mahmudzaman5445
    @mahmudzaman5445 Před 2 lety +2

    Really cool. Planning to use it on my next side project.

  • @logichog4181
    @logichog4181 Před 2 lety +1

    thanks for this one bro, I needed it

  • @ibadsiddiqui1
    @ibadsiddiqui1 Před 2 lety +3

    just what I needed! 🤩

  • @weikeshi1788
    @weikeshi1788 Před 2 lety +1

    Just started to write tests for my project, and see this today

  • @jacobshuman1650
    @jacobshuman1650 Před 2 lety +4

    I’d love one of these videos for playwright! I tried cypress and while it was really cool (especially with the test runner) it felt a bit dated imo. The lack of native promises really hurt my experience.

  • @recker7017
    @recker7017 Před 2 lety

    this channel is becoming very js oriented

  • @GautamKhatter
    @GautamKhatter Před 2 lety

    Next video should be “Types of tests” in 100 seconds.

  • @siydge
    @siydge Před 2 lety +1

    My bud who I work with is from Cyprus, he's going to go crazy after seeing this video...
    Likely for both the name and what it does.

  • @connorallen162
    @connorallen162 Před 2 lety

    It's funny how I watch these videos once and I'm like "that's neat" then a month later I'm like "wait if I actually used that it could absolutely transform my development workflow!"

  • @edgarhnd
    @edgarhnd Před 2 lety

    I was about to launch my app to production without testing at the end of the week.. Thanks, that seems to be exactly what I need !

  • @moazahmed5388
    @moazahmed5388 Před 2 lety

    I've just experienced my first BSOD for a while , while watching this video. it makes sense now .

  • @mohammadfarhanr6650
    @mohammadfarhanr6650 Před 2 lety +2

    This content is always awesome. I am always curious how you can manage so many different techs, do you have experience using them throughout your career? Or do you just learn it like 1 week and make a video of it? or how? I am always amazed by how you deliver your content.

  • @brightpixeluk
    @brightpixeluk Před 2 lety

    Been using Cypress with TestingLibrary and MSW for a while and they are great for getting tests done fast.

  • @TheMrBvcx
    @TheMrBvcx Před 2 lety

    Fireship is a modern hero

  • @Rey_R_
    @Rey_R_ Před 2 lety +6

    E2E test is great if used properly. Never test all the things only with E2E. Make a lot of unit and integration tests. Then, test the end-user journey with E2E test.

    • @tomascarignano5002
      @tomascarignano5002 Před 2 lety

      Could you explain real quick why?

    • @Eagle3302PL
      @Eagle3302PL Před 2 lety +1

      @@tomascarignano5002 It's mostly about cost, e2e test take longer to run, longer to develop, are more brittle (prone to failure) and more time consuming to maintain than integration/unit tests.

  • @parthipankalayini8
    @parthipankalayini8 Před 2 lety +9

    Sir, waiting for more rust lang and golang videos 🙌

  • @jeromesimms
    @jeromesimms Před 2 lety

    *fireship on forms: hi mom

  • @devmeta1478
    @devmeta1478 Před 2 lety

    Okay, I guess my company just made another decision and that is which testing tool to use for front-end. :D Thanks Jeff

  • @owenwexler7214
    @owenwexler7214 Před 2 lety

    My company would not have gotten testing done as quickly as we did without Cypress.

  • @rtemis9016
    @rtemis9016 Před 2 lety

    finally found what I needed. thanks Jeff !

  • @awabqureshi814
    @awabqureshi814 Před 2 lety +1

    I'd love to see a purescript video! Maybe even a beyond 100 seconds on it too.

  • @NicolasPare
    @NicolasPare Před 2 lety +1

    I'm not sure I need a sophisticated tool to tell me my code sucks, I have co-workers for that!

  • @emstudios14
    @emstudios14 Před 2 lety +1

    This is so cool.

  • @imusingwindowsbtw1469
    @imusingwindowsbtw1469 Před 2 lety

    This is why I develop command line utilities.

  • @PhilipAlexanderHassialis
    @PhilipAlexanderHassialis Před 2 lety +1

    Excellent video as always! And now that you are delving into test territory, how about a nice vitest in 100 seconds? I think its time!

  • @evanhruskar
    @evanhruskar Před 2 lety

    I've been waiting for this video. The automatic loading feature doesn't always work properly (doesn't work for XHR requests). But It's 100x better than Selenium. Highly recommended.

  • @dinosaric4862
    @dinosaric4862 Před 2 lety +1

    Love your videos!

  • @PatricioHondagneuRoig
    @PatricioHondagneuRoig Před 2 lety +1

    Cypress is love. I don't wanna touch Selenium ever again.

  • @_sevelin
    @_sevelin Před 2 lety

    What a coincidence, I was learning Cypress right now already.

  • @PBKB
    @PBKB Před 2 lety

    I'm using Playwright. Amazing tool. Build a suite to test all our countries (work for a B2B supplier)

  • @Patrickdaawsome
    @Patrickdaawsome Před 2 lety

    Playwright is a great lowkey Cypress alternative.

  • @amoodaa
    @amoodaa Před 2 lety

    We've ended up using playwright instead of cypress, had some problems with ts with cypress, and playwright setup was just smooth as butter

  • @Kawacozy
    @Kawacozy Před 2 lety +5

    I want to clarify that in many SPA projects, cypress is a bad choice, leads to flaky tests. I'd recommend playwright if you use react and etc.

  • @TheDogn
    @TheDogn Před 2 lety

    0:35 precision is important in these matters.

  • @soko45
    @soko45 Před 2 lety

    "Fun" "Javascript" "Testing" choose one

  • @DogeMultiverse
    @DogeMultiverse Před 2 lety +5

    Was just looking at javascript testing! How do you always come up with timely content? Thanks again!

  • @its_vincesanity
    @its_vincesanity Před 2 lety

    I really love cypress ❤️ Even now I have to use React, I feel save to delivery some quality 🙌🏻

  • @dadsfads
    @dadsfads Před 2 lety +2

    Can you do one on Cypress Hill next?

  • @DevAcademyCom
    @DevAcademyCom Před 2 lety

    I hope you enjoy the free Web E2E testing course! 🔥
    courses.dev-academy.com/p/web-e2e-testing

  • @diogo405
    @diogo405 Před 2 lety

    Liking before watching 👍🏽

  • @LiamODonnellDev
    @LiamODonnellDev Před 2 lety

    I was struggling with something in webdriver and it looks like Jeff and the Algorithm (good name for a band) delivered Just In Time ;)

  • @imerence6290
    @imerence6290 Před 2 lety +3

    Video idea: HTML over the wire frameworks

  • @spencjon4822
    @spencjon4822 Před 2 lety

    'Love Cypress, highly recommend

  • @eliascotrim51
    @eliascotrim51 Před 2 lety +2

    What are the advantages of something like Jest compared to Cypress?

  • @adi.ranjan007
    @adi.ranjan007 Před 2 lety

    Are you fucking psychic, just needed this ❤️

  • @diegolikescode
    @diegolikescode Před 2 lety +1

    good content, as always.

  • @UselessDuckCompany
    @UselessDuckCompany Před 2 lety +1

    I hear html over the wire is coming back, any news on that?

    • @Dima1415
      @Dima1415 Před 2 lety

      Isn’t that just rendered html on the server? He definitely covered many frameworks that focus on that like nextjs.
      HTML over the wire has never stopped being a thing really.

  • @rafsoverflow
    @rafsoverflow Před 2 lety

    I'm trying my hardest to dig myself out of tutorial hell but you keep making these awesome videos that make me want to dig myself deeper. Fireship is not good during tutorial rehab.

  • @aaronbell5994
    @aaronbell5994 Před 2 lety

    These little jabs always make me laugh 0:39 😂

  • @nullpointer1755
    @nullpointer1755 Před 2 lety +2

    Can you make a video about Data Oriented Programming and ECS (Entity Component Systems) ?

  • @ninjaasmoke
    @ninjaasmoke Před 2 lety

    I'm just here to see all the people who _just_ started learning Cy

  • @WellSaint001
    @WellSaint001 Před 2 lety +1

    now, let's do a "playwright in 100 seconds" and then a "cypress vs playwright in 100 seconds" 👀

  • @IAmNumber4000
    @IAmNumber4000 Před 2 lety +1

    I'll add it to my list of the 8 trillion Javascript tools and frameworks I still need to evaluate lol
    Jokes aside I will probably check this out first since it actually looks super useful

  • @so-dz3px
    @so-dz3px Před 2 lety +1

    Cypress for UI and PactumJS for API

  • @utubewatcher1344
    @utubewatcher1344 Před 2 lety

    I got excited because i thought this was a minimentery about the nation of cyprus.

  • @masrafirinvi
    @masrafirinvi Před 2 lety

    Helpful! Thank you so much❤️

  • @astomero
    @astomero Před 2 lety

    that's quite insane I am not gonna lie

  • @jebronlames5582
    @jebronlames5582 Před 2 lety

    Impressive! R in 100 seconds please

  • @GlitchyPSI
    @GlitchyPSI Před 2 lety

    wow OK cypress looks super cool

  • @failist9570
    @failist9570 Před 2 lety

    Vitest in 100 seconds next!

  • @shlemekian
    @shlemekian Před 2 lety

    Currently trying to decide between Cypress and Playwright for e2e testing on a large project at my job. What's the chance you have a playwright video on the way? :) Great stuff as always.

  • @blendermaster8934
    @blendermaster8934 Před 2 lety +2

    Playwright in 100 seconds

  • @ArnavSingh-im5bj
    @ArnavSingh-im5bj Před 2 lety

    More about cypress please and also about load testing of APIs

  • @reggiemate7288
    @reggiemate7288 Před 2 lety

    Now I will defs test my own projects /s

  • @im1bear
    @im1bear Před 2 lety +2

    Assembly in 100 Seconds maybe? :)