So you want to contribute code to the OpenSearch Node.js Client? Excellent! We're glad you're here. Here's what you need to do:
Fork opensearch-project/opensearch-js and clone locally,
e.g. git clone https://github.com/[your username]/opensearch-js.git
.
The minimum supported version of Node.js is v10.
This project uses yarn as it's package manager. You can use npm to install yarn:
npm install --global yarn
Docker is required for building some OpenSearch artifacts and executing integration tests.
To install all the dependencies needed for this project, run
yarn install
There might be an issue on Windows OS:
yarn. ps1 cannot be loaded because running scripts is disabled on this system
If it occurs, open Windows PowerShell as an administrator and run:
Set-ExecutionPolicy unrestricted
Then type Y
Now you can run yarn install
To do a ESLint check on the project, run:
yarn run lint
To let ESLint to fix errors in your code automatically, run:
yarn run lint:fix
This will instruct ESLint to try to fix as many issues as possible. The fixes are made to the actual files themselves and only the remaining unfixed issues are output.
Not all problems are fixable using this option, and some of them you will need to fix manually.
Go to your terminal and run:
cd folder-path
yarn run test:unit
To run a specific unit test, you can use the following jest command. yarn test
will not work.
cd folder-path/to/test
jest TestName
If you don't have jest, you can install it via yarn
yarn global add jest-cli
In order to test opensearch-js client, you need a running OpenSearch cluster. You can use Docker to accomplish this. The Docker Compose file supports the ability to run integration tests for the project in local environments. If you have not installed docker-compose, you can install it from this link.
-
Run below command to start containers. By default, it will launch latest OpenSearch cluster.
cd folder-path/.ci/opensearch docker-compose up
-
Run all integration tests.
yarn run test:integration:helpers
-
Stop and clean containers.
docker-compose down