From 391e77e98df7df569fb7ec68c58785ddfdc36445 Mon Sep 17 00:00:00 2001 From: "opensearch-trigger-bot[bot]" <98922864+opensearch-trigger-bot[bot]@users.noreply.github.com> Date: Tue, 2 May 2023 20:21:29 -0400 Subject: [PATCH] Updated developer guide for adding dependencies. (#7367) (#7376) * Updated developer guide for adding dependencies. * Update DEVELOPER_GUIDE.md --------- (cherry picked from commit 556c7245ca65edca6066eaace29bf88293b0d7fe) Signed-off-by: dblock Signed-off-by: Daniel (dB.) Doubrovkine Signed-off-by: github-actions[bot] Co-authored-by: github-actions[bot] Co-authored-by: Andriy Redko --- DEVELOPER_GUIDE.md | 24 +++++++++++++++++++++--- 1 file changed, 21 insertions(+), 3 deletions(-) diff --git a/DEVELOPER_GUIDE.md b/DEVELOPER_GUIDE.md index 0dd8fdb479a83..c9dc52f36a85d 100644 --- a/DEVELOPER_GUIDE.md +++ b/DEVELOPER_GUIDE.md @@ -26,6 +26,7 @@ - [`server`](#server) - [`test`](#test) - [Java Language Formatting Guidelines](#java-language-formatting-guidelines) + - [Adding Dependencies](#adding-dependencies) - [Editor / IDE Support](#editor--ide-support) - [Formatting Failures](#formatting-failures) - [Gradle Build](#gradle-build) @@ -39,7 +40,7 @@ - [Distribution Download Plugin](#distribution-download-plugin) - [Creating fat-JAR of a Module](#creating-fat-jar-of-a-module) - [Components](#components) - - [Build libraries & interfaces](#build-libraries--interfaces) + - [Build Libraries & Interfaces](#build-libraries--interfaces) - [Clients & Libraries](#clients--libraries) - [Plugins](#plugins-1) - [Indexing & Search](#indexing--search) @@ -328,6 +329,18 @@ Please follow these formatting guidelines: * Note that JavaDoc and block comments i.e. `/* ... */` are not formatted, but line comments i.e `// ...` are. * There is an implicit rule that negative boolean expressions should use the form `foo == false` instead of `!foo` for better readability of the code. While this isn't strictly enforced, if might get called out in PR reviews as something to change. +## Adding Dependencies + +When adding a new dependency or removing an existing dependency via any `build.gradle` (that are not in the test scope), update the dependency LICENSE and library SHAs. + +For example, after adding `api "org.slf4j:slf4j-api:${versions.slf4j}"` to [plugins/discovery-ec2/build.gradle](plugins/discovery-ec2/build.gradle), copy the library `LICENSE.txt` and `NOTICE.txt` to `plugins/discovery-ec2/licenses/slf4j-api-LICENSE.txt` and `plugins/discovery-ec2/licenses/slf4j-api-NOTICE.txt`, then run the following to generate `plugins/discovery-ec2/licenses/slf4j-api-1.7.36.jar.sha1`. + +``` +./gradlew :plugins:discovery-ec2:updateSHAs +``` + +Ensure that `./gradlew :plugins:discovery-ec2:check` passes before submitting changes. + ### Editor / IDE Support IntelliJ IDEs can [import](https://blog.jetbrains.com/idea/2014/01/intellij-idea-13-importing-code-formatter-settings-from-eclipse/) the [settings file](buildSrc/formatterConfig.xml), and / or use the [Eclipse Code Formatter](https://plugins.jetbrains.com/plugin/6546-eclipse-code-formatter) @@ -424,7 +437,7 @@ Refer the installed JAR as any other maven artifact, e.g. As you work in the OpenSearch repo you may notice issues getting labeled with component labels. It's a housekeeping task to help group together similar pieces of work. You can pretty much ignore it, but if you're curious, here's what the different labels mean: -### Build libraries & interfaces +### Build Libraries & Interfaces Tasks to make sure the build tasks are useful and packaging and distribution are easy. @@ -437,7 +450,6 @@ Includes: - Compatibility - Javadoc enforcement - ### Clients & Libraries APIs and communication mechanisms for external connections to OpenSearch. This includes the “library” directory in OpenSearch (a set of common functions). @@ -499,6 +511,7 @@ Includes: Security is our top priority. Avoid checking in credentials. #### Installation + Install [awslabs/git-secrets](https://github.com/awslabs/git-secrets) by running the following commands. ``` git clone https://github.com/awslabs/git-secrets.git @@ -507,6 +520,7 @@ make install ``` #### Configuration + You can configure git secrets per repository, you need to change the directory to the root of the repository and run the following command. ``` git secrets --install @@ -533,11 +547,13 @@ OpenSearch addresses backward and forward compatibility at three different level to ensure backwards compatibility are provided below. #### Data + The data level consists of index and application data file formats. OpenSearch guarantees file formats and indexes are compatible only back to the first release of the previous major version. If on disk formats or encodings need to be changed (including index data, cluster state, or any other persisted data) developers must use Version checks accordingly (e.g., `Version.onOrAfter`, `Version.before`) to guarantee backwards compatibility. #### Developer API + The Developer API consists of interfaces and foundation software implementations that enable external users to develop new OpenSearch features. This includes obvious components such as the Plugin framework and less obvious components such as REST Action Handlers. When developing a new feature of OpenSearch it is important to explicitly mark which implementation components may, or may not, be extended by external implementations. For example, all new API classes with `@opensearch.api` @@ -547,6 +563,7 @@ guarantee backwards compatibility and may change at any time. The `@deprecated` either changed or planned to be removed across minor versions. #### User API + The User API consists of integration specifications (e.g., [Query Domain Specific Language](https://opensearch.org/docs/latest/opensearch/query-dsl/index/), [field mappings](https://opensearch.org/docs/latest/opensearch/mappings/)) and endpoints (e.g., [`_search`](https://opensearch.org/docs/latest/api-reference/search/), [`_cat`](https://opensearch.org/docs/latest/api-reference/cat/index/)) users rely on to integrate and use OpenSearch. Backwards compatibility is critical to the @@ -556,6 +573,7 @@ users of any changes by adding the `>breaking` label on Pull Requests, adding an and a log message to the OpenSearch deprecation log files using the `DeprecationLogger`. #### Experimental Development + Rapidly developing new features often benefit from several release cycles before committing to an official and long term supported (LTS) API. To enable this cycle OpenSearch uses an Experimental Development process leveraging [Feature Flags](https://featureflags.io/feature-flags/). This allows a feature to be developed using the same process as a LTS feature but with additional guard rails and communication mechanisms to signal to the users and development community the feature is not yet stable, may change in a future