Skip to content

Latest commit

 

History

History
80 lines (54 loc) · 3.34 KB

DEVELOPER_GUIDE.md

File metadata and controls

80 lines (54 loc) · 3.34 KB

Developer Guide

So you want to contribute code to this project? Excellent! We're glad you're here. Here's what you need to do.

Forking

Fork the repository on GitHub.

Install Prerequisites

You will need to install node.js, nvm, and yarn in your environment to properly pull down dependencies to build and bootstrap the plugin.

Setup

  1. Download OpenSearch Geospatial plugin, which requires same version with OpenSearch-Dashboard and dashboards-maps plugin.
  2. Run ./gradlew run under Geospatial plugin root path to start OpenSearch cluster.
  3. Download the OpenSearch Dashboards source code for the version specified in package.json you want to set up.
  4. Change your node version by nvm use <version>to the version specified in .node-version inside the OpenSearch Dashboards root directory.
  5. Create a plugins directory inside the OpenSearch Dashboards source code directory, if plugins directory doesn't exist.
  6. cd into plugins directory in the OpenSearch Dashboards source code directory.
  7. Check out this package from version control into the plugins directory.
  8. Run yarn osd bootstrap inside OpenSearch-Dashboards/plugins/dashboards-maps folder.

Ultimately, your directory structure should look like this:

├── OpenSearch-Dashboards
│   ├── plugins
│   │   └── dashboards-maps

Run

From OpenSearch-Dashboards repo (root folder), the following commands start OpenSearch Dashboards and includes this plugin.

yarn osd bootstrap --single-version=loose
yarn start --no-base-path

OpenSearch Dashboards will be available on localhost:5601.

Build

To build the plugin's distributable zip simply run yarn build.

Example output: ./build/customImportMapDashboards-1.0.0.0.zip

Test

From dashboards-maps folder running the following command runs the plugin unit tests:

Unit test

yarn test:jest

Integration Tests

All integration tests cases for maps-dashboards plugin are written in opensearch-dashboards-functional-test repository using the Cypress test framework. Please follow the DEVELOPER_GUIDE.md to run the integration tests. The tests are located in the cypress/fixtures/plugins/custom-import-map-dashboards directory.

Submitting Changes

See CONTRIBUTING.

Backports

The GitHub backport workflow creates backport PRs automatically for PRs with label backport <backport-branch-name>. Label should be attached to the original PR, backport workflow starts when original PR merged to main branch. For example, if a PR on main needs to be backported to 1.x branch, add a label backport 1.x to the PR and make sure the backport workflow runs on the PR along with other checks. Once this PR is merged to main, the workflow will create a backport PR to the 1.x branch.