fix message size in a message in gentestdata

and work around the message in test-upgrade.sh.
and add subcommand to open an account, triggering data upgrades.
This commit is contained in:
Mechiel Lukkien 2023-08-16 14:36:17 +02:00
parent ddf3cb3653
commit 1ccc5d0177
No known key found for this signature in database
6 changed files with 64 additions and 12 deletions

2
doc.go
View file

@ -413,6 +413,8 @@ possibly making them potentially no longer readable by the previous version.
usage: mox verifydata data-dir usage: mox verifydata data-dir
-fix -fix
fix fixable problems, such as moving away message files not referenced by their database fix fixable problems, such as moving away message files not referenced by their database
-skip-size-check
skip the check for message size
# mox config test # mox config test

View file

@ -356,7 +356,7 @@ Accounts:
MailboxDestinedID: sent.ID, MailboxDestinedID: sent.ID,
Flags: store.Flags{Seen: true, Junk: true}, Flags: store.Flags{Seen: true, Junk: true},
Size: int64(len(prefix1) + len(msg1)), Size: int64(len(prefix1) + len(msg1)),
MsgPrefix: []byte(prefix), MsgPrefix: []byte(prefix1),
} }
mf1 := tempfile() mf1 := tempfile()
xcheckf(err, "creating temp file for delivery") xcheckf(err, "creating temp file for delivery")

25
main.go
View file

@ -158,6 +158,7 @@ var commands = []struct {
{"gentestdata", cmdGentestdata}, {"gentestdata", cmdGentestdata},
{"ximport maildir", cmdXImportMaildir}, {"ximport maildir", cmdXImportMaildir},
{"ximport mbox", cmdXImportMbox}, {"ximport mbox", cmdXImportMbox},
{"openaccounts", cmdOpenaccounts},
} }
var cmds []cmd var cmds []cmd
@ -2378,3 +2379,27 @@ func cmdMessageParse(c *cmd) {
err = enc.Encode(part) err = enc.Encode(part)
xcheckf(err, "write") xcheckf(err, "write")
} }
func cmdOpenaccounts(c *cmd) {
c.unlisted = true
c.params = "datadir account ..."
c.help = `Open and close accounts, for triggering data upgrades, for tests.
Opens database files directly, not going through a running mox instance.
`
args := c.Parse()
if len(args) <= 1 {
c.Usage()
}
dataDir := filepath.Clean(args[0])
for _, accName := range args[1:] {
accDir := filepath.Join(dataDir, "accounts", accName)
log.Printf("opening account %s...", filepath.Join(accDir, accName))
a, err := store.OpenAccountDB(accDir, accName)
xcheckf(err, "open account %s", accName)
err = a.Close()
xcheckf(err, "close account %s", accName)
}
}

View file

@ -677,7 +677,6 @@ func OpenAccount(name string) (*Account, error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
acc.nused++
openAccounts.names[name] = acc openAccounts.names[name] = acc
return acc, nil return acc, nil
} }
@ -685,13 +684,20 @@ func OpenAccount(name string) (*Account, error) {
// openAccount opens an existing account, or creates it if it is missing. // openAccount opens an existing account, or creates it if it is missing.
func openAccount(name string) (a *Account, rerr error) { func openAccount(name string) (a *Account, rerr error) {
dir := filepath.Join(mox.DataDirPath("accounts"), name) dir := filepath.Join(mox.DataDirPath("accounts"), name)
dbpath := filepath.Join(dir, "index.db") return OpenAccountDB(dir, name)
}
// OpenAccountDB opens an account database file and returns an initialized account
// or error. Only exported for use by subcommands that verify the database file.
// Almost all account opens must go through OpenAccount/OpenEmail/OpenEmailAuth.
func OpenAccountDB(accountDir, accountName string) (a *Account, rerr error) {
dbpath := filepath.Join(accountDir, "index.db")
// Create account if it doesn't exist yet. // Create account if it doesn't exist yet.
isNew := false isNew := false
if _, err := os.Stat(dbpath); err != nil && os.IsNotExist(err) { if _, err := os.Stat(dbpath); err != nil && os.IsNotExist(err) {
isNew = true isNew = true
os.MkdirAll(dir, 0770) os.MkdirAll(accountDir, 0770)
} }
db, err := bstore.Open(context.TODO(), dbpath, &bstore.Options{Timeout: 5 * time.Second, Perm: 0660}, DBTypes...) db, err := bstore.Open(context.TODO(), dbpath, &bstore.Options{Timeout: 5 * time.Second, Perm: 0660}, DBTypes...)
@ -719,7 +725,7 @@ func openAccount(name string) (a *Account, rerr error) {
return bstore.QueryTx[Mailbox](tx).FilterEqual("HaveCounts", false).ForEach(func(mb Mailbox) error { return bstore.QueryTx[Mailbox](tx).FilterEqual("HaveCounts", false).ForEach(func(mb Mailbox) error {
if !mentioned { if !mentioned {
mentioned = true mentioned = true
xlog.Info("first calculation of mailbox counts for account", mlog.Field("account", name)) xlog.Info("first calculation of mailbox counts for account", mlog.Field("account", accountName))
} }
mc, err := mb.CalculateCounts(tx) mc, err := mb.CalculateCounts(tx)
if err != nil { if err != nil {
@ -736,10 +742,11 @@ func openAccount(name string) (a *Account, rerr error) {
} }
return &Account{ return &Account{
Name: name, Name: accountName,
Dir: dir, Dir: accountDir,
DBPath: dbpath, DBPath: dbpath,
DB: db, DB: db,
nused: 1,
}, nil }, nil
} }

View file

@ -22,6 +22,7 @@ cd testdata/upgrade
# Check that we can upgrade what we currently generate. # Check that we can upgrade what we currently generate.
../../mox gentestdata data ../../mox gentestdata data
../../mox verifydata data ../../mox verifydata data
../../mox openaccounts data test0 test1 test2
rm -r data rm -r data
echo echo
@ -38,8 +39,13 @@ for tag in $tagsrev; do
(CGO_ENABLED=0 GOBIN=$PWD/$tag go install github.com/mjl-/mox@$tag) (CGO_ENABLED=0 GOBIN=$PWD/$tag go install github.com/mjl-/mox@$tag)
# Generate with historic release. # Generate with historic release.
./$tag/mox gentestdata $tag/data ./$tag/mox gentestdata $tag/data
# Verify with current code. # Verify with current code. v0.0.[45] had a message with wrong Size. We don't
../../mox verifydata $tag/data # want to abort the upgrade check because of it.
if test $tag = v0.0.4 -o $tag = v0.0.5; then
../../mox verifydata -skip-size-check $tag/data
else
../../mox verifydata $tag/data
fi
echo echo
rm -r $tag/data rm -r $tag/data
done done
@ -65,12 +71,18 @@ for tag in $tags; do
fi fi
echo "Upgrade data to $tag." echo "Upgrade data to $tag."
time ./$tag/mox verifydata stepdata if test $tag = v0.0.4 -o $tag = v0.0.5; then
time ./$tag/mox verifydata stepdata
else
time ./$tag/mox verifydata -skip-size-check stepdata
time ./$tag/mox openaccounts stepdata test0 test1 test2
fi
echo echo
fi fi
done done
echo "Testing final upgrade to current." echo "Testing final upgrade to current."
time ../../mox verifydata stepdata time ../../mox verifydata -skip-size-check stepdata
time ../../mox openaccounts stepdata test0 test1 test2
rm -r stepdata rm -r stepdata
rm */mox rm */mox
cd ../.. cd ../..

View file

@ -46,6 +46,12 @@ possibly making them potentially no longer readable by the previous version.
` `
var fix bool var fix bool
c.flag.BoolVar(&fix, "fix", false, "fix fixable problems, such as moving away message files not referenced by their database") c.flag.BoolVar(&fix, "fix", false, "fix fixable problems, such as moving away message files not referenced by their database")
// To prevent aborting the upgrade test with v0.0.[45] that had a message with
// incorrect Size.
var skipSizeCheck bool
c.flag.BoolVar(&skipSizeCheck, "skip-size-check", false, "skip the check for message size")
args := c.Parse() args := c.Parse()
if len(args) != 1 { if len(args) != 1 {
c.Usage() c.Usage()
@ -140,7 +146,7 @@ possibly making them potentially no longer readable by the previous version.
checkFile := func(dbpath, path string, prefixSize int, size int64) { checkFile := func(dbpath, path string, prefixSize int, size int64) {
st, err := os.Stat(path) st, err := os.Stat(path)
checkf(err, path, "checking if file exists") checkf(err, path, "checking if file exists")
if err == nil && int64(prefixSize)+st.Size() != size { if !skipSizeCheck && err == nil && int64(prefixSize)+st.Size() != size {
filesize := st.Size() filesize := st.Size()
checkf(fmt.Errorf("%s: message size is %d, should be %d (length of MsgPrefix %d + file size %d), see \"mox fixmsgsize\"", path, size, int64(prefixSize)+st.Size(), prefixSize, filesize), dbpath, "checking message size") checkf(fmt.Errorf("%s: message size is %d, should be %d (length of MsgPrefix %d + file size %d), see \"mox fixmsgsize\"", path, size, int64(prefixSize)+st.Size(), prefixSize, filesize), dbpath, "checking message size")
} }