Ensure that deleting a large set of keys will work correctly.
(t *testing.T)
| 328 | |
| 329 | // Ensure that deleting a large set of keys will work correctly. |
| 330 | func TestBucket_Delete_Large(t *testing.T) { |
| 331 | db := btesting.MustCreateDB(t) |
| 332 | |
| 333 | if err := db.Update(func(tx *bolt.Tx) error { |
| 334 | b, err := tx.CreateBucket([]byte("widgets")) |
| 335 | if err != nil { |
| 336 | t.Fatal(err) |
| 337 | } |
| 338 | |
| 339 | for i := 0; i < 100; i++ { |
| 340 | if err := b.Put([]byte(strconv.Itoa(i)), []byte(strings.Repeat("*", 1024))); err != nil { |
| 341 | t.Fatal(err) |
| 342 | } |
| 343 | } |
| 344 | |
| 345 | return nil |
| 346 | }); err != nil { |
| 347 | t.Fatal(err) |
| 348 | } |
| 349 | |
| 350 | if err := db.Update(func(tx *bolt.Tx) error { |
| 351 | b := tx.Bucket([]byte("widgets")) |
| 352 | for i := 0; i < 100; i++ { |
| 353 | if err := b.Delete([]byte(strconv.Itoa(i))); err != nil { |
| 354 | t.Fatal(err) |
| 355 | } |
| 356 | } |
| 357 | return nil |
| 358 | }); err != nil { |
| 359 | t.Fatal(err) |
| 360 | } |
| 361 | |
| 362 | if err := db.View(func(tx *bolt.Tx) error { |
| 363 | b := tx.Bucket([]byte("widgets")) |
| 364 | for i := 0; i < 100; i++ { |
| 365 | if v := b.Get([]byte(strconv.Itoa(i))); v != nil { |
| 366 | t.Fatalf("unexpected value: %v, i=%d", v, i) |
| 367 | } |
| 368 | } |
| 369 | return nil |
| 370 | }); err != nil { |
| 371 | t.Fatal(err) |
| 372 | } |
| 373 | } |
| 374 | |
| 375 | // Deleting a very large list of keys will cause the freelist to use overflow. |
| 376 | func TestBucket_Delete_FreelistOverflow(t *testing.T) { |
nothing calls this directly
no test coverage detected