myHotTake

Tag: Jest focus tests

  • How to Focus or Skip Tests in Jest and Mocha: A Guide

    Hey there! If you enjoy this little journey through the fog, give it a like or share with friends who might be navigating similar paths.


    I’m sailing in a thick, impenetrable fog, each test in my JavaScript suite like a buoy in the sea. Some of these buoys are crucial landmarks, while others are merely distractions in my quest for clarity. As I navigate, I need to focus on the beacons that matter most and perhaps, for now, bypass the ones that don’t.

    In this foggy sea, Jest and Mocha are my trusted navigational tools. When I want to hone in on a specific test buoy in Jest, I call upon the command .only. It’s like activating a powerful lighthouse that cuts through the haze, illuminating just that one test. By appending .only to a test or describe block, I tell Jest, “This is my guiding light, focus here!” Suddenly, the surrounding fog clears, and I can see and understand that part of the sea with unparalleled clarity.

    In the realm of Mocha, the magic is similar. I use .only with it or describe, and it’s as if the fog parts, revealing the test buoy I need to understand my position better. The rest of the sea remains shrouded in mystery, allowing me to concentrate my energies on what’s vital.

    But what if I need to skip a test, perhaps because it’s a mirage or a buoy that’s not ready for my attention? I harness the power of .skip. With a simple command, I tell my navigational aids to ignore these markers. In Jest, test.skip or describe.skip is like drawing a curtain over these parts of the sea, allowing me to sail past without distraction. Mocha responds to it.skip or describe.skip in the same way, ensuring I sail smoothly without unnecessary detours.


    In Jest, when I want to focus on a particular buoy, say a critical test, I use the .only method. It’s like shining a spotlight in the fog:

    // Jest example
    describe('Navigation Suite', () => {
      test.only('should find the path through the fog', () => {
        const path = findPath(foggySea);
        expect(path).toBeDefined();
      });
    
      test('should alert if no path is found', () => {
        const path = findPath(emptySea);
        expect(path).toBeUndefined();
      });
    });

    Here, the .only method ensures that only the test should find the path through the fog runs, allowing me to focus on this crucial part of my journey.

    In Mocha, the process is similar, using .only to focus my attention:

    // Mocha example
    describe('Navigation Suite', function() {
      it.only('should find the path through the fog', function() {
        const path = findPath(foggySea);
        assert.isDefined(path);
      });
    
      it('should alert if no path is found', function() {
        const path = findPath(emptySea);
        assert.isUndefined(path);
      });
    });

    Again, .only illuminates the test I care about, letting me concentrate on navigating this specific channel through the fog.

    When there are tests I want to skip—perhaps because they’re not ready or relevant to my current focus—I use .skip to let them drift into the mist:

    // Jest skip example
    test.skip('should alert if no path is found', () => {
      const path = findPath(emptySea);
      expect(path).toBeUndefined();
    });
    // Mocha skip example
    it.skip('should alert if no path is found', function() {
      const path = findPath(emptySea);
      assert.isUndefined(path);
    });

    By using .skip, these tests are temporarily ignored, allowing me to sail past without the distraction of failing or unfinished tests.


    Key Takeaways:

    1. Focus with .only: Whether in Jest or Mocha, use .only to run specific tests, focusing your efforts where they matter most.
    2. Ignore with .skip: Use .skip to temporarily bypass tests that are not relevant to your current objectives, maintaining a clear path through your testing journey.
    3. Efficient Navigation: These tools help streamline your testing process, allowing you to concentrate on critical areas while minimizing distractions.