Jest - использование only

Reading time ~5 minutes

В Karma\Jasmine есть варианы для запуска выборочных тестов - fit, fdescribe. В этом посте - разберусь, какие есть варианты для этого - в Jest.

Использование .only для запуска только одного теста

В данном случае - запустится только один тест - первый:

describe('my suite', () => {
  test.only('my only true test', () => {
    expect(1 + 1).toEqual(2);
  });
  // этот тест --> не запустится
  test('my only true test', () => {
    expect(1 + 1).toEqual(1);
  });
});

В Jest для test.only есть алиас по аналогии с Jasmine - fit; то есть по идее - можно написать так:

describe('my suite', () => {
  fit('my only true test', () => {
    expect(1 + 1).toEqual(2);
  });
  // этот тест --> не запустится
  test('my only true test', () => {
    expect(1 + 1).toEqual(1);
  });
});

Ссылка из официальной документации - Test.Only

Использование .only для запуска нескольких тестов

В данном случае - запустится несколько тестов - первый и второй; третий - будет пропущен:

describe('my suite', () => {
  test.only('one of my .only test', () => {
    expect(1 + 1).toEqual(2);
  });
  test.only('other of my .only test', () => {
    expect(1 + 2).toEqual(3);
  });
  // этот тест --> не запустится
  test('my only true test', () => {
    expect(1 + 1).toEqual(1);
  });
});

В Jest для test.only есть алиас по аналогии с Jasmine - fit; то есть по идее - можно написать так:

describe('my suite', () => {
  fit('one of my .only test', () => {
    expect(1 + 1).toEqual(2);
  });
  fit('other of my .only test', () => {
    expect(1 + 2).toEqual(3);
  });
  // этот тест --> не запустится
  test('my only true test', () => {
    expect(1 + 1).toEqual(1);
  });
});

Ссылка из официальной документации - Test.Only

Использование .only для запуска набора тестов

Для выбора набора тестов для запуска - также можно использовать .only. В данном случае - запустятся тесты только из первого набора (‘first suite’), для которого установлено describe.only; второй набор тестов (‘second suite’) - будет пропущен:

describe.only('first suite', () => {
  test('one of my .only test', () => {
    expect(1 + 1).toEqual(2);
  });
});
// эти тесты --> не запустятся
describe('second suite', () => {
  test('my only true test', () => {
    expect(1 + 1).toEqual(1);
  });
});

У .only есть - алиас fdescribe; то есть, в Jest можно (по идее) написать по аналогии с Jasmine:

fdescribe('first suite', () => {
  test('one of my .only test', () => {
    expect(1 + 1).toEqual(2);
  });
});
// эти тесты --> не запустятся
describe('second suite', () => {
  test('my only true test', () => {
    expect(1 + 1).toEqual(1);
  });
});

Ссылка из официальной документации - Describe.Only

Использование .only для запуска нескольких наборов тестов

Аналогично предыдущему вварианту, можно указать .only для запуска нескольких наборов тестов; в данном случае - будут запущены только два первых набора тестов:

describe.only('my suite', () => {
  test('one of my .only test', () => {
    expect(1 + 1).toEqual(2);
  });
});
describe.only('other suite', () => {
  test('other of my .only test', () => {
    expect(1 + 2).toEqual(3);
  });
});
// эти тесты --> не запустятся
describe('skipped other suite', () => {
  test('my only true test', () => {
    expect(1 + 1).toEqual(1);
  });
});

У .only есть - алиас fdescribe; то есть, в Jest можно (по идее) написать по аналогии с Jasmine:

fdescribe('my suite', () => {
  test('one of my .only test', () => {
    expect(1 + 1).toEqual(2);
  });
});
fdescribe('other suite', () => {
  test('other of my .only test', () => {
    expect(1 + 2).toEqual(3);
  });
});
// эти тесты --> не запустятся
describe('skipped other suite', () => {
  test('my only true test', () => {
    expect(1 + 1).toEqual(1);
  });
});

Ссылка из официальной документации - Describe.Only


Ошибка с версией Node.js

Довольно часто в своей практике сталкиваюсь с такой ошибкой, когда запускаю локально сторонний проект:```bash$ npm run start> dom-moving-...… Continue reading

Mangling Angular

Published on February 15, 2024

Constructor parameter without access modifier

Published on February 04, 2024