mirror of
https://github.com/caddyserver/caddy.git
synced 2024-11-29 20:24:11 +08:00
40 lines
1.2 KiB
Go
40 lines
1.2 KiB
Go
|
package storagetest
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"github.com/mholt/caddy/caddytls"
|
||
|
"os"
|
||
|
"path/filepath"
|
||
|
"testing"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
// TestFileStorage tests the file storage set with the test harness in this
|
||
|
// package.
|
||
|
func TestFileStorage(t *testing.T) {
|
||
|
emailCounter := 0
|
||
|
storageTest := &StorageTest{
|
||
|
Storage: caddytls.FileStorage("./testdata"),
|
||
|
PostTest: func() { os.RemoveAll("./testdata") },
|
||
|
AfterUserEmailStore: func(email string) error {
|
||
|
// We need to change the dir mod time to show a
|
||
|
// that certain dirs are newer.
|
||
|
emailCounter++
|
||
|
fp := filepath.Join("./testdata", "users", email)
|
||
|
|
||
|
// What we will do is subtract 10 days from today and
|
||
|
// then add counter * seconds to make the later
|
||
|
// counters newer. We accept that this isn't exactly
|
||
|
// how the file storage works because it only changes
|
||
|
// timestamps on *newly seen* users, but it achieves
|
||
|
// the result that the harness expects.
|
||
|
chTime := time.Now().AddDate(0, 0, -10).Add(time.Duration(emailCounter) * time.Second)
|
||
|
if err := os.Chtimes(fp, chTime, chTime); err != nil {
|
||
|
return fmt.Errorf("Unable to change file time for %v: %v", fp, err)
|
||
|
}
|
||
|
return nil
|
||
|
},
|
||
|
}
|
||
|
storageTest.Test(t, false)
|
||
|
}
|