mirror of
https://github.com/jhillyerd/inbucket.git
synced 2025-12-17 09:37:02 +00:00
68 lines
1.7 KiB
Go
68 lines
1.7 KiB
Go
package storage
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestDoRetentionScan(t *testing.T) {
|
|
// Create mock objects
|
|
mds := &MockDataStore{}
|
|
|
|
mb1 := &MockMailbox{}
|
|
mb2 := &MockMailbox{}
|
|
mb3 := &MockMailbox{}
|
|
|
|
// Mockup some different aged messages (num is in hours)
|
|
new1 := mockMessage(0)
|
|
new2 := mockMessage(1)
|
|
new3 := mockMessage(2)
|
|
old1 := mockMessage(4)
|
|
old2 := mockMessage(12)
|
|
old3 := mockMessage(24)
|
|
|
|
// First it should ask for all mailboxes
|
|
mds.On("AllMailboxes").Return([]Mailbox{mb1, mb2, mb3}, nil)
|
|
|
|
// Then for all messages on each box
|
|
mb1.On("GetMessages").Return([]Message{new1, old1, old2}, nil)
|
|
mb2.On("GetMessages").Return([]Message{old3, new2}, nil)
|
|
mb3.On("GetMessages").Return([]Message{new3}, nil)
|
|
|
|
// Test 4 hour retention
|
|
rs := &RetentionScanner{
|
|
ds: mds,
|
|
retentionPeriod: 4*time.Hour - time.Minute,
|
|
retentionSleep: 0,
|
|
}
|
|
if err := rs.doScan(); err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
// Check our assertions
|
|
mds.AssertExpectations(t)
|
|
mb1.AssertExpectations(t)
|
|
mb2.AssertExpectations(t)
|
|
mb3.AssertExpectations(t)
|
|
|
|
// Delete should not have been called on new messages
|
|
new1.AssertNotCalled(t, "Delete")
|
|
new2.AssertNotCalled(t, "Delete")
|
|
new3.AssertNotCalled(t, "Delete")
|
|
|
|
// Delete should have been called once on old messages
|
|
old1.AssertNumberOfCalls(t, "Delete", 1)
|
|
old2.AssertNumberOfCalls(t, "Delete", 1)
|
|
old3.AssertNumberOfCalls(t, "Delete", 1)
|
|
}
|
|
|
|
// Make a MockMessage of a specific age
|
|
func mockMessage(ageHours int) *MockMessage {
|
|
msg := &MockMessage{}
|
|
msg.On("ID").Return(fmt.Sprintf("MSG[age=%vh]", ageHours))
|
|
msg.On("Date").Return(time.Now().Add(time.Duration(ageHours*-1) * time.Hour))
|
|
msg.On("Delete").Return(nil)
|
|
return msg
|
|
}
|