mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-20 22:52:46 -05:00
Merge branch 'master' into fix-857-test
This commit is contained in:
commit
d51afd89ca
4 changed files with 78 additions and 78 deletions
|
@ -1,31 +1,31 @@
|
|||
---
|
||||
id: unit-testing
|
||||
title: "Unit Testing"
|
||||
id: unit-testing(单元-测试)
|
||||
title: "单元测试"
|
||||
---
|
||||
All tests are split in three folders:
|
||||
所有测试都被分成3 个文件夹:
|
||||
|
||||
- `test/unit` - Tests that cover functions that transform data in an non-trivial way. These tests simply `require()` a few files and run code in there, so they are very fast.
|
||||
- `test/functional` - Tests that launch a verdaccio instance and perform a series of requests to it over http. They are slower than unit tests.
|
||||
- `test/integration` - Tests that launch a verdaccio instance and do requests to it using npm. They are really slow and can hit a real npm registry. **unmaintained test**
|
||||
- `test/unit` - 涵盖非平凡方式转换数据的功能测试。这些测试只 `require()` 一些文件并在其中运行代码,因此它们是非常快的。
|
||||
- `test/functional` - 启动verdaccio instance并在 http上执行一系列请求的测试。它们比单元测试慢一些。
|
||||
- `test/integration` - 启动verdaccio instance并用 npm对其执行请求的测试。它们真的很慢并能打击到真的npm registry。 **unmaintained test**
|
||||
|
||||
Unit and functional tests are executed automatically by running `npm test` from the project's root directory. Integration tests are supposed to be executed manually from time to time.
|
||||
单元和功能测试是从项目根目录里运行 `npm test` 来自动执行的。集成测试应该时常手动执行。
|
||||
|
||||
We use `jest` for all test.
|
||||
我们所有测试都使用 `jest`。
|
||||
|
||||
## The npm Script
|
||||
## Npm 脚本
|
||||
|
||||
To run the test script you can use either `npm` or `yarn`.
|
||||
要运行测试脚本,您可以使用 `npm` 或 `yarn`。
|
||||
|
||||
yarn run test
|
||||
|
||||
|
||||
That will trigger only two first groups of test, unit and functional.
|
||||
这将只会触发测试,单元和功能的前两组。
|
||||
|
||||
### Using test/unit
|
||||
### 使用测试/单元
|
||||
|
||||
The following is just an example how a unit test should looks like. Basically follow the `jest` standard.
|
||||
以下只是单元测试的一个例子。基本上遵守`jest` 标准。
|
||||
|
||||
Try to describe what exactly does the unit test in a single sentence in the header of the `test` section.
|
||||
请试着描述单元在 `test` 部分页眉里的单一句子里确切测试什么。
|
||||
|
||||
```javacript
|
||||
const verdaccio = require('../../src/api/index');
|
||||
|
@ -48,11 +48,11 @@ describe('basic system test', () => {
|
|||
});
|
||||
```
|
||||
|
||||
### Using test/functional
|
||||
### 使用测试/功能
|
||||
|
||||
Funtional testing in verdaccio has a bit more of complextity that needs a deep explanation in order to success in your experience.
|
||||
Verdaccio 中的功能测试有点复杂,需要深入解释来让您有成功的体验。
|
||||
|
||||
All starts in the `index.js` file. Let's dive in into it.
|
||||
一切从`index.js`文件开始。让我们来深入了解它吧。
|
||||
|
||||
```javascript
|
||||
// we create 3 server instances
|
||||
|
@ -107,17 +107,17 @@ All starts in the `index.js` file. Let's dive in into it.
|
|||
|
||||
```
|
||||
|
||||
### Usage
|
||||
### 使用
|
||||
|
||||
Here we are gonna describe how it looks like an usual functional test, check inline for more detail information.
|
||||
这里我们将描述常规功能测试看起来是什么样的,请核对内联了解更多详细信息。
|
||||
|
||||
#### The lib/server.js
|
||||
|
||||
The server class is just a wrapper that simulates a `npm` client and provides a simple API for the funtional test.
|
||||
服务器 class(类)只是模拟 `npm` client 的 wrapper类,它为功能测试提供简单的API。
|
||||
|
||||
As we mention in the previous section, we are creating 3 process servers that are accessible in each process as `server1`, `server2` and ``server3`.
|
||||
如我们在之前的章节里提到的, 我们正创建3 个流程服务器,可以在每个流程里以`server1`, `server2` 和 ``server3`进行访问。
|
||||
|
||||
Using such reference you will be able to send request to any of the 3 instance running.
|
||||
通过这样的引用,您可以给这任何3 个运行的instance 发送请求。
|
||||
|
||||
```javascript
|
||||
<br />export default function(server) {
|
||||
|
@ -129,6 +129,6 @@ Using such reference you will be able to send request to any of the 3 instance r
|
|||
});
|
||||
```
|
||||
|
||||
### Test/integration
|
||||
### 测试/集成
|
||||
|
||||
These section never has been used, but we are looking for help to make it run properly. **All new ideas are very welcome.**
|
||||
这些部分还没有被使用,但是我们在寻求帮助来让它正常运转。**欢迎任何新的想法。**
|
|
@ -2,11 +2,11 @@
|
|||
id: uplinks
|
||||
title: "Uplinks"
|
||||
---
|
||||
An *uplink* is a link with an external registry that provides acccess to external packages.
|
||||
*上行链路* 是指可以访问到外部包的外部注册服务器地址。
|
||||
|
||||
![Uplinks](/img/uplinks.png)
|
||||
![上行链路](/img/uplinks.png)
|
||||
|
||||
### Usage
|
||||
### 用法
|
||||
|
||||
```yaml
|
||||
uplinks:
|
||||
|
@ -21,26 +21,26 @@ uplinks:
|
|||
url: http://localhost:55666/
|
||||
```
|
||||
|
||||
### Configuration
|
||||
### 配置
|
||||
|
||||
You can define mutiple uplinks and each of them must have an unique name (key). They can have two properties:
|
||||
你可以定义多个上行链路,每一个都必须有唯一的名称(键值). 它们可以有多个属性:
|
||||
|
||||
| Property | Type | Required | Example | Support | Description | Default |
|
||||
| ------------ | ------- | -------- | --------------------------------------- | ------- | -------------------------------------------------------------------------------------------------------------------------- | ---------- |
|
||||
| url | string | Yes | https://registry.npmjs.org/ | all | The registry url | npmjs |
|
||||
| ca | string | No | ~./ssl/client.crt' | all | SSL path certificate | No default |
|
||||
| timeout | string | No | 100ms | all | set new timeout for the request | 30s |
|
||||
| maxage | string | No | 10m | all | limit maximun failure request | 2m |
|
||||
| fail_timeout | string | No | 10m | all | defines max time when a request becomes a failure | 5m |
|
||||
| max_fails | number | No | 2 | all | limit maximun failure request | 2 |
|
||||
| cache | boolean | No | [true,false] | >= 2.1 | cache all remote tarballs in storage | true |
|
||||
| auth | list | No | [see below](uplinks.md#auth-property) | >= 2.5 | assigns the header 'Authorization' [more info](http://blog.npmjs.org/post/118393368555/deploying-with-npm-private-modules) | disabled |
|
||||
| headers | list | No | authorization: "Bearer SecretJWToken==" | all | list of custom headers for the uplink | disabled |
|
||||
| strict_ssl | boolean | No | [true,false] | >= 3.0 | If true, requires SSL certificates be valid. | true |
|
||||
| 属性 | 类型 | 必须的 | 范例 | 支持版本 | 描述 | 默认值 |
|
||||
| ------------ | ------- | --- | --------------------------------------- | ------ | ----------------------------------------------------------------------------------------------------------- | -------- |
|
||||
| url | string | 是 | https://registry.npmjs.org/ | 全部 | 外部注册服务器URL | npmjs |
|
||||
| ca | string | 否 | ~./ssl/client.crt' | 全部 | SSL证书文件路径 | 无默认值 |
|
||||
| timeout | string | 否 | 100ms | 全部 | 为请求设置新的超时时间 | 30s |
|
||||
| maxage | string | 否 | 10m | 全部 | 请求返回信息时效,在此时间内不会发起相同的请求 | 2m |
|
||||
| fail_timeout | string | 否 | 10m | 全部 | 请求在连续失败超过指定次数后的最长等待重试时间 | 5m |
|
||||
| max_fails | number | 否 | 2 | 全部 | 请求连续失败的最大次数限制 | 2 |
|
||||
| cache | boolean | 否 | [true,false] | >= 2.1 | 缓存下载的远程tarball文件到本地 | true |
|
||||
| auth | list | 否 | [见下文](uplinks.md#auth-property) | >= 2.5 | 指定“授权authorization”请求头的内容 [详情见](http://blog.npmjs.org/post/118393368555/deploying-with-npm-private-modules) | disabled |
|
||||
| headers | list | 否 | authorization: "Bearer SecretJWToken==" | 全部 | 上行链路请求的请求头header列表 | disabled |
|
||||
| strict_ssl | boolean | 否 | [true,false] | >= 3.0 | 为true时,会检测SSL证书的有效性 | true |
|
||||
|
||||
#### Auth property
|
||||
#### Auth属性
|
||||
|
||||
The `auth` property allows you to use an auth token with an uplink. Using the default environment variable:
|
||||
`auth` 属性内容是向上行链路发起请求时提供的授权令牌。例如使用默认环境变量:
|
||||
|
||||
```yaml
|
||||
uplinks:
|
||||
|
@ -51,7 +51,7 @@ uplinks:
|
|||
token_env: true # defaults to `process.env['NPM_TOKEN']`
|
||||
```
|
||||
|
||||
or via a specified environment variable:
|
||||
或者使用一个指定的环境变量
|
||||
|
||||
```yaml
|
||||
uplinks:
|
||||
|
@ -62,9 +62,9 @@ uplinks:
|
|||
token_env: FOO_TOKEN
|
||||
```
|
||||
|
||||
`token_env: FOO_TOKEN`internally will use `process.env['FOO_TOKEN']`
|
||||
`token_env: FOO_TOKEN`内部将使用 `process.env['FOO_TOKEN']`
|
||||
|
||||
or by directly specifying a token:
|
||||
或者直接指定令牌:
|
||||
|
||||
```yaml
|
||||
uplinks:
|
||||
|
@ -75,12 +75,12 @@ uplinks:
|
|||
token: "token"
|
||||
```
|
||||
|
||||
> Note: `token` has priority over `token_env`
|
||||
> 注意: `token`的优先级高于`token_env`
|
||||
|
||||
### You Must know
|
||||
### 须知
|
||||
|
||||
* Verdaccio does not use Basic Authentication since version `v2.3.0`. All tokens generated by verdaccio are based on JWT ([JSON Web Token](https://jwt.io/))
|
||||
* Uplinks must be registries compatible with the `npm` endpoints. Eg: *verdaccio*, `sinopia@1.4.0`, *npmjs registry*, *yarn registry*, *JFrog*, *Nexus* and more.
|
||||
* Setting `cache` to false will help to save space in your hard drive. This will avoid store `tarballs` but [it will keep metadata in folders](https://github.com/verdaccio/verdaccio/issues/391).
|
||||
* Exceed with multiple uplinks might slow down the lookup of your packages due for each request a npm client does, verdaccio does 1 call for each uplink.
|
||||
* The (timeout, maxage and fail_timeout) format follow the [NGINX measurement units](http://nginx.org/en/docs/syntax.html)
|
||||
* 自版本 `v2.3.0`以来, Verdaccio 不在使用Basic Authentication。verdaccio 所生成的所有令牌都基于 JWT ([JSON Web Token](https://jwt.io/))
|
||||
* 上行链路必须是兼容`npm`的注册服务器 例如: *verdaccio*, `sinopia@1.4.0`, *npmjs registry*, *yarn registry*, *JFrog*, *Nexus* and more.
|
||||
* 设置`cache` 为false可以帮助节省你的硬盘空间。 This will avoid store `tarballs` but [it will keep metadata in folders](https://github.com/verdaccio/verdaccio/issues/391).
|
||||
* 配置过多的上行链路会导致包查询速度变慢,这是因为相比较一个npm客户端每发送一次的请求,verdaccio却需要向每个上行链路都发送一次这样的请求
|
||||
* 这些属性(timeout, maxage and fail_timeout) 的配置单位格式参考[NGINX measurement units](http://nginx.org/en/docs/syntax.html)
|
|
@ -1,31 +1,31 @@
|
|||
---
|
||||
id: use-cases
|
||||
title: "Use Cases"
|
||||
id: use-cases(使用-场景)
|
||||
title: "使用场景"
|
||||
---
|
||||
## Using private packages
|
||||
## 使用私有包
|
||||
|
||||
You can add users and manage which users can access which packages.
|
||||
您可以添加用户并管理哪个用户可以访问哪个包。
|
||||
|
||||
It is recommended that you define a prefix for your private packages, for example "local", so all your private things will look like this: `local-foo`. This way you can clearly separate public packages from private ones.
|
||||
建议您定义私有包的前缀。例如“local(当地)",这样您私人的东西将如下所示:`local-foo`。 通过这种方法您可以清楚地把公有包和私有包分开。
|
||||
|
||||
## Using public packages from npmjs.org
|
||||
## 从npmjs.org使用公有包
|
||||
|
||||
If some package doesn't exist in the storage, server will try to fetch it from npmjs.org. If npmjs.org is down, it serves packages from cache pretending that no other packages exist. Verdaccio will download only what's needed (= requested by clients), and this information will be cached, so if client will ask the same thing second time, it can be served without asking npmjs.org for it.
|
||||
如果一些包没有在存储里,服务器将试着从npmjs.org中取它。 如果npmjs.org坏了,它会假装没有其他的包存在, 并起到缓存包的作用。 Verdaccio将只下载需要的 (= 由客户要求的)信息, 而且此信息将被缓存,这样如果客户再次问同样的事,它可以马上作用而不需要问npmjs.org。
|
||||
|
||||
Example: if you successfully request express@3.0.1 from this server once, you'll able to do that again (with all it's dependencies) anytime even if npmjs.org is down. But say express@3.0.0 will not be downloaded until it's actually needed by somebody. And if npmjs.org is offline, this server would say that only express@3.0.1 (= only what's in the cache) is published, but nothing else.
|
||||
例如:如果您曾经成功从此服务器请求express@3.0.1,哪怕npmjs.org 坏了,您也可以在任何时候再次请求(包含其相关项)。 但是,除非有人真正需要express@3.0.0,否则它是不会被下载的。 而且如果npmjs.org脱线,此服务器将会说除了express@3.0.1 (=只有在缓存里的)外,没有其他的发布。
|
||||
|
||||
## Override public packages
|
||||
## 覆盖公共包
|
||||
|
||||
If you want to use a modified version of some public package `foo`, you can just publish it to your local server, so when your type `npm install foo`, it'll consider installing your version.
|
||||
如果您希望使用一些公共包`foo`的修正版本,您只要把它发布到您的当地服务器,这样当您输入`npm install foo`,它将考虑安装您的版本。
|
||||
|
||||
There's two options here:
|
||||
这里有两个选项:
|
||||
|
||||
1. You want to create a separate fork and stop synchronizing with public version.
|
||||
1. 您要创建单独的分叉并停止与公共版本同步。
|
||||
|
||||
If you want to do that, you should modify your configuration file so verdaccio won't make requests regarding this package to npmjs anymore. Add a separate entry for this package to *config.yaml* and remove `npmjs` from `proxy` list and restart the server.
|
||||
如果您希望这么做,您应该修改配置文件,这样verdaccio将不再向npmjs提出此包的请求。 将此包单独添加到*config.yaml* 中并从`proxy`列表删除`npmjs`,然后重启服务器。
|
||||
|
||||
When you publish your package locally, you should probably start with version string higher than existing one, so it won't conflict with existing package in the cache.
|
||||
当您在本地发布包,您可能应该从现有版本更高的 string开始,这样它就不会和缓存中的现有包冲突。
|
||||
|
||||
2. You want to temporarily use your version, but return to public one as soon as it's updated.
|
||||
2. 您希望临时使用自己的版本,但在它更新后立即切换回公共版本。
|
||||
|
||||
In order to avoid version conflicts, you should use a custom pre-release suffix of the next patch version. For example, if a public package has version 0.1.2, you can upload 0.1.3-my-temp-fix. This way your package will be used until its original maintainer updates his public package to 0.1.3.
|
||||
为了避免版本冲突,您应该使用下一个补丁版本的自定义预发行的后缀。 例如,如果公共包有 0.1.2版本,您可以上传0.1.3-my-temp-fix。 这样,您的包将在原始维护人员更新其公共包到0.1.3之前使用。
|
|
@ -1,12 +1,12 @@
|
|||
---
|
||||
id: webui
|
||||
title: "Web User Interface2"
|
||||
title: "网页用户界面2"
|
||||
---
|
||||
|
||||
|
||||
<p align="center"><img src="https://github.com/verdaccio/verdaccio/blob/master/assets/gif/verdaccio_big_30.gif?raw=true"></p>
|
||||
|
||||
Verdaccio has a web user interface to display only the private packges and can be customisable.
|
||||
Verdaccio有个网页用户界面,它只显示私有包并可以定制。
|
||||
|
||||
```yaml
|
||||
web:
|
||||
|
@ -15,12 +15,12 @@ web:
|
|||
logo: logo.png
|
||||
```
|
||||
|
||||
All access restrictions defined to [protect your packages](protect-your-dependencies.md) will also apply to the Web Interface.
|
||||
所有访问限制定义为[保护包](protect-your-dependencies.md),它也将应用于网页界面。
|
||||
|
||||
### Configuration
|
||||
### 配置
|
||||
|
||||
| Property | Type | Required | Example | Support | Description |
|
||||
| -------- | ------- | -------- | ------------------------------ | ------- | ---------------------------------- |
|
||||
| enable | boolean | No | true/false | all | allow to display the web interface |
|
||||
| title | string | No | Verdaccio | all | HTML head title description |
|
||||
| logo | string | No | http://my.logo.domain/logo.png | all | a URI where logo is located |
|
||||
| 属性 | 类型 | 必填 | 范例 | 支持 | 描述 |
|
||||
| ------ | ------- | -- | ------------------------------ | --- | ----------- |
|
||||
| enable | boolean | No | true/false | all | 允许显示网页界面 |
|
||||
| title | string | No | Verdaccio | all | HTML 页眉标题说明 |
|
||||
| logo | string | No | http://my.logo.domain/logo.png | all | logo 位于的URI |
|
Loading…
Add table
Reference in a new issue