Tsd: `tsd install` иногда не работает с ошибкой: ENOENT в файле кеша

Созданный на 3 сент. 2015  ·  7Комментарии  ·  Источник: DefinitelyTyped/tsd

Иногда наша ежедневная сборка завершается ошибкой ENOENT. tsd пытается открыть файл кеша, которого не существует.

[ERR!] Ошибка: ENOENT, откройте 'C: \ Users *** \ AppData \ Roaming \ tsd-cache \ borisyankov-DefinitherTyped \ git-raw-fmt1.0 \ fa \ fac3185ed76eb7238c79967983952cc5224e8d36.raw'

В package.json мы добавили команду "./node_modules/.bin/tsd install" для автоматического запуска после npm-install.

tsd-debug.log:
[ERR!] Cwd: c: *[ERR!] ОС: Windows_NT 6.2.9200[ERR!] Argv: "node" "c: * _node_modules \ tsd \ build \ cli.js" "install"[ERR!] Узел: v0.10.33[ERR!] Tsd: 0.6.4[ERR!] Ошибка: ENOENT, откройте 'C: \ Users * _ \ AppData \ Roaming \ tsd-cache \ borisyankov-DefinitherTyped \ git-raw-fmt1.0 \ fa \ fac3185ed76eb7238c79967983952cc5224e8d36.raw'[ERR!] КОД: ENOENT[ОШИБКА!] ENOENT, откройте 'C: \ Users * \ AppData \ Roaming \ tsd-cache \ borisyankov-DefinitherTyped \ git-raw-fmt1.0 \ fa \ fac3185ed76eb7238c79967983952cc5224e8d36.raw'
Скорее всего, проблема не в самом tsd
и связано с тем, что tsd не может найти файл.

[ERR!]
Ошибка: ENOENT, откройте 'C: \ Users *** \ AppData \ Roaming \ tsd-cache \ borisyankov-DefinitherTyped \ git-raw-fmt1.0 \ fa \ fac3185ed76eb7238c79967983952cc5224e8d36.raw'

[ERR!] Tsd.json: {"версия": "v4", "репо": "борисянков / ОпределенноТипед", "ссылка": "мастер", "путь": "типизация", "пакет": "типизация / tsd.d.ts "," установлено ": {" jquery / jquery.d.ts ": {" commit ":" 0de1592ef9e3144b925287ca0494f621e12b01c6 "}," angularjs / angular.d.ts ": {" commit ":" 76e1eededf0bada45d92c3b575b }, "angularjs / angular-route.d.ts": {"совершить": "76e1dedf0bada455c0b75abeec3206d3aa5bd892"}, "requirejs / require.d.ts": {"commit": "76e1dedf0bada455c0b75abeec3206domready" .ts ": {" commit ":" 76e1dedf0bada455c0b75abeec3206d3aa5bd892 "}," modernizr / modernizr.d.ts ": {" commit ":" f6c8ca47193fb67947944a3170912672ac3e908e "}," angular-router " ": {" коммит ":" 53439c5a40339b54d926b32e51c738b69b83660d "}," angular-translate / angular-translate.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c-ionic: cord "ionic"}, cord "ionic"} {"commit": "38fb591c6eba840e0b53d1110302b8e4fb04651c"}, "cordova-ionic / plugins / keyboard.d.ts": {"commit": "38fb591c6eba840e0b53d1110302b8e4fb04651c"}, "cor"} dova / cordova.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}," cordova / plugins / Camera.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8eba840e0b53d1110302b8e4fb0}. ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}," cordova / plugins / FileTransfer.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651 "cordMobile" / "cordMo" / ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}," cordova / plugins / Splashscreen.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}:" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}:" Cordova / plugins1d1110302b8e4fb04651c "}," cordova / 8cd1cd1cd3d02 / "cordova" / , "cordova / plugins / Contacts.d.ts": {"commit": "38fb591c6eba840e0b53d1110302b8e4fb04651c"}, "cordova / plugins / Media.d.ts": {"commit": "38fb591c6eba840e0b53d11f302b8e StatusBar.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}," cordova / plugins / NetworkInformation.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb0}, cordova / plugins.b8e4fb0} : {"совершить": "38fb591 c6eba840e0b53d1110302b8e4fb04651c "}," cordova / plugins / Vibration.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}," cordova / plugins10e4fb04651c "}," cordova / plugins10e4fb04651c "}," cordova / plugins103b03db08d03d06d08d03d06d08e.cordova ": /plugins/DeviceOrientation.d.ts":{"commit":"38fb591c6eba840e0b53d1110302b8e4fb04651c"},"cordova/plugins/Push.d.ts":{"commit":"38fb591c6ebad}.d.ts":{"commit":"38fb591c6ebad3d1d03b03b5d03d05d06d03d08d08d08d08d05d06d5d05ddddddddddddddddddddddddddddddddddddddd05 .ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}," cordova / plugins / WebSQL.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651cdus "cordova" / "plugin" / "шнур" / "cordova" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}," cordova / plugins / InAppBrowser.d.ts ": {" commit ":" 38fb591c6eba840e0b53d1110302b8e4fb04651c "}}}

[ERR!] .Tsdrc не может быть получен

Самый полезный комментарий

Я настоятельно рекомендую не использовать tsd на этом этапе. Типы теперь публикуются в npm в пространстве имен @types или непосредственно внутри пакетов JS.

Все 7 Комментарий

Привет @ L6Echo Спасибо, что сообщили об этой проблеме. Я исследую и попытаюсь воспроизвести проблему.

Недавно мы столкнулись с чем-то похожим. Также использование сценария npm для запуска нашего tsd reinstall , чтобы убедиться, что все зависимости на месте перед компиляцией.

Вот результат нашего сервера сборки:

> tsd reinstall


-> running reinstall
[ERR!] cwd  : c:\j\vNext Dev Deploy\Foo.Web
[ERR!] os   : Windows_NT 6.3.9600
[ERR!] argv : "node" "c:\\j\\vNext Dev Deploy\\Foo.Web\\node_modules\\tsd\\build\\cli.js" "reinstall"
[ERR!] node : v0.12.4
[ERR!] tsd  : 0.6.5
[ERR!] Error: path exists but is not a directory C:\Users\jenkins\AppData\Roaming\tsd-cache\borisyankov-DefinitelyTyped\git-raw-fmt1.0\51
[ERR!] CODE : undefined
[ERR!] path exists but is not a directory C:\Users\jenkins\AppData\Roaming\tsd-cache\borisyankov-DefinitelyTyped\git-raw-fmt1.0\51
[ERR!] If you need help, you may report this error at:
    https://github.com/DefinitelyTyped/tsd/issues

[ERR!] .tsdrc could not be retrieved

[ERR!] Please include the following file with any support request:
    c:\j\vNext Dev Deploy\Foo.Web\tsd-debug.log


npm ERR! Windows_NT 6.3.9600
npm ERR! argv "C:\\Program Files\\nodejs\\\\node.exe" "C:\\Program Files\\nodejs\\node_modules\\npm\\bin\\npm-cli.js" "run" "tsd:install"
npm ERR! node v0.12.7
npm ERR! npm  v2.14.1
npm ERR! code ELIFECYCLE
npm ERR! [email protected] tsd:install: `tsd reinstall`
npm ERR! Exit status 1
npm ERR! 
npm ERR! Failed at the [email protected] tsd:install script 'tsd reinstall'.
npm ERR! This is most likely a problem with the Foo package,
npm ERR! not with npm itself.
npm ERR! Tell the author that this fails on your system:
npm ERR!     tsd reinstall
npm ERR! You can get their info via:
npm ERR!     npm owner ls Foo
npm ERR! There is likely additional logging output above.

npm ERR! Please include the following file with any support request:
npm ERR!     c:\j\vNext Dev Deploy\Foo.Web\npm-debug.log

Это происходит довольно регулярно на нашем CI-сервере (jenkins). Мы получаем тот же результат, что и @jwcarroll.

Просто чтобы добавить еще одну точку данных, мы также испытываем это во время нашего процесса развертывания. Мы начали использовать TSD примерно одну или две недели назад, и это происходило в трех наших ночных сборках. Однако, когда я вхожу в систему сборки и запускаю тот же «/ usr / bin / nodejs /[path-to-project sizes/node_modules/.bin/tsd install» из того же каталога, чтобы попытаться диагностировать его, я не могу воспроизвести он и tsd работают нормально.

[ERR!] cwd  : /[path-to-project]
[ERR!] os   : Linux 3.2.0-67-virtual
[ERR!] argv : "/usr/bin/nodejs" "/[path-to-project]/node_modules/.bin/tsd" "install"
[ERR!] node : v4.2.3
[ERR!] tsd  : 0.6.5
[ERR!] Error: ENOENT: no such file or directory, open '/root/.tsd-cache/DefinitelyTyped-DefinitelyTyped/git-raw-fmt1.0/a0/a01aa4eefc1319b5e8fcd210aa759ff041e23d90.raw'
[ERR!] CODE : ENOENT
[ERR!] ENOENT: no such file or directory, open '/root/.tsd-cache/DefinitelyTyped-DefinitelyTyped/git-raw-fmt1.0/a0/a01aa4eefc1319b5e8fcd210aa759ff041e23d90.raw'
This is most likely not a problem with tsd itself
and is related to tsd not being able to find a file.

[ERR!]
Error: ENOENT: no such file or directory, open '/root/.tsd-cache/DefinitelyTyped-DefinitelyTyped/git-raw-fmt1.0/a0/a01aa4eefc1319b5e8fcd210aa759ff041e23d90.raw'
    at Error (native)

[ERR!] tsd.json: {"version":"v4","repo":"DefinitelyTyped/DefinitelyTyped","ref":"master","path":"typings","bundle":"typings/tsd.d.ts","installed":{"jquery/jquery.d.ts":{"commit":"ba424f7ee39717d51c17699a09ac8df312a7e9a1"},"chosen/chosen.jquery.d.ts":{"commit":"52b0ea5c9719831eecf6ba7436660e30061a4b3c"},"core-js/core-js.d.ts":{"commit":"d0adccc436197cc7c3559322721e9df86b892bd6"},"moment/moment.d.ts":{"commit":"d28dd90af5a7ba2b4f18b107ddba3321a5a1f629"},"moment/moment-node.d.ts":{"commit":"d28dd90af5a7ba2b4f18b107ddba3321a5a1f629"},"fullCalendar/fullCalendar.d.ts":{"commit":"d28dd90af5a7ba2b4f18b107ddba3321a5a1f629"},"node/node.d.ts":{"commit":"b9a05cb4c96ae9961bbc41fbd7df9105c3b8fbd0"},"browserify/browserify.d.ts":{"commit":"b9a05cb4c96ae9961bbc41fbd7df9105c3b8fbd0"},"glob/glob.d.ts":{"commit":"b9a05cb4c96ae9961bbc41fbd7df9105c3b8fbd0"},"minimatch/minimatch.d.ts":{"commit":"b9a05cb4c96ae9961bbc41fbd7df9105c3b8fbd0"},"jsdom/jsdom.d.ts":{"commit":"b9a05cb4c96ae9961bbc41fbd7df9105c3b8fbd0"},"react/react.d.ts":{"commit":"b9a05cb4c96ae9961bbc41fbd7df9105c3b8fbd0"},"webpack/webpack.d.ts":{"commit":"ba424f7ee39717d51c17699a09ac8df312a7e9a1"}}}

[ERR!] .tsdrc could not be retrieved

[ERR!] Please include the following file with any support request:
    /[path-to-project]/tsd-debug.log

Я вижу эту проблему примерно раз в неделю на нашем сервере Jenkins. Мы используем tsd через плагин gulp-tsd. Никогда не наблюдайте эту проблему на машинах для разработки. Он может завершиться ошибкой с кодом ENOENT или с другой проблемой, связанной с файлом. Когда я ищу проблемный файл, он явно там, что наводит меня на мысль, что это, возможно, проблема с асинхронным чтением файла. Удаление всего кеша tsd решает проблему на некоторое время, затем, похоже, она возвращается.

  [12:55:08] Using gulpfile D:\ws\project\web\gulpfile.js
  [12:55:08] Starting 'tsd'...
  [12:55:12] [gulp-tsd] execute command: reinstall
  [12:55:12] [gulp-tsd] config: ./tsd.json
  [12:55:12] [gulp-tsd] latest: undefined
  [12:55:12] [gulp-tsd] running...

  ---
  path exists but is not a directory C:\Users\$buildmaster722\AppData\Roaming\tsd-cache\DefinitelyTyped-DefinitelyTyped\git-raw-fmt1.0\53
  D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\async.js:93
                  throw res.e;
                  ^

EXEC : error : path exists but is not a directory C:\Users\$buildmaster722\AppData\Roaming\tsd-cache\DefinitelyTyped-DefinitelyTyped\git-raw-fmt1.0\53 [D:\ws\project\Build.xml]
      at D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\build\xm\fileIO.js:117:28
      at tryCatch1 (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\util.js:63:19)
      at Promise$_callHandler [as _callHandler] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\promise.js:695:13)
      at Promise$_settlePromiseFromHandler [as _settlePromiseFromHandler] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\promise.js:711:18)
      at Promise$_settlePromiseAt [as _settlePromiseAt] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\promise.js:868:14)
      at Promise$_settlePromises [as _settlePromises] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\promise.js:1006:14)
      at Async$_consumeFunctionBuffer [as _consumeFunctionBuffer] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\async.js:74:12)
      at Async$consumeFunctionBuffer (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\async.js:37:14)
      at doNTCallback0 (node.js:407:9)
      at process._tickCallback (node.js:336:13)
D:\ws\project\Build.xml(69,3): error MSB3073: The command "gulp build" exited with code 1.
EXEC : error : path exists but is not a directory C:\Users\$buildmaster722\AppData\Roaming\tsd-cache\DefinitelyTyped-DefinitelyTyped\git-raw-fmt1.0\53 [D:\ws\project\Build.xml]
      at D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\build\xm\fileIO.js:117:28
      at tryCatch1 (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\util.js:63:19)
      at Promise$_callHandler [as _callHandler] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\promise.js:695:13)
      at Promise$_settlePromiseFromHandler [as _settlePromiseFromHandler] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\promise.js:711:18)
      at Promise$_settlePromiseAt [as _settlePromiseAt] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\promise.js:868:14)
      at Promise$_settlePromises [as _settlePromises] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\promise.js:1006:14)
      at Async$_consumeFunctionBuffer [as _consumeFunctionBuffer] (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\async.js:74:12)
      at Async$consumeFunctionBuffer (D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\async.js:37:14)
      at doNTCallback0 (node.js:407:9)
      at process._tickCallback (node.js:336:13)
D:\ws\project\Build.xml(69,3): error MSB3073: The command "gulp build" exited with code 1.

[10:39:43] Using gulpfile D:\ws\project\web\gulpfile.js
  [10:39:43] Starting 'tsd'...
  [10:39:45] [gulp-tsd] execute command: reinstall
  [10:39:45] [gulp-tsd] config: ./tsd.json
  [10:39:46] [gulp-tsd] latest: undefined
  [10:39:46] [gulp-tsd] running...
  ---
  ENOENT: no such file or directory, open 'C:\Users\$buildmaster722\AppData\Roaming\tsd-cache\DefinitelyTyped-DefinitelyTyped\git-raw-fmt1.0\d7\d70d12a88d7a6b3f711dadb0fde5b3387c0a860e.raw'
  D:\ws\project\web\node_modules\gulp-tsd\node_modules\tsd\node_modules\bluebird\js\main\async.js:93
                  throw res.e;
                  ^

EXEC : error : ENOENT: no such file or directory, open 'C:\Users\$buildmaster722\AppData\Roaming\tsd-cache\DefinitelyTyped-DefinitelyTyped\git-raw-fmt1.0\d7\d70d12a88d7a6b3f711dadb0fde5b3387c0a860e.raw' [D:\ws\project\build.xml]
      at Error (native)

какие-нибудь новые мысли по этому поводу? У меня такая же ошибка

12:26:46 [FrontEnd] Ошибка: не удается стат "/home/jenkins/.tsd-cache/borisyankov-DefinatelyTyped/git-raw-fmt1.0/58/585e78ba1ed6a3b9d25722f40429c3ba934ea79d.json": нет такой ошибки: ENOENT файл или каталог, stat '/home/jenkins/.tsd-cache/borisyankov-DefinentyTyped/git-raw-fmt1.0/58/585e78ba1ed6a3b9d25722f40429c3ba934ea79d.json'

но файл существует

# stat /home/jenkins/.tsd-cache/borisyankov-DefinitelyTyped/git-raw-fmt1.0/58/585e78ba1ed6a3b9d25722f40429c3ba934ea79d.json File: ‘/home/jenkins/.tsd-cache/borisyankov-DefinitelyTyped/git-raw-fmt1.0/58/585e78ba1ed6a3b9d25722f40429c3ba934ea79d.json’ Size: 501 Blocks: 8 IO Block: 4096 regular file Device: fd00h/64768d Inode: 4485381 Links: 1 Access: (0644/-rw-r--r--) Uid: ( 1002/ jenkins) Gid: ( 1002/ jenkins) Context: unconfined_u:object_r:user_home_t:s0 Access: 2019-02-21 13:08:24.000000000 +0100 Modify: 2019-02-20 14:25:54.000000000 +0100 Change: 2019-02-21 13:08:24.838670651 +0100 Birth: -

Я настоятельно рекомендую не использовать tsd на этом этапе. Типы теперь публикуются в npm в пространстве имен @types или непосредственно внутри пакетов JS.

Была ли эта страница полезной?
0 / 5 - 0 рейтинги

Смежные вопросы

blakeembrey picture blakeembrey  ·  15Комментарии

Diullei picture Diullei  ·  70Комментарии

lazlojuly picture lazlojuly  ·  9Комментарии

DanielRosenwasser picture DanielRosenwasser  ·  3Комментарии

gavJackson picture gavJackson  ·  3Комментарии