Merge branch 'master' into workflow-dev
This commit is contained in:
		
						commit
						d8b5d14330
					
				|  | @ -52,6 +52,7 @@ jobs: | ||||||
|         - secretstores.local.file |         - secretstores.local.file | ||||||
|         - bindings.rabbitmq |         - bindings.rabbitmq | ||||||
|         - bindings.localstorage |         - bindings.localstorage | ||||||
|  |         - bindings.postgres | ||||||
|         EOF |         EOF | ||||||
|         ) |         ) | ||||||
|         echo "::set-output name=pr-components::$PR_COMPONENTS" |         echo "::set-output name=pr-components::$PR_COMPONENTS" | ||||||
|  |  | ||||||
|  | @ -0,0 +1,24 @@ | ||||||
|  | # PostgreSQL Output Binding Certification | ||||||
|  | 
 | ||||||
|  | The purpose of this module is to provide tests that certify the PostgreSQL Output Binding as a stable component. | ||||||
|  | 
 | ||||||
|  | ## Test plan | ||||||
|  | 
 | ||||||
|  | * Verify the postgres is created/present | ||||||
|  |     * Create component spec | ||||||
|  |     * Run dapr application with component | ||||||
|  |     * Ensure the postgres is present | ||||||
|  | * Verify the connection is established to postgres. | ||||||
|  |     * Create component spec. | ||||||
|  |     * Run dapr application with component. | ||||||
|  |     * Ensure that you have access to postgres and connection to postgres DB is established. | ||||||
|  | * Verify data is getting stored in postgres DB. | ||||||
|  |     * Create component spec with the data to be stored. | ||||||
|  |     * Run dapr application with component to store data in postgres as output binding. | ||||||
|  |     * Read stored data from postgres. | ||||||
|  |     * Ensure that read data is same as the data that was stored. | ||||||
|  | * Verify reconnection to postgres for output binding. | ||||||
|  |     * Simulate a network error before sending any messages. | ||||||
|  |     * Run dapr application with the component. | ||||||
|  |     * After the reconnection, send messages to postgres. | ||||||
|  |     * Ensure that the messages sent after the reconnection are stored in postgres. | ||||||
|  | @ -0,0 +1,10 @@ | ||||||
|  | apiVersion: dapr.io/v1alpha1 | ||||||
|  | kind: Component | ||||||
|  | metadata: | ||||||
|  |   name: standard-binding | ||||||
|  | spec: | ||||||
|  |   type: bindings.postgres | ||||||
|  |   version: v1 | ||||||
|  |   metadata: | ||||||
|  |     - name: url | ||||||
|  |       value: "host=localhost user=postgres password=example port=5432 connect_timeout=10 database=dapr_test" | ||||||
|  | @ -0,0 +1,6 @@ | ||||||
|  | apiVersion: dapr.io/v1alpha1 | ||||||
|  | kind: Configuration | ||||||
|  | metadata: | ||||||
|  |   name: keyvaultconfig | ||||||
|  | spec: | ||||||
|  |   features: | ||||||
|  | @ -0,0 +1,11 @@ | ||||||
|  | version: '2' | ||||||
|  | services: | ||||||
|  |   db: | ||||||
|  |     image: postgres | ||||||
|  |     restart: always | ||||||
|  |     ports: | ||||||
|  |       - "5432:5432" | ||||||
|  |     environment: | ||||||
|  |       POSTGRES_USER: postgres | ||||||
|  |       POSTGRES_PASSWORD: example | ||||||
|  |       POSTGRES_DB: dapr_test | ||||||
|  | @ -0,0 +1,144 @@ | ||||||
|  | module github.com/dapr/components-contrib/tests/certification/state/postgresql | ||||||
|  | 
 | ||||||
|  | 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/lib/pq v1.10.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/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/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/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/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/jackc/chunkreader/v2 v2.0.1 // indirect | ||||||
|  | 	github.com/jackc/pgconn v1.11.0 // indirect | ||||||
|  | 	github.com/jackc/pgio v1.0.0 // indirect | ||||||
|  | 	github.com/jackc/pgpassfile v1.0.0 // indirect | ||||||
|  | 	github.com/jackc/pgproto3/v2 v2.2.0 // indirect | ||||||
|  | 	github.com/jackc/pgservicefile v0.0.0-20200714003250-2b9c44734f2b // indirect | ||||||
|  | 	github.com/jackc/pgtype v1.10.0 // indirect | ||||||
|  | 	github.com/jackc/pgx/v4 v4.15.0 // indirect | ||||||
|  | 	github.com/jackc/puddle v1.2.1 // 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 | ||||||
|  | 	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/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 | ||||||
|  | 
 | ||||||
|  | replace github.com/dapr/dapr => github.com/1046102779/dapr v1.5.2-0.20220829014128-56ac94bfadd1 | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -0,0 +1,212 @@ | ||||||
|  | /* | ||||||
|  | Copyright 2022 The Dapr Authors | ||||||
|  | Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
|  | you may not use this file except in compliance with the License. | ||||||
|  | You may obtain a copy of the License at | ||||||
|  |     http://www.apache.org/licenses/LICENSE-2.0
 | ||||||
|  | Unless required by applicable law or agreed to in writing, software | ||||||
|  | distributed under the License is distributed on an "AS IS" BASIS, | ||||||
|  | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||||
|  | See the License for the specific language governing permissions and | ||||||
|  | limitations under the License. | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | package postgres_test | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"database/sql" | ||||||
|  | 	"fmt" | ||||||
|  | 	"testing" | ||||||
|  | 	"time" | ||||||
|  | 
 | ||||||
|  | 	_ "github.com/lib/pq" | ||||||
|  | 
 | ||||||
|  | 	"github.com/stretchr/testify/assert" | ||||||
|  | 	"github.com/stretchr/testify/require" | ||||||
|  | 
 | ||||||
|  | 	"github.com/dapr/components-contrib/bindings" | ||||||
|  | 	binding_postgres "github.com/dapr/components-contrib/bindings/postgres" | ||||||
|  | 	bindings_loader "github.com/dapr/dapr/pkg/components/bindings" | ||||||
|  | 	"github.com/dapr/dapr/pkg/runtime" | ||||||
|  | 	dapr_testing "github.com/dapr/dapr/pkg/testing" | ||||||
|  | 	daprClient "github.com/dapr/go-sdk/client" | ||||||
|  | 	"github.com/dapr/kit/logger" | ||||||
|  | 
 | ||||||
|  | 	"github.com/dapr/components-contrib/tests/certification/embedded" | ||||||
|  | 	"github.com/dapr/components-contrib/tests/certification/flow" | ||||||
|  | 	"github.com/dapr/components-contrib/tests/certification/flow/dockercompose" | ||||||
|  | 	"github.com/dapr/components-contrib/tests/certification/flow/network" | ||||||
|  | 	"github.com/dapr/components-contrib/tests/certification/flow/sidecar" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | const ( | ||||||
|  | 	dockerComposeYAML      = "docker-compose.yml" | ||||||
|  | 	numOfMessages          = 10 | ||||||
|  | 	dockerConnectionString = "host=localhost user=postgres password=example port=5432 connect_timeout=10 database=dapr_test sslmode=disable" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | func TestPostgres(t *testing.T) { | ||||||
|  | 
 | ||||||
|  | 	ports, _ := dapr_testing.GetFreePorts(3) | ||||||
|  | 	grpcPort := ports[0] | ||||||
|  | 	httpPort := ports[1] | ||||||
|  | 
 | ||||||
|  | 	testExec := func(ctx flow.Context) error { | ||||||
|  | 		client, err := daprClient.NewClientWithPort(fmt.Sprintf("%d", grpcPort)) | ||||||
|  | 		require.NoError(t, err, "Could not initialize dapr client.") | ||||||
|  | 
 | ||||||
|  | 		metadata := make(map[string]string) | ||||||
|  | 
 | ||||||
|  | 		ctx.Log("Invoking output binding for exec operation!") | ||||||
|  | 		req := &daprClient.InvokeBindingRequest{Name: "standard-binding", Operation: "exec", Metadata: metadata} | ||||||
|  | 		req.Metadata["sql"] = "INSERT INTO dapr_test_table (id, c1, ts) VALUES (1, 'demo', '2020-09-24T11:45:05Z07:00');" | ||||||
|  | 		errBinding := client.InvokeOutputBinding(ctx, req) | ||||||
|  | 		require.NoError(ctx, errBinding, "error in output binding - exec") | ||||||
|  | 
 | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	testQuery := func(ctx flow.Context) error { | ||||||
|  | 		client, err := daprClient.NewClientWithPort(fmt.Sprintf("%d", grpcPort)) | ||||||
|  | 		require.NoError(t, err, "Could not initialize dapr client.") | ||||||
|  | 
 | ||||||
|  | 		metadata := make(map[string]string) | ||||||
|  | 
 | ||||||
|  | 		ctx.Log("Invoking output binding for query operation!") | ||||||
|  | 		req := &daprClient.InvokeBindingRequest{Name: "standard-binding", Operation: "query", Metadata: metadata} | ||||||
|  | 		req.Metadata["sql"] = "SELECT * FROM dapr_test_table WHERE id = 1;" | ||||||
|  | 		resp, errBinding := client.InvokeBinding(ctx, req) | ||||||
|  | 		assert.Contains(t, string(resp.Data), "1,\"demo\",\"2020-09-24T11:45:05Z07:00\"") | ||||||
|  | 		require.NoError(ctx, errBinding, "error in output binding - query") | ||||||
|  | 
 | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	testClose := func(ctx flow.Context) error { | ||||||
|  | 		client, err := daprClient.NewClientWithPort(fmt.Sprintf("%d", grpcPort)) | ||||||
|  | 		require.NoError(t, err, "Could not initialize dapr client.") | ||||||
|  | 
 | ||||||
|  | 		metadata := make(map[string]string) | ||||||
|  | 
 | ||||||
|  | 		ctx.Log("Invoking output binding for query operation!") | ||||||
|  | 		req := &daprClient.InvokeBindingRequest{Name: "standard-binding", Operation: "close", Metadata: metadata} | ||||||
|  | 		errBinding := client.InvokeOutputBinding(ctx, req) | ||||||
|  | 		require.NoError(ctx, errBinding, "error in output binding - close") | ||||||
|  | 
 | ||||||
|  | 		req = &daprClient.InvokeBindingRequest{Name: "standard-binding", Operation: "query", Metadata: metadata} | ||||||
|  | 		req.Metadata["sql"] = "SELECT * FROM dapr_test_table WHERE id = 1;" | ||||||
|  | 		errBinding = client.InvokeOutputBinding(ctx, req) | ||||||
|  | 		require.Error(ctx, errBinding, "error in output binding - query") | ||||||
|  | 
 | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	createTable := func(ctx flow.Context) error { | ||||||
|  | 		db, err := sql.Open("postgres", dockerConnectionString) | ||||||
|  | 		assert.NoError(t, err) | ||||||
|  | 		_, err = db.Exec("CREATE TABLE dapr_test_table(id INT, c1 TEXT, ts TEXT);") | ||||||
|  | 		assert.NoError(t, err) | ||||||
|  | 		db.Close() | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	flow.New(t, "Run tests"). | ||||||
|  | 		Step(dockercompose.Run("db", dockerComposeYAML)). | ||||||
|  | 		Step("wait for component to start", flow.Sleep(10*time.Second)). | ||||||
|  | 		Step("Creating table", createTable). | ||||||
|  | 		Step("wait for component to start", flow.Sleep(10*time.Second)). | ||||||
|  | 		Step(sidecar.Run("standardSidecar", | ||||||
|  | 			embedded.WithoutApp(), | ||||||
|  | 			embedded.WithDaprGRPCPort(grpcPort), | ||||||
|  | 			embedded.WithDaprHTTPPort(httpPort), | ||||||
|  | 			embedded.WithComponentsPath("./components/standard"), | ||||||
|  | 			componentRuntimeOptions(), | ||||||
|  | 		)). | ||||||
|  | 		Step("Run exec test", testExec). | ||||||
|  | 		Step("Run query test", testQuery). | ||||||
|  | 		Step("wait for DB operations to complete", flow.Sleep(10*time.Second)). | ||||||
|  | 		Step("Run close test", testClose). | ||||||
|  | 		Step("stop postgresql", dockercompose.Stop("db", dockerComposeYAML, "db")). | ||||||
|  | 		Step("wait for component to start", flow.Sleep(10*time.Second)). | ||||||
|  | 		Run() | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func TestPostgresNetworkError(t *testing.T) { | ||||||
|  | 
 | ||||||
|  | 	ports, _ := dapr_testing.GetFreePorts(3) | ||||||
|  | 	grpcPort := ports[0] | ||||||
|  | 	httpPort := ports[1] | ||||||
|  | 
 | ||||||
|  | 	testExec := func(ctx flow.Context) error { | ||||||
|  | 		client, err := daprClient.NewClientWithPort(fmt.Sprintf("%d", grpcPort)) | ||||||
|  | 		require.NoError(t, err, "Could not initialize dapr client.") | ||||||
|  | 
 | ||||||
|  | 		metadata := make(map[string]string) | ||||||
|  | 
 | ||||||
|  | 		ctx.Log("Invoking output binding for exec operation!") | ||||||
|  | 		req := &daprClient.InvokeBindingRequest{Name: "standard-binding", Operation: "exec", Metadata: metadata} | ||||||
|  | 		req.Metadata["sql"] = "INSERT INTO dapr_test_table (id, c1, ts) VALUES (1, 'demo', '2020-09-24T11:45:05Z07:00');" | ||||||
|  | 		errBinding := client.InvokeOutputBinding(ctx, req) | ||||||
|  | 		require.NoError(ctx, errBinding, "error in output binding - exec") | ||||||
|  | 
 | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	testQuery := func(ctx flow.Context) error { | ||||||
|  | 		client, err := daprClient.NewClientWithPort(fmt.Sprintf("%d", grpcPort)) | ||||||
|  | 		require.NoError(t, err, "Could not initialize dapr client.") | ||||||
|  | 
 | ||||||
|  | 		metadata := make(map[string]string) | ||||||
|  | 
 | ||||||
|  | 		ctx.Log("Invoking output binding for query operation!") | ||||||
|  | 		req := &daprClient.InvokeBindingRequest{Name: "standard-binding", Operation: "query", Metadata: metadata} | ||||||
|  | 		req.Metadata["sql"] = "SELECT * FROM dapr_test_table WHERE id = 1;" | ||||||
|  | 		errBinding := client.InvokeOutputBinding(ctx, req) | ||||||
|  | 		require.NoError(ctx, errBinding, "error in output binding - query") | ||||||
|  | 
 | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	createTable := func(ctx flow.Context) error { | ||||||
|  | 		db, err := sql.Open("postgres", dockerConnectionString) | ||||||
|  | 		assert.NoError(t, err) | ||||||
|  | 		_, err = db.Exec("CREATE TABLE dapr_test_table(id INT, c1 TEXT, ts TEXT);") | ||||||
|  | 		assert.NoError(t, err) | ||||||
|  | 		db.Close() | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	flow.New(t, "Run tests"). | ||||||
|  | 		Step(dockercompose.Run("db", dockerComposeYAML)). | ||||||
|  | 		Step("wait for component to start", flow.Sleep(10*time.Second)). | ||||||
|  | 		Step("Creating table", createTable). | ||||||
|  | 		Step("wait for component to start", flow.Sleep(10*time.Second)). | ||||||
|  | 		Step(sidecar.Run("standardSidecar", | ||||||
|  | 			embedded.WithoutApp(), | ||||||
|  | 			embedded.WithDaprGRPCPort(grpcPort), | ||||||
|  | 			embedded.WithDaprHTTPPort(httpPort), | ||||||
|  | 			embedded.WithComponentsPath("./components/standard"), | ||||||
|  | 			componentRuntimeOptions(), | ||||||
|  | 		)). | ||||||
|  | 		Step("Run exec test", testExec). | ||||||
|  | 		Step("Run query test", testQuery). | ||||||
|  | 		Step("wait for DB operations to complete", flow.Sleep(10*time.Second)). | ||||||
|  | 		Step("interrupt network", network.InterruptNetwork(30*time.Second, nil, nil, "5432")). | ||||||
|  | 		Step("wait for component to recover", flow.Sleep(10*time.Second)). | ||||||
|  | 		Step("Run query test", testQuery). | ||||||
|  | 		Run() | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func componentRuntimeOptions() []runtime.Option { | ||||||
|  | 	log := logger.NewLogger("dapr.components") | ||||||
|  | 
 | ||||||
|  | 	bindingsRegistry := bindings_loader.NewRegistry() | ||||||
|  | 	bindingsRegistry.Logger = log | ||||||
|  | 	bindingsRegistry.RegisterOutputBinding(func(l logger.Logger) bindings.OutputBinding { | ||||||
|  | 		return binding_postgres.NewPostgres(l) | ||||||
|  | 	}, "postgres") | ||||||
|  | 
 | ||||||
|  | 	return []runtime.Option{ | ||||||
|  | 		runtime.WithBindings(bindingsRegistry), | ||||||
|  | 	} | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue