From f7b1106f8ca7089a1e14156080298b8509cc47bb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Luk=C3=A1=C5=A1=20Zapletal?= Date: Wed, 11 Oct 2023 10:24:36 +0200 Subject: [PATCH] fix(HMS-2757): improve unexpected rows error MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Lukáš Zapletal --- internal/dao/pgx/pubkey_pgx.go | 6 +++--- internal/dao/pgx/reservation_pgx.go | 24 ++++++++++++------------ internal/dao/pgx/service_pgx.go | 2 +- internal/jobs/launch_instance_aws.go | 1 + 4 files changed, 17 insertions(+), 16 deletions(-) diff --git a/internal/dao/pgx/pubkey_pgx.go b/internal/dao/pgx/pubkey_pgx.go index 1aaf1b13..f105ce2b 100644 --- a/internal/dao/pgx/pubkey_pgx.go +++ b/internal/dao/pgx/pubkey_pgx.go @@ -88,7 +88,7 @@ func (x *pubkeyDao) Update(ctx context.Context, pubkey *models.Pubkey) error { return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } @@ -132,7 +132,7 @@ func (x *pubkeyDao) Delete(ctx context.Context, id int64) error { return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } @@ -191,7 +191,7 @@ func (x *pubkeyDao) UnscopedDeleteResource(ctx context.Context, id int64) error return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } diff --git a/internal/dao/pgx/reservation_pgx.go b/internal/dao/pgx/reservation_pgx.go index f0b69c82..497d7fc8 100644 --- a/internal/dao/pgx/reservation_pgx.go +++ b/internal/dao/pgx/reservation_pgx.go @@ -53,7 +53,7 @@ func (x *reservationDao) CreateAWS(ctx context.Context, reservation *models.AWSR return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil @@ -84,7 +84,7 @@ func (x *reservationDao) CreateAzure(ctx context.Context, reservation *models.Az return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil @@ -115,7 +115,7 @@ func (x *reservationDao) CreateGCP(ctx context.Context, reservation *models.GCPR return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil @@ -160,7 +160,7 @@ func (x *reservationDao) CreateInstance(ctx context.Context, instance *models.Re return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil @@ -179,7 +179,7 @@ func (x *reservationDao) UpdateReservationInstance(ctx context.Context, reservat return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil @@ -300,7 +300,7 @@ func (x *reservationDao) UpdateStatus(ctx context.Context, id int64, status stri return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } @@ -313,7 +313,7 @@ func (x *reservationDao) UnscopedUpdateAWSDetail(ctx context.Context, id int64, return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } @@ -326,7 +326,7 @@ func (x *reservationDao) UpdateReservationIDForAWS(ctx context.Context, id int64 return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } @@ -339,7 +339,7 @@ func (x *reservationDao) UpdateOperationNameForGCP(ctx context.Context, id int64 return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } @@ -352,7 +352,7 @@ func (x *reservationDao) FinishWithSuccess(ctx context.Context, id int64) error return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } @@ -365,7 +365,7 @@ func (x *reservationDao) FinishWithError(ctx context.Context, id int64, errorStr return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } @@ -378,7 +378,7 @@ func (x *reservationDao) Delete(ctx context.Context, id int64) error { return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } diff --git a/internal/dao/pgx/service_pgx.go b/internal/dao/pgx/service_pgx.go index 678ebd10..4f19477c 100644 --- a/internal/dao/pgx/service_pgx.go +++ b/internal/dao/pgx/service_pgx.go @@ -36,7 +36,7 @@ func UnscopedUpdatePubkey(ctx context.Context, pubkey *models.Pubkey) error { return fmt.Errorf("pgx error: %w", err) } if tag.RowsAffected() != 1 { - return fmt.Errorf("expected 1 row: %w", dao.ErrAffectedMismatch) + return fmt.Errorf("expected 1 row, got %d: %w", tag.RowsAffected(), dao.ErrAffectedMismatch) } return nil } diff --git a/internal/jobs/launch_instance_aws.go b/internal/jobs/launch_instance_aws.go index fbfffce3..d787e55e 100644 --- a/internal/jobs/launch_instance_aws.go +++ b/internal/jobs/launch_instance_aws.go @@ -181,6 +181,7 @@ func DoEnsurePubkeyOnAWS(ctx context.Context, args *LaunchInstanceAWSTaskArgs) e // update the AWS key name in reservation details awsReservation.Detail.PubkeyName = ec2Name + logger.Debug().Msgf("Updating AWS reservation detail %d", awsReservation.Reservation.ID) err = resDao.UnscopedUpdateAWSDetail(ctx, awsReservation.Reservation.ID, awsReservation.Detail) if err != nil { span.SetStatus(codes.Error, "failed to save AWS pubkey name to DB")