Команда не найдена: шутка

У меня есть такой тестовый файл: (я использую приложение create-response-app)

import React from 'react';
import ReactDOM from 'react-dom';
import App from './components/Calculator';

import { getAction, getResult } from './actions/'

import {shallow} from 'enzyme';
import toJson from 'enzyme-to-json';

import Enzyme from 'enzyme';
import Adapter from 'enzyme-adapter-react-16';

Enzyme.configure({ adapter: new Adapter() });

it('renders without crashing', () => {
  const wrapper = shallow(<App />)
  expect(toJson(wrapper)).toMatchSnapshot();
});

it('displays the choosen operator', () => {
  const action = {
      type: 'GET_ACTION',
      operator: '+'
    };
  expect(getAction("+")).toEqual(action)
})

it('displays the typed digit', () => {
  const action = {
    type: 'GET_RESULT',
    n: 3
  };
  expect(getResult(3)).toEqual(action);
})

it('checks that the clickevent for getNumber is called',() => {
  const clickEvent = jest.fn();
  const p = shallow(<p data-n = "1" onClick = {clickEvent}>1</p>)
  p.simulate('click')
  expect(clickEvent).toBeCalled();
})

и packaje.json:

{
  "name": "my-app",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "react": "^16.2.0",
    "react-dom": "^16.2.0",
    "react-scripts": "1.1.1"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    // "test": "react-scripts test --env=jsdom",
    "test": "jest",
    "eject": "react-scripts eject"
  },
  "devDependencies": {
    "enzyme": "^3.3.0",
    "enzyme-adapter-react-16": "^1.1.1",
    "enzyme-to-json": "^3.3.3",
    "jest": "^22.4.3"
  }
}

когда я запускаю "jest --updateSnapshot", я получаю:

command not found: jest

но шутка установлена.

Команда не найдена: шутка

Почему вы закомментировали тестовый сценарий, поставляемый с приложением create-react-app? Это должно вас устроить.

djfdev 02.05.2018 17:54

Я пробовал обновлять снимки, которые не удались, но не работали («команда jest не найдена» после запуска jest --updateSnapshot)

Alessandro 02.05.2018 17:55
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
57
2
76 353
10
Перейти к ответу Данный вопрос помечен как решенный

Ответы 10

просто используйте команду

npm test или npm t

Ответ принят как подходящий

Jest установлен, но, скорее всего, находится в вашем каталоге ./node_modules/.bin. Вы можете добавить это к своей команде ./node_modules/.bin/jest --updateSnapshot. Поскольку у вас уже есть jest как команда scripts в вашем package.json, вы также можете запустить ее с npm test -- --updateSnapshot. npm автоматически добавляет ./node_modules/.bin к вашему пути.

что именно тест npm - делать в этом случае? где это - задокументировано?

31415926 01.02.2019 10:20
test и start - специальные поля в scripts' that can be executed without npm run. npm test` - это та же команда, что и npm run test
CaptEmulation 03.02.2019 19:14

Если вы изменили сценарий тестирования пакета и хотите получить быстрый прямой доступ к jest через модули узла, вы также можете добавить системную ссылку. ln -s ./node_modules/.bin/jest jest, а затем используйте его с ./jest

sam 20.02.2020 12:29

Документация по приведенному выше ответу: jestjs.io/docs/en/cli.html#using-with-npm-scripts

sam 20.02.2020 12:30

Я только что столкнулся с этой проблемой, когда я использовал шутку в CLI, пока внезапно шутка не превратилась в «неизвестную команду». Оказывается, я использовал NVM для переключения на более старую версию узла (10.13.0), и я думаю, что это также переключает версию NPM. При переходе на 10.17.0 эта проблема была решена. Поэтому я предполагаю, что NPM добавляет ./node_modules/.bin к пути в более поздних версиях.

James Webb 04.03.2020 16:06

Почему npm test работает в Windows, но не в Linux? Ни в одной из систем jest не установлен глобально, но в Windows он работает нормально, а в Linux написано "jest: command not found"

Marc 10.06.2020 13:49

мне нужен jest-cli для запуска jest в cmd? npm t должен быть в порядке, так зачем возиться с jest-cli и добавлять этот пакет?

Timo 24.03.2021 16:20

Вам нужно запустить его так:

./node_modules/.bin/jest

или запустите npm test

Установите интерфейс командной строки Jest (Jest CLI):

npm install --save-dev jest-cli

Затем запустите команду jest. Работаю для меня в экземпляре linux докером в Windows 10.

В моем случае npm по какой-то причине не установил команду jest.

Чтобы исправить это:

  1. Я удалил каталог node_modules/jest
  2. Повторно запустил npm install и установил команду jest.

Я столкнулся с подобной проблемой. Я исправил это установив jest глобально.

npm install -g jest

Это сработало и для меня. Я смог выполнить команду "jest" после глобальной установки. Если он не установлен глобально, вы можете использовать команду «npx jest».

Webalation 15.09.2020 17:04

Я бы не стал сторонником решения проблем с путями путем глобальной установки модулей npm. Это создает зависимость от среды хоста и может вызвать сбои в средах CI.

TheRocketSurgeon 16.09.2020 02:16

Удаление node_modules и повторный запуск npm install исправили это для меня. Также "новая" команда npm ci может исправить это, поскольку она удаляет (или очищает) модули узлов и каждый раз выполняет чистую установку, плюс это быстрее по сравнению с ручным удалением node_modules и повторной установкой.

Просто перезагрузите конфигурационный файл bash после установки jest:

source ~/.bashrC# on linux ?
source ~/.bash_profile # on macOs

Jest не распознается, но автоматически выполняется с помощью npx jest

Я считаю, что это зависит от шутки, установленной глобально

sam 20.02.2020 12:26

Моя ситуация была вызвана моим конвейером git. Я не кешировал node_modules и не кешировал неотслеживаемые файлы.

В итоге я добавил

cache:
  # untracked: true
  key:
    files:
      - package-lock.json
  paths:
    - node_modules

в мой конвейер .yml и violá

Примечание

вы можете использовать path ИЛИ untracked, узнать больше о каждом, чтобы узнать, что лучше всего подходит для вас

Я получал zsh: command not found: jest после установки jest и попытки использовать команду jest. Решение, которое сработало для меня, запускало npx jest

Другие вопросы по теме