chunk_interval_list_test.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. package page_writer
  2. import (
  3. "github.com/stretchr/testify/assert"
  4. "testing"
  5. )
  6. func Test_PageChunkWrittenIntervalList(t *testing.T) {
  7. list := newChunkWrittenIntervalList()
  8. assert.Equal(t, 0, list.size(), "empty list")
  9. list.MarkWritten(0, 5)
  10. assert.Equal(t, 1, list.size(), "one interval")
  11. list.MarkWritten(0, 5)
  12. assert.Equal(t, 1, list.size(), "duplicated interval2")
  13. list.MarkWritten(95, 100)
  14. assert.Equal(t, 2, list.size(), "two intervals")
  15. list.MarkWritten(50, 60)
  16. assert.Equal(t, 3, list.size(), "three intervals")
  17. list.MarkWritten(50, 55)
  18. assert.Equal(t, 3, list.size(), "three intervals merge")
  19. list.MarkWritten(40, 50)
  20. assert.Equal(t, 3, list.size(), "three intervals grow forward")
  21. list.MarkWritten(50, 65)
  22. assert.Equal(t, 3, list.size(), "three intervals grow backward")
  23. list.MarkWritten(70, 80)
  24. assert.Equal(t, 4, list.size(), "four intervals")
  25. list.MarkWritten(60, 70)
  26. assert.Equal(t, 3, list.size(), "three intervals merged")
  27. list.MarkWritten(59, 71)
  28. assert.Equal(t, 3, list.size(), "covered three intervals")
  29. list.MarkWritten(5, 59)
  30. assert.Equal(t, 2, list.size(), "covered two intervals")
  31. list.MarkWritten(70, 99)
  32. assert.Equal(t, 1, list.size(), "covered one intervals")
  33. }