mirror of
https://github.com/zitadel/zitadel.git
synced 2025-05-05 22:10:47 +00:00
fix(db): always use begin tx (#7142)
* fix(db): always use begin tx * fix(handler): timeout for begin
This commit is contained in:
parent
c0cef4983a
commit
b7d027e2fd
@ -1,6 +1,7 @@
|
|||||||
package initialise
|
package initialise
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"embed"
|
"embed"
|
||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
@ -48,7 +49,7 @@ The user provided by flags needs privileges to
|
|||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
config := MustNewConfig(viper.GetViper())
|
config := MustNewConfig(viper.GetViper())
|
||||||
|
|
||||||
InitAll(config)
|
InitAll(cmd.Context(), config)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,7 +57,7 @@ The user provided by flags needs privileges to
|
|||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
func InitAll(config *Config) {
|
func InitAll(ctx context.Context, config *Config) {
|
||||||
err := initialise(config.Database,
|
err := initialise(config.Database,
|
||||||
VerifyUser(config.Database.Username(), config.Database.Password()),
|
VerifyUser(config.Database.Username(), config.Database.Password()),
|
||||||
VerifyDatabase(config.Database.DatabaseName()),
|
VerifyDatabase(config.Database.DatabaseName()),
|
||||||
@ -64,7 +65,7 @@ func InitAll(config *Config) {
|
|||||||
)
|
)
|
||||||
logging.OnError(err).Fatal("unable to initialize the database")
|
logging.OnError(err).Fatal("unable to initialize the database")
|
||||||
|
|
||||||
err = verifyZitadel(config.Database)
|
err = verifyZitadel(ctx, config.Database)
|
||||||
logging.OnError(err).Fatal("unable to initialize ZITADEL")
|
logging.OnError(err).Fatal("unable to initialize ZITADEL")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package initialise
|
package initialise
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
_ "embed"
|
_ "embed"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
@ -23,13 +24,13 @@ Prereqesits:
|
|||||||
`,
|
`,
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
config := MustNewConfig(viper.GetViper())
|
config := MustNewConfig(viper.GetViper())
|
||||||
err := verifyZitadel(config.Database)
|
err := verifyZitadel(cmd.Context(), config.Database)
|
||||||
logging.OnError(err).Fatal("unable to init zitadel")
|
logging.OnError(err).Fatal("unable to init zitadel")
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func VerifyZitadel(db *database.DB, config database.Config) error {
|
func VerifyZitadel(ctx context.Context, db *database.DB, config database.Config) error {
|
||||||
err := ReadStmts(config.Type())
|
err := ReadStmts(config.Type())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -41,7 +42,7 @@ func VerifyZitadel(db *database.DB, config database.Config) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
logging.WithFields().Info("verify encryption keys")
|
logging.WithFields().Info("verify encryption keys")
|
||||||
if err := createEncryptionKeys(db); err != nil {
|
if err := createEncryptionKeys(ctx, db); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,7 +57,7 @@ func VerifyZitadel(db *database.DB, config database.Config) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
logging.WithFields().Info("verify events tables")
|
logging.WithFields().Info("verify events tables")
|
||||||
if err := createEvents(db); err != nil {
|
if err := createEvents(ctx, db); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -73,7 +74,7 @@ func VerifyZitadel(db *database.DB, config database.Config) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func verifyZitadel(config database.Config) error {
|
func verifyZitadel(ctx context.Context, config database.Config) error {
|
||||||
logging.WithFields("database", config.DatabaseName()).Info("verify zitadel")
|
logging.WithFields("database", config.DatabaseName()).Info("verify zitadel")
|
||||||
|
|
||||||
db, err := database.Connect(config, false, dialect.DBPurposeQuery)
|
db, err := database.Connect(config, false, dialect.DBPurposeQuery)
|
||||||
@ -81,15 +82,15 @@ func verifyZitadel(config database.Config) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := VerifyZitadel(db, config); err != nil {
|
if err := VerifyZitadel(ctx, db, config); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return db.Close()
|
return db.Close()
|
||||||
}
|
}
|
||||||
|
|
||||||
func createEncryptionKeys(db *database.DB) error {
|
func createEncryptionKeys(ctx context.Context, db *database.DB) error {
|
||||||
tx, err := db.Begin()
|
tx, err := db.BeginTx(ctx, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -101,8 +102,8 @@ func createEncryptionKeys(db *database.DB) error {
|
|||||||
return tx.Commit()
|
return tx.Commit()
|
||||||
}
|
}
|
||||||
|
|
||||||
func createEvents(db *database.DB) (err error) {
|
func createEvents(ctx context.Context, db *database.DB) (err error) {
|
||||||
tx, err := db.Begin()
|
tx, err := db.BeginTx(ctx, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package initialise
|
package initialise
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"database/sql/driver"
|
"database/sql/driver"
|
||||||
"errors"
|
"errors"
|
||||||
@ -107,7 +108,7 @@ func Test_verifyEvents(t *testing.T) {
|
|||||||
|
|
||||||
for _, tt := range tests {
|
for _, tt := range tests {
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
if err := createEvents(tt.args.db.db); !errors.Is(err, tt.targetErr) {
|
if err := createEvents(context.Background(), tt.args.db.db); !errors.Is(err, tt.targetErr) {
|
||||||
t.Errorf("createEvents() error = %v, want: %v", err, tt.targetErr)
|
t.Errorf("createEvents() error = %v, want: %v", err, tt.targetErr)
|
||||||
}
|
}
|
||||||
if err := tt.args.db.mock.ExpectationsWereMet(); err != nil {
|
if err := tt.args.db.mock.ExpectationsWereMet(); err != nil {
|
||||||
@ -160,7 +161,7 @@ func Test_verifyEncryptionKeys(t *testing.T) {
|
|||||||
}
|
}
|
||||||
for _, tt := range tests {
|
for _, tt := range tests {
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
if err := createEncryptionKeys(tt.args.db.db); !errors.Is(err, tt.targetErr) {
|
if err := createEncryptionKeys(context.Background(), tt.args.db.db); !errors.Is(err, tt.targetErr) {
|
||||||
t.Errorf("createEvents() error = %v, want: %v", err, tt.targetErr)
|
t.Errorf("createEvents() error = %v, want: %v", err, tt.targetErr)
|
||||||
}
|
}
|
||||||
if err := tt.args.db.mock.ExpectationsWereMet(); err != nil {
|
if err := tt.args.db.mock.ExpectationsWereMet(); err != nil {
|
||||||
|
@ -74,7 +74,7 @@ new -f keys.yaml key2=anotherkey`,
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return storage.CreateKeys(keys...)
|
return storage.CreateKeys(cmd.Context(), keys...)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
cmd.PersistentFlags().StringP(flagKeyFile, "f", "", "path to keys file")
|
cmd.PersistentFlags().StringP(flagKeyFile, "f", "", "path to keys file")
|
||||||
|
@ -46,7 +46,7 @@ func (mig *FirstInstance) Execute(ctx context.Context) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("cannot start key storage: %w", err)
|
return fmt.Errorf("cannot start key storage: %w", err)
|
||||||
}
|
}
|
||||||
if err = verifyKey(mig.userEncryptionKey, keyStorage); err != nil {
|
if err = verifyKey(ctx, mig.userEncryptionKey, keyStorage); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
userAlg, err := crypto.NewAESCrypto(mig.userEncryptionKey, keyStorage)
|
userAlg, err := crypto.NewAESCrypto(mig.userEncryptionKey, keyStorage)
|
||||||
@ -54,7 +54,7 @@ func (mig *FirstInstance) Execute(ctx context.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err = verifyKey(mig.smtpEncryptionKey, keyStorage); err != nil {
|
if err = verifyKey(ctx, mig.smtpEncryptionKey, keyStorage); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
smtpEncryption, err := crypto.NewAESCrypto(mig.smtpEncryptionKey, keyStorage)
|
smtpEncryption, err := crypto.NewAESCrypto(mig.smtpEncryptionKey, keyStorage)
|
||||||
@ -62,7 +62,7 @@ func (mig *FirstInstance) Execute(ctx context.Context) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err = verifyKey(mig.oidcEncryptionKey, keyStorage); err != nil {
|
if err = verifyKey(ctx, mig.oidcEncryptionKey, keyStorage); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
oidcEncryption, err := crypto.NewAESCrypto(mig.oidcEncryptionKey, keyStorage)
|
oidcEncryption, err := crypto.NewAESCrypto(mig.oidcEncryptionKey, keyStorage)
|
||||||
@ -167,7 +167,7 @@ func (mig *FirstInstance) String() string {
|
|||||||
return "03_default_instance"
|
return "03_default_instance"
|
||||||
}
|
}
|
||||||
|
|
||||||
func verifyKey(key *crypto.KeyConfig, storage crypto.KeyStorage) (err error) {
|
func verifyKey(ctx context.Context, key *crypto.KeyConfig, storage crypto.KeyStorage) (err error) {
|
||||||
_, err = crypto.LoadKey(key.EncryptionKeyID, storage)
|
_, err = crypto.LoadKey(key.EncryptionKeyID, storage)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
return nil
|
return nil
|
||||||
@ -176,5 +176,5 @@ func verifyKey(key *crypto.KeyConfig, storage crypto.KeyStorage) (err error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return storage.CreateKeys(k)
|
return storage.CreateKeys(ctx, k)
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
package start
|
package start
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
"github.com/zitadel/zitadel/internal/crypto"
|
"github.com/zitadel/zitadel/internal/crypto"
|
||||||
"github.com/zitadel/zitadel/internal/zerrors"
|
"github.com/zitadel/zitadel/internal/zerrors"
|
||||||
)
|
)
|
||||||
@ -34,8 +36,8 @@ type encryptionKeys struct {
|
|||||||
OIDCKey []byte
|
OIDCKey []byte
|
||||||
}
|
}
|
||||||
|
|
||||||
func ensureEncryptionKeys(keyConfig *encryptionKeyConfig, keyStorage crypto.KeyStorage) (keys *encryptionKeys, err error) {
|
func ensureEncryptionKeys(ctx context.Context, keyConfig *encryptionKeyConfig, keyStorage crypto.KeyStorage) (keys *encryptionKeys, err error) {
|
||||||
if err := verifyDefaultKeys(keyStorage); err != nil {
|
if err := verifyDefaultKeys(ctx, keyStorage); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
keys = new(encryptionKeys)
|
keys = new(encryptionKeys)
|
||||||
@ -89,7 +91,7 @@ func ensureEncryptionKeys(keyConfig *encryptionKeyConfig, keyStorage crypto.KeyS
|
|||||||
return keys, nil
|
return keys, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func verifyDefaultKeys(keyStorage crypto.KeyStorage) (err error) {
|
func verifyDefaultKeys(ctx context.Context, keyStorage crypto.KeyStorage) (err error) {
|
||||||
keys := make([]*crypto.Key, 0, len(defaultKeyIDs))
|
keys := make([]*crypto.Key, 0, len(defaultKeyIDs))
|
||||||
for _, keyID := range defaultKeyIDs {
|
for _, keyID := range defaultKeyIDs {
|
||||||
_, err := crypto.LoadKey(keyID, keyStorage)
|
_, err := crypto.LoadKey(keyID, keyStorage)
|
||||||
@ -105,7 +107,7 @@ func verifyDefaultKeys(keyStorage crypto.KeyStorage) (err error) {
|
|||||||
if len(keys) == 0 {
|
if len(keys) == 0 {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if err := keyStorage.CreateKeys(keys...); err != nil {
|
if err := keyStorage.CreateKeys(ctx, keys...); err != nil {
|
||||||
return zerrors.ThrowInternal(err, "START-aGBq2", "cannot create default keys")
|
return zerrors.ThrowInternal(err, "START-aGBq2", "cannot create default keys")
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -95,7 +95,7 @@ Requirements:
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return startZitadel(config, masterKey, server)
|
return startZitadel(cmd.Context(), config, masterKey, server)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -119,11 +119,9 @@ type Server struct {
|
|||||||
Shutdown chan<- os.Signal
|
Shutdown chan<- os.Signal
|
||||||
}
|
}
|
||||||
|
|
||||||
func startZitadel(config *Config, masterKey string, server chan<- *Server) error {
|
func startZitadel(ctx context.Context, config *Config, masterKey string, server chan<- *Server) error {
|
||||||
showBasicInformation(config)
|
showBasicInformation(config)
|
||||||
|
|
||||||
ctx := context.Background()
|
|
||||||
|
|
||||||
i18n.MustLoadSupportedLanguagesFromDir()
|
i18n.MustLoadSupportedLanguagesFromDir()
|
||||||
|
|
||||||
queryDBClient, err := database.Connect(config.Database, false, dialect.DBPurposeQuery)
|
queryDBClient, err := database.Connect(config.Database, false, dialect.DBPurposeQuery)
|
||||||
@ -143,7 +141,7 @@ func startZitadel(config *Config, masterKey string, server chan<- *Server) error
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("cannot start key storage: %w", err)
|
return fmt.Errorf("cannot start key storage: %w", err)
|
||||||
}
|
}
|
||||||
keys, err := ensureEncryptionKeys(config.EncryptionKeys, keyStorage)
|
keys, err := ensureEncryptionKeys(ctx, config.EncryptionKeys, keyStorage)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -29,7 +29,7 @@ Requirements:
|
|||||||
masterKey, err := key.MasterKey(cmd)
|
masterKey, err := key.MasterKey(cmd)
|
||||||
logging.OnError(err).Panic("No master key provided")
|
logging.OnError(err).Panic("No master key provided")
|
||||||
|
|
||||||
initialise.InitAll(initialise.MustNewConfig(viper.GetViper()))
|
initialise.InitAll(cmd.Context(), initialise.MustNewConfig(viper.GetViper()))
|
||||||
|
|
||||||
setupConfig := setup.MustNewConfig(viper.GetViper())
|
setupConfig := setup.MustNewConfig(viper.GetViper())
|
||||||
setupSteps := setup.MustNewSteps(viper.New())
|
setupSteps := setup.MustNewSteps(viper.New())
|
||||||
@ -37,7 +37,7 @@ Requirements:
|
|||||||
|
|
||||||
startConfig := MustNewConfig(viper.GetViper())
|
startConfig := MustNewConfig(viper.GetViper())
|
||||||
|
|
||||||
err = startZitadel(startConfig, masterKey, server)
|
err = startZitadel(cmd.Context(), startConfig, masterKey, server)
|
||||||
logging.OnError(err).Fatal("unable to start zitadel")
|
logging.OnError(err).Fatal("unable to start zitadel")
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,7 @@ Requirements:
|
|||||||
|
|
||||||
startConfig := MustNewConfig(viper.GetViper())
|
startConfig := MustNewConfig(viper.GetViper())
|
||||||
|
|
||||||
err = startZitadel(startConfig, masterKey, server)
|
err = startZitadel(cmd.Context(), startConfig, masterKey, server)
|
||||||
logging.OnError(err).Fatal("unable to start zitadel")
|
logging.OnError(err).Fatal("unable to start zitadel")
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -1,17 +1,13 @@
|
|||||||
package view
|
package view
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
|
||||||
|
|
||||||
"github.com/jinzhu/gorm"
|
"github.com/jinzhu/gorm"
|
||||||
|
|
||||||
"github.com/zitadel/zitadel/internal/api/call"
|
|
||||||
"github.com/zitadel/zitadel/internal/database"
|
"github.com/zitadel/zitadel/internal/database"
|
||||||
)
|
)
|
||||||
|
|
||||||
type View struct {
|
type View struct {
|
||||||
Db *gorm.DB
|
Db *gorm.DB
|
||||||
client *database.DB
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func StartView(sqlClient *database.DB) (*View, error) {
|
func StartView(sqlClient *database.DB) (*View, error) {
|
||||||
@ -20,15 +16,10 @@ func StartView(sqlClient *database.DB) (*View, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return &View{
|
return &View{
|
||||||
Db: gorm,
|
Db: gorm,
|
||||||
client: sqlClient,
|
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *View) Health() (err error) {
|
func (v *View) Health() (err error) {
|
||||||
return v.Db.DB().Ping()
|
return v.Db.DB().Ping()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *View) TimeTravel(ctx context.Context, tableName string) string {
|
|
||||||
return tableName + v.client.Timetravel(call.Took(ctx))
|
|
||||||
}
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package database
|
package database
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
|
|
||||||
sq "github.com/Masterminds/squirrel"
|
sq "github.com/Masterminds/squirrel"
|
||||||
@ -98,7 +99,7 @@ func (d *database) ReadKey(id string) (_ *crypto.Key, err error) {
|
|||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *database) CreateKeys(keys ...*crypto.Key) error {
|
func (d *database) CreateKeys(ctx context.Context, keys ...*crypto.Key) error {
|
||||||
insert := sq.Insert(EncryptionKeysTable).
|
insert := sq.Insert(EncryptionKeysTable).
|
||||||
Columns(encryptionKeysIDCol, encryptionKeysKeyCol).PlaceholderFormat(sq.Dollar)
|
Columns(encryptionKeysIDCol, encryptionKeysKeyCol).PlaceholderFormat(sq.Dollar)
|
||||||
for _, key := range keys {
|
for _, key := range keys {
|
||||||
@ -112,7 +113,7 @@ func (d *database) CreateKeys(keys ...*crypto.Key) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return zerrors.ThrowInternal(err, "", "unable to insert new keys")
|
return zerrors.ThrowInternal(err, "", "unable to insert new keys")
|
||||||
}
|
}
|
||||||
tx, err := d.client.Begin()
|
tx, err := d.client.BeginTx(ctx, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return zerrors.ThrowInternal(err, "", "unable to insert new keys")
|
return zerrors.ThrowInternal(err, "", "unable to insert new keys")
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package database
|
package database
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"database/sql/driver"
|
"database/sql/driver"
|
||||||
"errors"
|
"errors"
|
||||||
@ -395,7 +396,7 @@ func Test_database_CreateKeys(t *testing.T) {
|
|||||||
masterKey: tt.fields.masterKey,
|
masterKey: tt.fields.masterKey,
|
||||||
encrypt: tt.fields.encrypt,
|
encrypt: tt.fields.encrypt,
|
||||||
}
|
}
|
||||||
err := d.CreateKeys(tt.args.keys...)
|
err := d.CreateKeys(context.Background(), tt.args.keys...)
|
||||||
if tt.res.err == nil {
|
if tt.res.err == nil {
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
} else if tt.res.err != nil && !tt.res.err(err) {
|
} else if tt.res.err != nil && !tt.res.err(err) {
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
package crypto
|
package crypto
|
||||||
|
|
||||||
|
import "context"
|
||||||
|
|
||||||
type KeyStorage interface {
|
type KeyStorage interface {
|
||||||
ReadKeys() (Keys, error)
|
ReadKeys() (Keys, error)
|
||||||
ReadKey(id string) (*Key, error)
|
ReadKey(id string) (*Key, error)
|
||||||
CreateKeys(...*Key) error
|
CreateKeys(context.Context, ...*Key) error
|
||||||
}
|
}
|
||||||
|
@ -316,13 +316,17 @@ func (h *Handler) processEvents(ctx context.Context, config *triggerConfig) (add
|
|||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
txCtx := ctx
|
||||||
if h.txDuration > 0 {
|
if h.txDuration > 0 {
|
||||||
var cancel func()
|
var cancel func()
|
||||||
ctx, cancel = context.WithTimeout(ctx, h.txDuration)
|
ctx, cancel = context.WithTimeout(ctx, h.txDuration)
|
||||||
defer cancel()
|
defer cancel()
|
||||||
|
// add 100ms to store current state if iteration takes too long
|
||||||
|
txCtx, cancel = context.WithTimeout(ctx, h.txDuration+100*time.Millisecond)
|
||||||
|
defer cancel()
|
||||||
}
|
}
|
||||||
|
|
||||||
tx, err := h.client.Begin()
|
tx, err := h.client.BeginTx(txCtx, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return false, err
|
return false, err
|
||||||
}
|
}
|
||||||
|
@ -121,7 +121,7 @@ func TestHandler_lockState(t *testing.T) {
|
|||||||
projection: tt.fields.projection,
|
projection: tt.fields.projection,
|
||||||
}
|
}
|
||||||
|
|
||||||
tx, err := tt.fields.mock.DB.Begin()
|
tx, err := tt.fields.mock.DB.BeginTx(context.Background(), nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unable to begin transaction: %v", err)
|
t.Fatalf("unable to begin transaction: %v", err)
|
||||||
}
|
}
|
||||||
@ -244,7 +244,7 @@ func TestHandler_updateLastUpdated(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
tx, err := tt.fields.mock.DB.Begin()
|
tx, err := tt.fields.mock.DB.BeginTx(context.Background(), nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unable to begin transaction: %v", err)
|
t.Fatalf("unable to begin transaction: %v", err)
|
||||||
}
|
}
|
||||||
@ -433,7 +433,7 @@ func TestHandler_currentState(t *testing.T) {
|
|||||||
projection: tt.fields.projection,
|
projection: tt.fields.projection,
|
||||||
}
|
}
|
||||||
|
|
||||||
tx, err := tt.fields.mock.DB.Begin()
|
tx, err := tt.fields.mock.DB.BeginTx(context.Background(), nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unable to begin transaction: %v", err)
|
t.Fatalf("unable to begin transaction: %v", err)
|
||||||
}
|
}
|
||||||
|
@ -88,7 +88,7 @@ func initDB(db *database.DB) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
err = initialise.VerifyZitadel(db, *config)
|
err = initialise.VerifyZitadel(context.Background(), db, *config)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package sql
|
package sql
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"os"
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
@ -60,7 +61,7 @@ func initDB(db *database.DB) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = initialise.VerifyZitadel(db, *config)
|
err = initialise.VerifyZitadel(context.Background(), db, *config)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func (es *Eventstore) Push(ctx context.Context, commands ...eventstore.Command) (events []eventstore.Event, err error) {
|
func (es *Eventstore) Push(ctx context.Context, commands ...eventstore.Command) (events []eventstore.Event, err error) {
|
||||||
tx, err := es.client.Begin()
|
tx, err := es.client.BeginTx(ctx, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -109,7 +109,7 @@ func (q *Queries) latestState(ctx context.Context, projections ...table) (state
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (q *Queries) ClearCurrentSequence(ctx context.Context, projectionName string) (err error) {
|
func (q *Queries) ClearCurrentSequence(ctx context.Context, projectionName string) (err error) {
|
||||||
tx, err := q.client.Begin()
|
tx, err := q.client.BeginTx(ctx, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return zerrors.ThrowInternal(err, "QUERY-9iOpr", "Errors.RemoveFailed")
|
return zerrors.ThrowInternal(err, "QUERY-9iOpr", "Errors.RemoveFailed")
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user