Benjamin Wang
c19ea9b613
Handle the case of io.EOF when reading the second meta page
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-29 16:37:24 +08:00
Benjamin Wang
dab07c58b4
Update test cases TestOpen_ReadPageSize_FromMeta1_OS and TestOpen_ReadPageSize_FromMeta1_Given
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-29 09:10:57 +08:00
Benjamin Wang
7b6c235774
Merge pull request #294 from ahrtr/enhance_check_command
...
Get the page size from the second meta page if the first one is invalid
2022-12-29 06:46:34 +08:00
Piotr Tabor
a0def3434b
Merge pull request #360 from ptabor/20221220-btesting
...
Factor out (bolt)testing library.
2022-12-28 16:14:12 +01:00
Piotr Tabor
1f46d6c7e7
cmd/main_test.go is using btesting as well.
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-28 15:18:46 +01:00
Piotr Tabor
37d72cc1cd
Use require.NoError in btesting.go
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-28 15:18:46 +01:00
Piotr Tabor
93380c59e8
testing: group (reorder) imports.
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-28 15:18:46 +01:00
Piotr Tabor
26cc5e3e8b
Tests: Migrate from test DB to btesting.DB
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-28 15:18:46 +01:00
Piotr Tabor
f3e164d8dd
Example: How to use the separated 'btesting' library.
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-28 15:18:46 +01:00
Piotr Tabor
46cdbf5b6c
Factor out (bolt)testing library.
...
Thanks to putting it outside the bbolt_test package it can be used to test other packages.
The replacement of the bbolt_test variant inlined in db_test.go is to be performed in a follow up PR.
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-28 15:18:46 +01:00
Benjamin Wang
2385046d41
replace all ioutil with os
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-28 16:56:01 +08:00
ahrtr
8e6a1168ae
get the page size from the second meta page if the first one is invalid
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-28 16:52:47 +08:00
Benjamin Wang
9830ab2f14
Merge pull request #365 from ahrtr/bolt_cmd_readonly_20221227
...
Open db file in readonly mode for commands which shouldn't update db file
2022-12-28 15:51:29 +08:00
Benjamin Wang
5dbd2ec7f3
Merge pull request #366 from ahrtr/workflow_windows_20221227
...
Support running workflow on Windows-latest
2022-12-28 15:49:41 +08:00
Benjamin Wang
7cc5901171
Extended the test timeout to 30m
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-27 14:51:47 +08:00
Benjamin Wang
99fe21f5e0
Disabled linter on field 'dataref'
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-27 14:51:10 +08:00
Benjamin Wang
d04dc0c2d0
Support running workflow on Windows-latest
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-27 14:49:58 +08:00
Benjamin Wang
f8dc40c033
Removed the use of log and reorder the import items
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-27 13:05:12 +08:00
Benjamin Wang
329eba7818
Open db file in readonly mode for commands which shouldn't update db file
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-27 12:58:32 +08:00
Piotr Tabor
d4831e6217
Merge pull request #358 from ptabor/20221218-defensive-pageread
...
Validate page being fetched at possition 'p' self identifies as page 'p'
2022-12-23 11:07:33 +01:00
Piotr Tabor
86ce028a52
Defensive: Expect page that node writes onto to be zeroed.
...
I've seen data corruption that seen like a random bit-flip
or application on already allocated page.
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-23 09:43:03 +01:00
Piotr Tabor
3cbd9c9a44
Detect pages that have multiple flags set.
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-23 09:43:03 +01:00
Piotr Tabor
d1aa8034d4
Validate page being fetched at possition 'p' self identifies as page 'p'.
...
It's the easiest verification whether the page is actually written, or its 'random' garbage in the block.
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-23 09:37:41 +01:00
Piotr Tabor
109f510a5e
Merge pull request #359 from ptabor/20221219-bbolt-page-all
...
bbolt page supports --all and --value-format=redacted formats.
2022-12-22 10:05:21 +01:00
Piotr Tabor
577a4d99b9
bbolt page supports --all and --value-format=redacted formats.
...
--all - prints all pages (only skips pages that were considered successful overflow pages)
--value-format=redacted just prints a length of the value, to reduce length and protect privacy.
The auto & redacted formats are supported in all tools that accept '--format'.
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-22 09:56:16 +01:00
Piotr Tabor
4b8c53388b
Merge pull request #250 from x1ddos/sort-order-docs
...
bucket,cursor: clarify sort order and seek algorithm
2022-12-21 22:07:36 +01:00
Piotr Tabor
1231aef645
Merge pull request #241 from adream307/master
...
remove unreachable code
2022-12-21 22:05:57 +01:00
Piotr Tabor
a3749e4c36
Merge pull request #287 from dramirez-qb/patch-1
...
Update README.md fixed typo
2022-12-21 21:39:15 +01:00
Piotr Tabor
696c85ce3d
Merge pull request #356 from ptabor/20221215-flags
...
Add internal iterator to Bucket that goes over buckets.
2022-12-21 12:58:50 +01:00
Piotr Tabor
ebca452da7
Add internal iterator to Bucket that goes over buckets.
...
So far the code was frequently traversing all the keys (ignoring flag whether key is a bucket)
and trying to open each of the keys as bucket (seeking the same entry from the scratch).
In this proposal, we iterate only through bucket keys.
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-21 12:16:50 +01:00
Piotr Tabor
fa80ceeb19
Merge pull request #357 from ptabor/20221218-stack-to-error
...
Pages stacktrace printed for initialization errors.
2022-12-21 11:57:31 +01:00
Benjamin Wang
f0ccf4e887
Merge pull request #363 from ahrtr/seek_assert_20221221
...
only perform assert check on exported method
2022-12-21 18:38:20 +08:00
Benjamin Wang
ed0438722e
only perform assert on exported method
...
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2022-12-21 16:39:30 +08:00
Benjamin Wang
dd0ab6da68
Merge pull request #307 from fyrchik/fix-windows-readonly
...
Fix readonly file mapping on windows
2022-12-21 09:12:26 +08:00
Piotr Tabor
038b2b4d5a
Merge pull request #355 from ptabor/20221216-test-on-16KB-pages
...
Fix bbolt tests for 16KB block page (e.g. Mac with M1 CPU).
2022-12-20 13:59:00 +01:00
Piotr Tabor
cc771afa1e
Move page command to a separate file. It's already a huge file of tools.
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-19 00:42:54 +01:00
Piotr Tabor
bad964e850
Merge pull request #354 from ptabor/20221214-fix-bbolt-safety
...
Add safeguards to bbolt CLI tool
2022-12-18 13:17:08 +01:00
Piotr Tabor
7190a8fe57
Pages stacktrace should be provided for initialization errors.
...
It makes it easy to find which page actually looks to be corrupted.
```
go build ./cmd/bbolt/ && ./bbolt check ~/Downloads/db
panic: freepages: failed to get all reachable pages (page 8314893338927566090: out of bounds: 6258 (stack: [4517 395 821]))
goroutine 18 [running]:
go.etcd.io/bbolt.(*DB).freepages.func2()
/Users/ptab/gits/bbolt/db.go:1056 +0x8c
created by go.etcd.io/bbolt.(*DB).freepages
/Users/ptab/gits/bbolt/db.go:1054 +0x138
```
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-17 15:32:54 +01:00
Piotr Tabor
c34493c3d1
Safety check to 'bbolt page' command.
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-17 14:43:12 +01:00
Piotr Tabor
1d5a2b0e24
Merge pull request #306 from ptabor/20211220-bbolt_cmd_format
...
Add support for --format flag for 'keys'
2022-12-16 20:41:01 +01:00
Piotr Tabor
b09984ea16
Fix bbolt test for 16KB block page (e.g. Mac with M1 CPU).
...
The tests were failing when doing development on M1 mac. This was due to page-size difference (4KB assumed in tests) vs. the
OS defaults.
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-16 19:14:51 +01:00
Piotr Tabor
4acf9d93a5
Fixing golangci warnings.
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-16 16:08:56 +01:00
Piotr Tabor
505c3888a1
Merge pull request #328 from xpetit/patch-1
...
Comment fix.
2022-12-16 15:50:57 +01:00
Benjamin Wang
307b638af3
Merge pull request #350 from ahrtr/update_cache_20221124
...
change freelist.cache from map[pgid]bool to map[pgid]struct{}
2022-12-16 06:13:34 +08:00
Piotr Tabor
5495c633ad
bbolt get support --parseFormat and --format flags.
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-07 22:36:11 +01:00
Piotr Tabor
ed3e67c69b
writelnBytes method has cleaner contract
...
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-07 22:36:11 +01:00
Piotr Tabor
b9199f476d
Add support for --format flag for 'bbolt keys' command.
...
This allows to print keys as 'hex', especially useful in context of etcd revisions:
./bbolt keys --format=hex ./foo/db key
Signed-off-by: Piotr Tabor <ptab@google.com>
2022-12-07 22:36:11 +01:00
Xavier Petit
8fe68b8f4d
Fix comment
...
Signed-off-by: xpetit <32063953+xpetit@users.noreply.github.com>
2022-12-01 11:44:53 +01:00
Benjamin Wang
020684ea1e
Merge pull request #315 from missinglink/enable-main-test
...
cmd/bbolt: re-enable "bbolt" testing
2022-11-30 18:40:10 +08:00
missinglink
e7e1f0c05a
cmd/bbolt: re-enable "bbolt" testing
...
Signed-off-by: missinglink <insomnia@rcpt.at>
2022-11-30 11:20:27 +01:00