forked from dapr/components-contrib
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add certification tests for MongoDB state store
Closes dapr#1938 Signed-off-by: Yash Nisar <[email protected]>
- Loading branch information
1 parent
2dd5533
commit b194ed2
Showing
12 changed files
with
1,755 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
# MongoDB State Store certification testing | ||
|
||
This project aims to test the MongoDB State Store component under various conditions. | ||
|
||
## Test plan | ||
|
||
## Basic Test for CRUD operations: | ||
1. Able to create and test connection. | ||
2. Able to do set, fetch, update and delete. | ||
3. Negative test to fetch record with key, that is not present. | ||
|
||
## Component must reconnect when server or network errors are encountered | ||
|
||
## Infra test: | ||
1. When MongoDB goes down and then comes back up - client is able to connect |
15 changes: 15 additions & 0 deletions
15
tests/certification/state/mongodb/components/docker/default/mongodbstatestore.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
apiVersion: dapr.io/v1alpha1 | ||
kind: Component | ||
metadata: | ||
name: statestore | ||
spec: | ||
type: state.mongodb | ||
version: v1 | ||
initTimeout: 5m | ||
metadata: | ||
- name: host | ||
value: "localhost:27017" | ||
- name: databaseName | ||
value: "admin" | ||
- name: params | ||
value: "?replicaSet=rs0&directConnection=true" |
19 changes: 19 additions & 0 deletions
19
tests/certification/state/mongodb/components/docker/singleNode/mongodbstatestore.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
apiVersion: dapr.io/v1alpha1 | ||
kind: Component | ||
metadata: | ||
name: statestore | ||
spec: | ||
type: state.mongodb | ||
version: v1 | ||
initTimeout: 5m | ||
metadata: | ||
- name: host | ||
value: "localhost:27017" | ||
- name: databaseName | ||
value: "admin" | ||
- name: writeConcern | ||
value: "majority" | ||
- name: readConcern | ||
value: "local" | ||
- name: operationTimeout | ||
value: "10s" |
21 changes: 21 additions & 0 deletions
21
...on/state/mongodb/components/docker/validReadWriteConcernAndTimeout/mongodbstatestore.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
apiVersion: dapr.io/v1alpha1 | ||
kind: Component | ||
metadata: | ||
name: statestore | ||
spec: | ||
type: state.mongodb | ||
version: v1 | ||
initTimeout: 5m | ||
metadata: | ||
- name: host | ||
value: "localhost:27017" | ||
- name: databaseName | ||
value: "admin" | ||
- name: writeConcern | ||
value: "majority" | ||
- name: readConcern | ||
value: "local" | ||
- name: operationTimeout | ||
value: "10s" | ||
- name: params | ||
value: "?replicaSet=rs0&directConnection=true" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
apiVersion: dapr.io/v1alpha1 | ||
kind: Configuration | ||
metadata: | ||
name: keyvaultconfig | ||
spec: | ||
features: |
48 changes: 48 additions & 0 deletions
48
tests/certification/state/mongodb/docker-compose-cluster.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
version: '3.8' | ||
|
||
services: | ||
|
||
mongo1: | ||
image: mongo | ||
restart: always | ||
ports: | ||
- 27017:27017 | ||
volumes: | ||
- mongo1:/data/db | ||
entrypoint: [ "/usr/bin/mongod", "--bind_ip_all", "--replSet", "rs0"] | ||
|
||
mongo2: | ||
image: mongo | ||
restart: always | ||
ports: | ||
- 27018:27017 | ||
volumes: | ||
- mongo2:/data/db | ||
entrypoint: [ "/usr/bin/mongod", "--bind_ip_all", "--replSet", "rs0" ] | ||
|
||
mongo3: | ||
image: mongo | ||
restart: always | ||
ports: | ||
- 27019:27017 | ||
volumes: | ||
- mongo3:/data/db | ||
entrypoint: [ "/usr/bin/mongod", "--bind_ip_all", "--replSet", "rs0" ] | ||
|
||
mongosetup: | ||
image: mongo | ||
links: | ||
- mongo1 | ||
depends_on: | ||
- mongo1 | ||
- mongo2 | ||
- mongo3 | ||
volumes: | ||
- .:/scripts | ||
restart: "no" | ||
entrypoint: [ "bash", "/scripts/mongo_setup.sh" ] | ||
|
||
volumes: | ||
mongo1: | ||
mongo2: | ||
mongo3: |
15 changes: 15 additions & 0 deletions
15
tests/certification/state/mongodb/docker-compose-single.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
version: '3.8' | ||
|
||
services: | ||
|
||
mongo1: | ||
image: mongo | ||
restart: always | ||
ports: | ||
- 27017:27017 | ||
volumes: | ||
- mongo1:/data/db | ||
entrypoint: [ "/usr/bin/mongod", "--bind_ip_all"] | ||
|
||
volumes: | ||
mongo1: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,143 @@ | ||
module github.com/dapr/components-contrib/tests/certification/state/mongodb | ||
|
||
go 1.19 | ||
|
||
require ( | ||
github.com/dapr/components-contrib v1.8.0-rc.6 | ||
github.com/dapr/components-contrib/tests/certification v0.0.0-20220526162429-d03aeba3e0d6 | ||
github.com/dapr/dapr v1.8.4-0.20220829184035-996cc622ad0c | ||
github.com/dapr/go-sdk v1.4.0 | ||
github.com/dapr/kit v0.0.2 | ||
github.com/stretchr/testify v1.8.0 | ||
) | ||
|
||
require ( | ||
contrib.go.opencensus.io/exporter/prometheus v0.4.1 // indirect | ||
github.com/AdhityaRamadhanus/fasthttpcors v0.0.0-20170121111917-d4c07198763a // indirect | ||
github.com/PuerkitoBio/purell v1.1.1 // indirect | ||
github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578 // indirect | ||
github.com/agrea/ptr v0.0.0-20180711073057-77a518d99b7b // indirect | ||
github.com/andybalholm/brotli v1.0.4 // indirect | ||
github.com/antlr/antlr4/runtime/Go/antlr v0.0.0-20210826220005-b48c857c3a0e // indirect | ||
github.com/armon/go-metrics v0.3.10 // indirect | ||
github.com/aws/aws-sdk-go v1.43.16 // indirect | ||
github.com/beorn7/perks v1.0.1 // indirect | ||
github.com/cenkalti/backoff v2.2.1+incompatible // indirect | ||
github.com/cenkalti/backoff/v4 v4.1.3 // indirect | ||
github.com/cespare/xxhash/v2 v2.1.2 // indirect | ||
github.com/davecgh/go-spew v1.1.1 // indirect | ||
github.com/evanphx/json-patch v4.12.0+incompatible // indirect | ||
github.com/fasthttp/router v1.3.8 // indirect | ||
github.com/fatih/color v1.13.0 // indirect | ||
github.com/fsnotify/fsnotify v1.5.4 // indirect | ||
github.com/ghodss/yaml v1.0.0 // indirect | ||
github.com/go-kit/log v0.2.0 // indirect | ||
github.com/go-logfmt/logfmt v0.5.1 // indirect | ||
github.com/go-logr/logr v1.2.3 // indirect | ||
github.com/go-logr/stdr v1.2.2 // indirect | ||
github.com/go-stack/stack v1.8.0 // indirect | ||
github.com/gogo/protobuf v1.3.2 // indirect | ||
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect | ||
github.com/golang/mock v1.6.0 // indirect | ||
github.com/golang/protobuf v1.5.2 // indirect | ||
github.com/golang/snappy v0.0.4 // indirect | ||
github.com/google/cel-go v0.9.0 // indirect | ||
github.com/google/go-cmp v0.5.8 // indirect | ||
github.com/google/gofuzz v1.2.0 // indirect | ||
github.com/google/uuid v1.3.0 // indirect | ||
github.com/googleapis/gnostic v0.5.5 // indirect | ||
github.com/grandcat/zeroconf v0.0.0-20190424104450-85eadb44205c // indirect | ||
github.com/grpc-ecosystem/go-grpc-middleware v1.3.0 // indirect | ||
github.com/grpc-ecosystem/grpc-gateway/v2 v2.7.0 // indirect | ||
github.com/hashicorp/consul/api v1.11.0 // indirect | ||
github.com/hashicorp/errwrap v1.1.0 // indirect | ||
github.com/hashicorp/go-cleanhttp v0.5.2 // indirect | ||
github.com/hashicorp/go-hclog v1.2.1 // indirect | ||
github.com/hashicorp/go-immutable-radix v1.3.1 // indirect | ||
github.com/hashicorp/go-multierror v1.1.1 // indirect | ||
github.com/hashicorp/go-rootcerts v1.0.2 // indirect | ||
github.com/hashicorp/golang-lru v0.5.4 // indirect | ||
github.com/hashicorp/serf v0.9.6 // indirect | ||
github.com/imdario/mergo v0.3.12 // indirect | ||
github.com/jmespath/go-jmespath v0.4.0 // indirect | ||
github.com/json-iterator/go v1.1.12 // indirect | ||
github.com/klauspost/compress v1.15.1 // indirect | ||
github.com/mattn/go-colorable v0.1.12 // indirect | ||
github.com/mattn/go-isatty v0.0.14 // indirect | ||
github.com/matttproud/golang_protobuf_extensions v1.0.2-0.20181231171920-c182affec369 // indirect | ||
github.com/miekg/dns v1.1.50 // indirect | ||
github.com/minio/blake2b-simd v0.0.0-20160723061019-3f5f724cb5b1 // indirect | ||
github.com/mitchellh/go-homedir v1.1.0 // indirect | ||
github.com/mitchellh/mapstructure v1.5.1-0.20220423185008-bf980b35cac4 // indirect | ||
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect | ||
github.com/modern-go/reflect2 v1.0.2 // indirect | ||
github.com/openzipkin/zipkin-go v0.4.0 // indirect | ||
github.com/pkg/errors v0.9.1 // indirect | ||
github.com/pmezard/go-difflib v1.0.0 // indirect | ||
github.com/prometheus/client_golang v1.12.2 // indirect | ||
github.com/prometheus/client_model v0.2.0 // indirect | ||
github.com/prometheus/common v0.35.0 // indirect | ||
github.com/prometheus/procfs v0.7.3 // indirect | ||
github.com/prometheus/statsd_exporter v0.22.3 // indirect | ||
github.com/savsgio/gotils v0.0.0-20210217112953-d4a072536008 // indirect | ||
github.com/sirupsen/logrus v1.9.0 // indirect | ||
github.com/sony/gobreaker v0.4.2-0.20210216022020-dd874f9dd33b // indirect | ||
github.com/spf13/pflag v1.0.5 // indirect | ||
github.com/stoewer/go-strcase v1.2.0 // indirect | ||
github.com/stretchr/objx v0.4.0 // indirect | ||
github.com/tylertreat/comcast v1.0.1 // indirect | ||
github.com/valyala/bytebufferpool v1.0.0 // indirect | ||
github.com/valyala/fasthttp v1.34.0 // indirect | ||
github.com/xdg-go/pbkdf2 v1.0.0 // indirect | ||
github.com/xdg-go/scram v1.0.2 // indirect | ||
github.com/xdg-go/stringprep v1.0.2 // indirect | ||
github.com/youmark/pkcs8 v0.0.0-20181117223130-1be2e3e5546d // indirect | ||
go.mongodb.org/mongo-driver v1.5.1 // indirect | ||
go.opencensus.io v0.23.0 // indirect | ||
go.opentelemetry.io/otel v1.7.0 // indirect | ||
go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.7.0 // indirect | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.7.0 // indirect | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.7.0 // indirect | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.7.0 // indirect | ||
go.opentelemetry.io/otel/exporters/zipkin v1.7.0 // indirect | ||
go.opentelemetry.io/otel/sdk v1.7.0 // indirect | ||
go.opentelemetry.io/otel/trace v1.7.0 // indirect | ||
go.opentelemetry.io/proto/otlp v0.16.0 // indirect | ||
go.uber.org/atomic v1.9.0 // indirect | ||
golang.org/x/crypto v0.0.0-20220525230936-793ad666bf5e // indirect | ||
golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4 // indirect | ||
golang.org/x/net v0.0.0-20220630215102-69896b714898 // indirect | ||
golang.org/x/oauth2 v0.0.0-20220309155454-6242fa91716a // indirect | ||
golang.org/x/sync v0.0.0-20220601150217-0de741cfad7f // indirect | ||
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8 // indirect | ||
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211 // indirect | ||
golang.org/x/text v0.3.7 // indirect | ||
golang.org/x/time v0.0.0-20211116232009-f0f3c7e86c11 // indirect | ||
golang.org/x/tools v0.1.11 // indirect | ||
gomodules.xyz/jsonpatch/v2 v2.2.0 // indirect | ||
google.golang.org/appengine v1.6.7 // indirect | ||
google.golang.org/genproto v0.0.0-20220622171453-ea41d75dfa0f // indirect | ||
google.golang.org/grpc v1.47.0 // indirect | ||
google.golang.org/protobuf v1.28.0 // indirect | ||
gopkg.in/inf.v0 v0.9.1 // indirect | ||
gopkg.in/yaml.v2 v2.4.0 // indirect | ||
gopkg.in/yaml.v3 v3.0.1 // indirect | ||
k8s.io/api v0.23.0 // indirect | ||
k8s.io/apiextensions-apiserver v0.23.0 // indirect | ||
k8s.io/apimachinery v0.23.0 // indirect | ||
k8s.io/client-go v0.23.0 // indirect | ||
k8s.io/component-base v0.23.0 // indirect | ||
k8s.io/klog/v2 v2.30.0 // indirect | ||
k8s.io/kube-openapi v0.0.0-20211115234752-e816edb12b65 // indirect | ||
k8s.io/utils v0.0.0-20210930125809-cb0fa318a74b // indirect | ||
sigs.k8s.io/controller-runtime v0.11.0 // indirect | ||
sigs.k8s.io/json v0.0.0-20211020170558-c049b76a60c6 // indirect | ||
sigs.k8s.io/structured-merge-diff/v4 v4.2.0 // indirect | ||
sigs.k8s.io/yaml v1.3.0 // indirect | ||
) | ||
|
||
replace github.com/dapr/components-contrib/tests/certification => ../../ | ||
|
||
replace github.com/dapr/components-contrib => ../../../../ | ||
|
||
replace github.com/dapr/go-sdk => github.com/hunter007/dapr-go-sdk v1.3.1-0.20220709114046-2f2dc4f9a684 |
Oops, something went wrong.