Home

Awesome

Issues | Forums | Discord | Documentation

Couchbase JVM Clients

license

java-client scala-client kotlin-client

This repository contains the third generation of the Couchbase SDKs on the JVM ("SDK 3").

Overview

This repository contains the following projects:

Other toplevel modules might be present which contain examples, experimental code or internal tooling and test infrastructure.

Documentation is available for Java, Scala and Kotlin.
These include getting started guides.

Building

Stable releases are published on maven central.

You can always also just build it from source, using any JDK 17+:

$ git clone https://github.com/couchbase/couchbase-jvm-clients.git
$ cd couchbase-jvm-clients
$ make

Yes, we need make because maven doesn't support the setup we need and neither does gradle. If you want to build for different Scala versions, after the first make you can do this through:

$ ./mvnw -D"scala.compat.version=2.13" -D"scala.compat.library.version=2.13.13" clean install

Notes:

Testing

You can test like this:

$ ./mvnw clean test -fae

Testing with FIT

(This section is for internal consumption for Couchbase developers.)

Increasingly the SDK is tested internally with Couchbase's FIT suite.
Each SDK has its own FIT 'performer' - java-fit-performer, scala-fit-performer and kotlin-fit-performer. They are not included in the build by default as they require a) JDK 17 and b) the fit-grpc library (built separately).

To use a performer, uncomment the lines in the top-level pom.xml after 'Uncomment next lines to include the FIT performers', and reload the Maven config. Then run one of the performers in an IDE.

Branches & Release Trains

Since this monorepo houses different versions of different artifacts, release train names have been chosen to identify a collection of releases that belong to the same train.

These trains are named after historic computers for your delight.

Tags in each branch are named branchname-ga for the initial GA release, and then subsequently branchname-sr-n for each service release. See the tag information for specifics of what's in there.

Release TrainJava-ClientScala-ClientCore-IoTracing-OpenTelemetryTracing-OpenTracingMetrics-OpenTelemetryMetrics-Micrometer
colossus3.0.x1.0.x2.0.x0.2.x0.2.x--
pegasus3.1.x1.1.x2.1.x0.3.x0.3.x0.1.x0.1.x
hopper3.2.x1.2.x2.2.x1.0.x1.0.x0.2.x0.2.x
eos3.3.x1.3.x2.3.x1.1.x1.2.x0.3.x0.3.x
frontier3.4.x1.4.x2.4.x1.2.x1.3.x0.4.x0.4.x
titan3.5.x1.5.x2.5.x1.3.x1.4.x0.5.x0.5.x

Testing Info

To cover all tests, the suite needs to be run against the following topologies, but by default it runs against the mock. Recommended topologies:

Also to have maximum service coverage use a cluster which has all services enabled (can be MDS setup).

Building Documentation

Documentation will be built automatically by the mvn install command above.

According to the Maven standard, the file is named artifact-version-javadoc.jar (i.e. java-client-3.4.5-javadoc.jar).

This file can be extracted (jars are like zip files) with the following command:

jar xvf java-client-3.4.5-javadoc.jar

This will extract the contents of the javadoc file into the current directory. After the original jar is removed it can be uploaded to s3.

The location of the javadoc files depends on where you get it from. The easiest is, once published, from Maven central. For example, look it up on Maven central: https://search.maven.org/artifact/com.couchbase.client/java-client/3.4.5/jar and download the javadoc jar: https://search.maven.org/remotecontent?filepath=com/couchbase/client/java-client/3.0.4/java-client-3.4.5-javadoc.jar

The exact same approach can be used for any artifact, including Scala. The Scala documentation can also be built with this command:

cd scala-client && mvn scala:doc

IDE Configuration

IntelliJ

Scala code is automatically formatted on compile with the tool scalafmt. To make IntelliJ use the same settings:

In Editor -> Code Style -> Scala:

(mvn validate can be used from command-line to force reformat)