Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

firestore: bulkwriter loses documents #11418

Closed
alsofr opened this issue Jan 8, 2025 · 1 comment
Closed

firestore: bulkwriter loses documents #11418

alsofr opened this issue Jan 8, 2025 · 1 comment
Assignees
Labels
api: firestore Issues related to the Firestore API. type: bug Error or flaw in code with unintended results or allowing sub-optimal usage patterns.

Comments

@alsofr
Copy link

alsofr commented Jan 8, 2025

Client

firestore

Environment

go 1.23.4

Code and Dependencies

Here is a simplified example of the code generating the faulty behaviour.
Call the function with a larger slice of objects to persist (several thousands).

func (c *Client) BulkCreate(ctx context.Context, collID string, src any) error {
	if reflect.TypeOf(src).Kind() != reflect.Slice {
		return errors.New("bulk create: src must be a slice")
	}

	w := c.delegate.BulkWriter(ctx)
	defer w.End() // This will Flush all the remaining documents at the end

	docs := reflect.ValueOf(src)
	collRef := c.delegate.Collection(collID)

	for i := 0; i < docs.Len(); i++ {
		bwj, err := w.Create(collRef.NewDoc(), docs.Index(i).Interface())
		if err != nil {
			return fmt.Errorf("bulk create: %w", err)
		}
	}
	return nil
}
go.mod
go 1.23.4

require (
   cloud.google.com/go/firestore v1.17.0
)

Expected behavior

All documents passed to a BulkWriter are written to the database. If some documents fail, an error is thrown.

Actual behavior

When adding documents quickly to a bulkWriter, some documents are skipped silently. The bulk operation succeeds but there is no indication that any data is missing.

Possible explanation/work-around

After reading the source code, the following work-around was created to make sure that no documents are skipped.

		// The maxBatchSize for the bulkwriter is 20 after which the bulkwriter tries to write to the database
		// Wait for the write results before continuing. This prevents silent loss of data.
		if (i+1)%maxBatchSize == 0 {
			if _, err := bwj.Results(); err != nil {
				return fmt.Errorf("bulk create document: %w", err)
			}
		}

The faulty code seems to be the silencing of errors coming from the bundler.Add function:
image

It's possible that the bundler is throwing an ErrOverflow error when the document addition rate to the queue is faster than the Firestore persistence rate.
image

@alsofr alsofr added the triage me I really want to be triaged. label Jan 8, 2025
@product-auto-label product-auto-label bot added the api: firestore Issues related to the Firestore API. label Jan 8, 2025
@bhshkh bhshkh added type: bug Error or flaw in code with unintended results or allowing sub-optimal usage patterns. and removed triage me I really want to be triaged. labels Jan 21, 2025
@bhshkh
Copy link
Contributor

bhshkh commented Jan 21, 2025

Closing this one as duplicate of #11422
Please reopen if this is a different issue

@bhshkh bhshkh closed this as completed Jan 21, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
api: firestore Issues related to the Firestore API. type: bug Error or flaw in code with unintended results or allowing sub-optimal usage patterns.
Projects
None yet
Development

No branches or pull requests

2 participants