Simple email application for Android. Original source code: https://framagit.org/dystopia-project/simple-email
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

106 lines
7.8 KiB

  1. <!doctype html>
  2. <html>
  3. <title>npm-doctor</title>
  4. <meta charset="utf-8">
  5. <link rel="stylesheet" type="text/css" href="../../static/style.css">
  6. <link rel="canonical" href="https://www.npmjs.org/doc/cli/npm-doctor.html">
  7. <script async=true src="../../static/toc.js"></script>
  8. <body>
  9. <div id="wrapper">
  10. <h1><a href="../cli/npm-doctor.html">npm-doctor</a></h1> <p>Check your environments</p>
  11. <h2 id="synopsis">SYNOPSIS</h2>
  12. <pre><code>npm doctor</code></pre><h2 id="description">DESCRIPTION</h2>
  13. <p><code>npm doctor</code> runs a set of checks to ensure that your npm installation has
  14. what it needs to manage your JavaScript packages. npm is mostly a standalone tool, but it does
  15. have some basic requirements that must be met:</p>
  16. <ul>
  17. <li>Node.js and git must be executable by npm.</li>
  18. <li>The primary npm registry, <code>registry.npmjs.com</code>, or another service that uses
  19. the registry API, is available.</li>
  20. <li>The directories that npm uses, <code>node_modules</code> (both locally and globally),
  21. exist and can be written by the current user.</li>
  22. <li>The npm cache exists, and the package tarballs within it aren&#39;t corrupt.</li>
  23. </ul>
  24. <p>Without all of these working properly, npm may not work properly. Many issues
  25. are often attributable to things that are outside npm&#39;s code base, so <code>npm
  26. doctor</code> confirms that the npm installation is in a good state.</p>
  27. <p>Also, in addition to this, there are also very many issue reports due to using
  28. old versions of npm. Since npm is constantly improving, running <code>npm@latest</code> is
  29. better than an old version.</p>
  30. <p><code>npm doctor</code> verifies the following items in your environment, and if there are
  31. any recommended changes, it will display them.</p>
  32. <h3 id="npm-ping"><code>npm ping</code></h3>
  33. <p>By default, npm installs from the primary npm registry, <code>registry.npmjs.org</code>.
  34. <code>npm doctor</code> hits a special ping endpoint within the registry. This can also be
  35. checked with <code>npm ping</code>. If this check fails, you may be using a proxy that
  36. needs to be configured, or may need to talk to your IT staff to get access over
  37. HTTPS to <code>registry.npmjs.org</code>.</p>
  38. <p>This check is done against whichever registry you&#39;ve configured (you can see
  39. what that is by running <code>npm config get registry</code>), and if you&#39;re using a
  40. private registry that doesn&#39;t support the <code>/whoami</code> endpoint supported by the
  41. primary registry, this check may fail.</p>
  42. <h3 id="npm-v"><code>npm -v</code></h3>
  43. <p>While Node.js may come bundled with a particular version of npm, it&#39;s the
  44. policy of the CLI team that we recommend all users run <code>npm@latest</code> if they
  45. can. As the CLI is maintained by a small team of contributors, there are only
  46. resources for a single line of development, so npm&#39;s own long-term support
  47. releases typically only receive critical security and regression fixes. The
  48. team believes that the latest tested version of npm is almost always likely to
  49. be the most functional and defect-free version of npm.</p>
  50. <h3 id="node-v"><code>node -v</code></h3>
  51. <p>For most users, in most circumstances, the best version of Node will be the
  52. latest long-term support (LTS) release. Those of you who want access to new
  53. ECMAscript features or bleeding-edge changes to Node&#39;s standard library may be
  54. running a newer version, and some of you may be required to run an older
  55. version of Node because of enterprise change control policies. That&#39;s OK! But
  56. in general, the npm team recommends that most users run Node.js LTS.</p>
  57. <h3 id="npm-config-get-registry"><code>npm config get registry</code></h3>
  58. <p>Some of you may be installing from private package registries for your project
  59. or company. That&#39;s great! Others of you may be following tutorials or
  60. StackOverflow questions in an effort to troubleshoot problems you may be
  61. having. Sometimes, this may entail changing the registry you&#39;re pointing at.
  62. This part of <code>npm doctor</code> just lets you, and maybe whoever&#39;s helping you with
  63. support, know that you&#39;re not using the default registry.</p>
  64. <h3 id="which-git"><code>which git</code></h3>
  65. <p>While it&#39;s documented in the <a href="../../doc/README.html">README</a>, it may not be obvious that npm needs Git
  66. installed to do many of the things that it does. Also, in some cases
  67. – especially on Windows – you may have Git set up in such a way that it&#39;s not
  68. accessible via your <code>PATH</code> so that npm can find it. This check ensures that Git
  69. is available.</p>
  70. <h3 id="permissions-checks">Permissions checks</h3>
  71. <ul>
  72. <li>Your cache must be readable and writable by the user running npm.</li>
  73. <li>Global package binaries must be writable by the user running npm.</li>
  74. <li>Your local <code>node_modules</code> path, if you&#39;re running <code>npm doctor</code> with a project
  75. directory, must be readable and writable by the user running npm.</li>
  76. </ul>
  77. <h3 id="validate-the-checksums-of-cached-packages">Validate the checksums of cached packages</h3>
  78. <p>When an npm package is published, the publishing process generates a checksum
  79. that npm uses at install time to verify that the package didn&#39;t get corrupted
  80. in transit. <code>npm doctor</code> uses these checksums to validate the package tarballs
  81. in your local cache (you can see where that cache is located with <code>npm config
  82. get cache</code>, and see what&#39;s in that cache with <code>npm cache ls</code> – probably more
  83. than you were expecting!). In the event that there are corrupt packages in your
  84. cache, you should probably run <code>npm cache clean</code> and reset the cache.</p>
  85. <h2 id="see-also">SEE ALSO</h2>
  86. <ul>
  87. <li><a href="../cli/npm-bugs.html">npm-bugs(1)</a></li>
  88. <li><a href="../cli/npm-help.html">npm-help(1)</a></li>
  89. <li><a href="../cli/npm-ping.html">npm-ping(1)</a></li>
  90. </ul>
  91. </div>
  92. <table border=0 cellspacing=0 cellpadding=0 id=npmlogo>
  93. <tr><td style="width:180px;height:10px;background:rgb(237,127,127)" colspan=18>&nbsp;</td></tr>
  94. <tr><td rowspan=4 style="width:10px;height:10px;background:rgb(237,127,127)">&nbsp;</td><td style="width:40px;height:10px;background:#fff" colspan=4>&nbsp;</td><td style="width:10px;height:10px;background:rgb(237,127,127)" rowspan=4>&nbsp;</td><td style="width:40px;height:10px;background:#fff" colspan=4>&nbsp;</td><td rowspan=4 style="width:10px;height:10px;background:rgb(237,127,127)">&nbsp;</td><td colspan=6 style="width:60px;height:10px;background:#fff">&nbsp;</td><td style="width:10px;height:10px;background:rgb(237,127,127)" rowspan=4>&nbsp;</td></tr>
  95. <tr><td colspan=2 style="width:20px;height:30px;background:#fff" rowspan=3>&nbsp;</td><td style="width:10px;height:10px;background:rgb(237,127,127)" rowspan=3>&nbsp;</td><td style="width:10px;height:10px;background:#fff" rowspan=3>&nbsp;</td><td style="width:20px;height:10px;background:#fff" rowspan=4 colspan=2>&nbsp;</td><td style="width:10px;height:20px;background:rgb(237,127,127)" rowspan=2>&nbsp;</td><td style="width:10px;height:10px;background:#fff" rowspan=3>&nbsp;</td><td style="width:20px;height:10px;background:#fff" rowspan=3 colspan=2>&nbsp;</td><td style="width:10px;height:10px;background:rgb(237,127,127)" rowspan=3>&nbsp;</td><td style="width:10px;height:10px;background:#fff" rowspan=3>&nbsp;</td><td style="width:10px;height:10px;background:rgb(237,127,127)" rowspan=3>&nbsp;</td></tr>
  96. <tr><td style="width:10px;height:10px;background:#fff" rowspan=2>&nbsp;</td></tr>
  97. <tr><td style="width:10px;height:10px;background:#fff">&nbsp;</td></tr>
  98. <tr><td style="width:60px;height:10px;background:rgb(237,127,127)" colspan=6>&nbsp;</td><td colspan=10 style="width:10px;height:10px;background:rgb(237,127,127)">&nbsp;</td></tr>
  99. <tr><td colspan=5 style="width:50px;height:10px;background:#fff">&nbsp;</td><td style="width:40px;height:10px;background:rgb(237,127,127)" colspan=4>&nbsp;</td><td style="width:90px;height:10px;background:#fff" colspan=9>&nbsp;</td></tr>
  100. </table>
  101. <p id="footer">npm-doctor &mdash; npm@6.4.1</p>