Skip to content

Commit

Permalink
fix: handle duplicate create index race condition error
Browse files Browse the repository at this point in the history
  • Loading branch information
batrov committed Dec 12, 2023
1 parent f07825f commit 63418da
Showing 1 changed file with 14 additions and 3 deletions.
17 changes: 14 additions & 3 deletions internal/store/elasticsearch/discovery_repository.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ func NewDiscoveryRepository(cli *Client, logger log.Logger, requestTimeout time.
}
}

func (repo *DiscoveryRepository) createIndex(ctx context.Context, discoveryOp, indexName, alias string) error {
func (repo *DiscoveryRepository) createIndexIfNotExists(ctx context.Context, discoveryOp, indexName, alias string) error {
idxExists, err := repo.cli.indexExists(ctx, discoveryOp, indexName)
if err != nil {
return asset.DiscoveryError{
Expand All @@ -45,6 +45,12 @@ func (repo *DiscoveryRepository) createIndex(ctx context.Context, discoveryOp, i

if !idxExists {
if err := repo.cli.CreateIdx(ctx, discoveryOp, indexName, alias); err != nil {
if esErr, ok := err.(asset.DiscoveryError); ok {

Check failure on line 48 in internal/store/elasticsearch/discovery_repository.go

View workflow job for this annotation

GitHub Actions / golangci

type assertion on error will fail on wrapped errors. Use errors.As to check for specific errors (errorlint)
if esErr.ESCode == "resource_already_exists_exception" {
return nil
}
}

return asset.DiscoveryError{
Op: "CreateIndex",
Index: indexName,
Expand All @@ -64,7 +70,7 @@ func (repo *DiscoveryRepository) Upsert(ctx context.Context, ast asset.Asset) er
return asset.ErrUnknownType
}

if err := repo.createIndex(ctx, "Upsert", ast.Service, defaultSearchIndex); err != nil {
if err := repo.createIndexIfNotExists(ctx, "Upsert", ast.Service, defaultSearchIndex); err != nil {
return err
}

Expand Down Expand Up @@ -94,7 +100,12 @@ func (repo *DiscoveryRepository) SyncAssets(ctx context.Context, indexName strin
return nil, err
}

err = repo.createIndex(ctx, "SyncAssets", indexName, "")
err = repo.createIndexIfNotExists(ctx, "SyncAssets", indexName, "")
if err != nil {
return nil, err
}

err = repo.createIndexIfNotExists(ctx, "SyncAssets", indexName, "")
if err != nil {
return nil, err
}
Expand Down

0 comments on commit 63418da

Please sign in to comment.