add unit test
This commit is contained in:
@@ -0,0 +1,51 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"sort"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestAccountInfoResponseSliceLess(t *testing.T) {
|
||||
var accountRespSlice AccountInfoResponseSlice
|
||||
accountRespSlice = append(accountRespSlice, &AccountInfoResponse{
|
||||
Id: 1,
|
||||
Category: ACCOUNT_CATEGORY_DEBIT_CARD,
|
||||
DisplayOrder: int32(1),
|
||||
})
|
||||
accountRespSlice = append(accountRespSlice, &AccountInfoResponse{
|
||||
Id: 2,
|
||||
Category: ACCOUNT_CATEGORY_CASH,
|
||||
DisplayOrder: int32(3),
|
||||
})
|
||||
accountRespSlice = append(accountRespSlice, &AccountInfoResponse{
|
||||
Id: 3,
|
||||
Category: ACCOUNT_CATEGORY_CREDIT_CARD,
|
||||
DisplayOrder: int32(2),
|
||||
})
|
||||
accountRespSlice = append(accountRespSlice, &AccountInfoResponse{
|
||||
Id: 4,
|
||||
Category: ACCOUNT_CATEGORY_CASH,
|
||||
DisplayOrder: int32(2),
|
||||
})
|
||||
accountRespSlice = append(accountRespSlice, &AccountInfoResponse{
|
||||
Id: 5,
|
||||
Category: ACCOUNT_CATEGORY_CREDIT_CARD,
|
||||
DisplayOrder: int32(1),
|
||||
})
|
||||
accountRespSlice = append(accountRespSlice, &AccountInfoResponse{
|
||||
Id: 6,
|
||||
Category: ACCOUNT_CATEGORY_CASH,
|
||||
DisplayOrder: int32(1),
|
||||
})
|
||||
|
||||
sort.Sort(accountRespSlice)
|
||||
|
||||
assert.Equal(t, int64(6), accountRespSlice[0].Id)
|
||||
assert.Equal(t, int64(4), accountRespSlice[1].Id)
|
||||
assert.Equal(t, int64(2), accountRespSlice[2].Id)
|
||||
assert.Equal(t, int64(1), accountRespSlice[3].Id)
|
||||
assert.Equal(t, int64(5), accountRespSlice[4].Id)
|
||||
assert.Equal(t, int64(3), accountRespSlice[5].Id)
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"sort"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestLatestExchangeRateSliceLess(t *testing.T) {
|
||||
var latestExchangeRateSlice LatestExchangeRateSlice
|
||||
latestExchangeRateSlice = append(latestExchangeRateSlice, &LatestExchangeRate{
|
||||
Currency: "USD",
|
||||
})
|
||||
latestExchangeRateSlice = append(latestExchangeRateSlice, &LatestExchangeRate{
|
||||
Currency: "EUR",
|
||||
})
|
||||
latestExchangeRateSlice = append(latestExchangeRateSlice, &LatestExchangeRate{
|
||||
Currency: "CNY",
|
||||
})
|
||||
|
||||
sort.Sort(latestExchangeRateSlice)
|
||||
|
||||
assert.Equal(t, "CNY", latestExchangeRateSlice[0].Currency)
|
||||
assert.Equal(t, "EUR", latestExchangeRateSlice[1].Currency)
|
||||
assert.Equal(t, "USD", latestExchangeRateSlice[2].Currency)
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"sort"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestTokenInfoResponseSliceLess(t *testing.T) {
|
||||
var tokenInfoRespSlice TokenInfoResponseSlice
|
||||
tokenInfoRespSlice = append(tokenInfoRespSlice, &TokenInfoResponse{
|
||||
TokenId: "1",
|
||||
LastSeen: int64(1),
|
||||
})
|
||||
tokenInfoRespSlice = append(tokenInfoRespSlice, &TokenInfoResponse{
|
||||
TokenId: "2",
|
||||
LastSeen: int64(3),
|
||||
})
|
||||
tokenInfoRespSlice = append(tokenInfoRespSlice, &TokenInfoResponse{
|
||||
TokenId: "3",
|
||||
LastSeen: int64(2),
|
||||
})
|
||||
|
||||
sort.Sort(tokenInfoRespSlice)
|
||||
|
||||
assert.Equal(t, "2", tokenInfoRespSlice[0].TokenId)
|
||||
assert.Equal(t, "3", tokenInfoRespSlice[1].TokenId)
|
||||
assert.Equal(t, "1", tokenInfoRespSlice[2].TokenId)
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"sort"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestTransactionCategoryInfoResponseSliceLess(t *testing.T) {
|
||||
var transactionCategoryRespSlice TransactionCategoryInfoResponseSlice
|
||||
transactionCategoryRespSlice = append(transactionCategoryRespSlice, &TransactionCategoryInfoResponse{
|
||||
Id: 1,
|
||||
DisplayOrder: 3,
|
||||
})
|
||||
transactionCategoryRespSlice = append(transactionCategoryRespSlice, &TransactionCategoryInfoResponse{
|
||||
Id: 2,
|
||||
DisplayOrder: 1,
|
||||
})
|
||||
transactionCategoryRespSlice = append(transactionCategoryRespSlice, &TransactionCategoryInfoResponse{
|
||||
Id: 3,
|
||||
DisplayOrder: 2,
|
||||
})
|
||||
|
||||
sort.Sort(transactionCategoryRespSlice)
|
||||
|
||||
assert.Equal(t, int64(2), transactionCategoryRespSlice[0].Id)
|
||||
assert.Equal(t, int64(3), transactionCategoryRespSlice[1].Id)
|
||||
assert.Equal(t, int64(1), transactionCategoryRespSlice[2].Id)
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"sort"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestTransactionPictureInfoBasicResponseSliceLess(t *testing.T) {
|
||||
var pictureInfoSlice TransactionPictureInfoBasicResponseSlice
|
||||
pictureInfoSlice = append(pictureInfoSlice, &TransactionPictureInfoBasicResponse{
|
||||
PictureId: 2,
|
||||
})
|
||||
pictureInfoSlice = append(pictureInfoSlice, &TransactionPictureInfoBasicResponse{
|
||||
PictureId: 3,
|
||||
})
|
||||
pictureInfoSlice = append(pictureInfoSlice, &TransactionPictureInfoBasicResponse{
|
||||
PictureId: 1,
|
||||
})
|
||||
|
||||
sort.Sort(pictureInfoSlice)
|
||||
|
||||
assert.Equal(t, int64(1), pictureInfoSlice[0].PictureId)
|
||||
assert.Equal(t, int64(2), pictureInfoSlice[1].PictureId)
|
||||
assert.Equal(t, int64(3), pictureInfoSlice[2].PictureId)
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"sort"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestTransactionTagInfoResponseSliceLess(t *testing.T) {
|
||||
var transactionTagRespSlice TransactionTagInfoResponseSlice
|
||||
transactionTagRespSlice = append(transactionTagRespSlice, &TransactionTagInfoResponse{
|
||||
Id: 1,
|
||||
DisplayOrder: 3,
|
||||
})
|
||||
transactionTagRespSlice = append(transactionTagRespSlice, &TransactionTagInfoResponse{
|
||||
Id: 2,
|
||||
DisplayOrder: 1,
|
||||
})
|
||||
transactionTagRespSlice = append(transactionTagRespSlice, &TransactionTagInfoResponse{
|
||||
Id: 3,
|
||||
DisplayOrder: 2,
|
||||
})
|
||||
|
||||
sort.Sort(transactionTagRespSlice)
|
||||
|
||||
assert.Equal(t, int64(2), transactionTagRespSlice[0].Id)
|
||||
assert.Equal(t, int64(3), transactionTagRespSlice[1].Id)
|
||||
assert.Equal(t, int64(1), transactionTagRespSlice[2].Id)
|
||||
}
|
||||
@@ -0,0 +1,36 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"sort"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestTransactionTemplateInfoResponseSliceLess(t *testing.T) {
|
||||
var transactionTemplateRespSlice TransactionTemplateInfoResponseSlice
|
||||
transactionTemplateRespSlice = append(transactionTemplateRespSlice, &TransactionTemplateInfoResponse{
|
||||
TransactionInfoResponse: &TransactionInfoResponse{
|
||||
Id: 1,
|
||||
},
|
||||
DisplayOrder: 3,
|
||||
})
|
||||
transactionTemplateRespSlice = append(transactionTemplateRespSlice, &TransactionTemplateInfoResponse{
|
||||
TransactionInfoResponse: &TransactionInfoResponse{
|
||||
Id: 2,
|
||||
},
|
||||
DisplayOrder: 1,
|
||||
})
|
||||
transactionTemplateRespSlice = append(transactionTemplateRespSlice, &TransactionTemplateInfoResponse{
|
||||
TransactionInfoResponse: &TransactionInfoResponse{
|
||||
Id: 3,
|
||||
},
|
||||
DisplayOrder: 2,
|
||||
})
|
||||
|
||||
sort.Sort(transactionTemplateRespSlice)
|
||||
|
||||
assert.Equal(t, int64(2), transactionTemplateRespSlice[0].Id)
|
||||
assert.Equal(t, int64(3), transactionTemplateRespSlice[1].Id)
|
||||
assert.Equal(t, int64(1), transactionTemplateRespSlice[2].Id)
|
||||
}
|
||||
@@ -0,0 +1,96 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"sort"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestTransactionInfoResponseSliceLess(t *testing.T) {
|
||||
var transactionRespSlice TransactionInfoResponseSlice
|
||||
transactionRespSlice = append(transactionRespSlice, &TransactionInfoResponse{
|
||||
Id: 2,
|
||||
Time: 3,
|
||||
})
|
||||
transactionRespSlice = append(transactionRespSlice, &TransactionInfoResponse{
|
||||
Id: 3,
|
||||
Time: 2,
|
||||
})
|
||||
transactionRespSlice = append(transactionRespSlice, &TransactionInfoResponse{
|
||||
Id: 5,
|
||||
Time: 2,
|
||||
})
|
||||
transactionRespSlice = append(transactionRespSlice, &TransactionInfoResponse{
|
||||
Id: 4,
|
||||
Time: 1,
|
||||
})
|
||||
transactionRespSlice = append(transactionRespSlice, &TransactionInfoResponse{
|
||||
Id: 1,
|
||||
Time: 3,
|
||||
})
|
||||
|
||||
sort.Sort(transactionRespSlice)
|
||||
|
||||
assert.Equal(t, int64(2), transactionRespSlice[0].Id)
|
||||
assert.Equal(t, int64(1), transactionRespSlice[1].Id)
|
||||
assert.Equal(t, int64(5), transactionRespSlice[2].Id)
|
||||
assert.Equal(t, int64(3), transactionRespSlice[3].Id)
|
||||
assert.Equal(t, int64(4), transactionRespSlice[4].Id)
|
||||
}
|
||||
|
||||
func TestTransactionStatisticTrendsItemSliceLess(t *testing.T) {
|
||||
var transactionTrendsSlice TransactionStatisticTrendsItemSlice
|
||||
transactionTrendsSlice = append(transactionTrendsSlice, &TransactionStatisticTrendsItem{
|
||||
Year: 2024,
|
||||
Month: 9,
|
||||
})
|
||||
transactionTrendsSlice = append(transactionTrendsSlice, &TransactionStatisticTrendsItem{
|
||||
Year: 2022,
|
||||
Month: 10,
|
||||
})
|
||||
transactionTrendsSlice = append(transactionTrendsSlice, &TransactionStatisticTrendsItem{
|
||||
Year: 2023,
|
||||
Month: 1,
|
||||
})
|
||||
transactionTrendsSlice = append(transactionTrendsSlice, &TransactionStatisticTrendsItem{
|
||||
Year: 2022,
|
||||
Month: 2,
|
||||
})
|
||||
transactionTrendsSlice = append(transactionTrendsSlice, &TransactionStatisticTrendsItem{
|
||||
Year: 2024,
|
||||
Month: 1,
|
||||
})
|
||||
|
||||
sort.Sort(transactionTrendsSlice)
|
||||
|
||||
assert.Equal(t, int32(2022), transactionTrendsSlice[0].Year)
|
||||
assert.Equal(t, int32(2), transactionTrendsSlice[0].Month)
|
||||
assert.Equal(t, int32(2022), transactionTrendsSlice[1].Year)
|
||||
assert.Equal(t, int32(10), transactionTrendsSlice[1].Month)
|
||||
assert.Equal(t, int32(2023), transactionTrendsSlice[2].Year)
|
||||
assert.Equal(t, int32(1), transactionTrendsSlice[2].Month)
|
||||
assert.Equal(t, int32(2024), transactionTrendsSlice[3].Year)
|
||||
assert.Equal(t, int32(1), transactionTrendsSlice[3].Month)
|
||||
assert.Equal(t, int32(2024), transactionTrendsSlice[4].Year)
|
||||
assert.Equal(t, int32(9), transactionTrendsSlice[4].Month)
|
||||
}
|
||||
|
||||
func TestTransactionAmountsResponseItemAmountInfoSliceLess(t *testing.T) {
|
||||
var amountInfoSlice TransactionAmountsResponseItemAmountInfoSlice
|
||||
amountInfoSlice = append(amountInfoSlice, &TransactionAmountsResponseItemAmountInfo{
|
||||
Currency: "USD",
|
||||
})
|
||||
amountInfoSlice = append(amountInfoSlice, &TransactionAmountsResponseItemAmountInfo{
|
||||
Currency: "EUR",
|
||||
})
|
||||
amountInfoSlice = append(amountInfoSlice, &TransactionAmountsResponseItemAmountInfo{
|
||||
Currency: "CNY",
|
||||
})
|
||||
|
||||
sort.Sort(amountInfoSlice)
|
||||
|
||||
assert.Equal(t, "CNY", amountInfoSlice[0].Currency)
|
||||
assert.Equal(t, "EUR", amountInfoSlice[1].Currency)
|
||||
assert.Equal(t, "USD", amountInfoSlice[2].Currency)
|
||||
}
|
||||
@@ -0,0 +1,107 @@
|
||||
package models
|
||||
|
||||
import (
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
|
||||
"github.com/mayswind/ezbookkeeping/pkg/core"
|
||||
"github.com/mayswind/ezbookkeeping/pkg/utils"
|
||||
)
|
||||
|
||||
func TestUserCanEditTransactionByTransactionTime_ScopeIsNone(t *testing.T) {
|
||||
user := &User{
|
||||
TransactionEditScope: TRANSACTION_EDIT_SCOPE_NONE,
|
||||
}
|
||||
|
||||
assert.Equal(t, false, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(time.Now().Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
}
|
||||
|
||||
func TestUserCanEditTransactionByTransactionTime_ScopeIsAll(t *testing.T) {
|
||||
user := &User{
|
||||
TransactionEditScope: TRANSACTION_EDIT_SCOPE_ALL,
|
||||
}
|
||||
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(time.Now().Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
}
|
||||
|
||||
func TestUserCanEditTransactionByTransactionTime_ScopeIsTodayOrLater(t *testing.T) {
|
||||
user := &User{
|
||||
TransactionEditScope: TRANSACTION_EDIT_SCOPE_TODAY_OR_LATER,
|
||||
}
|
||||
|
||||
now := time.Now()
|
||||
todayFirstDatetime := time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, time.Local)
|
||||
yesterdayLastDatetime := todayFirstDatetime.Add(-1 * time.Second)
|
||||
todayLastDatetime := yesterdayLastDatetime.Add(24 * time.Hour)
|
||||
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(todayFirstDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(todayLastDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, false, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(yesterdayLastDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
}
|
||||
|
||||
func TestUserCanEditTransactionByTransactionTime_ScopeIsLast24HourOrLater(t *testing.T) {
|
||||
user := &User{
|
||||
TransactionEditScope: TRANSACTION_EDIT_SCOPE_LAST_24H_OR_LATER,
|
||||
}
|
||||
|
||||
now := time.Now()
|
||||
twentyfourHourBeforeDatetime := now.Add(-24 * time.Hour).Add(-1 * time.Second)
|
||||
|
||||
assert.Equal(t, false, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(twentyfourHourBeforeDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(twentyfourHourBeforeDatetime.Add(1*time.Second).Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
}
|
||||
|
||||
func TestUserCanEditTransactionByTransactionTime_ScopeIsThisWeekOrLater(t *testing.T) {
|
||||
user := &User{
|
||||
TransactionEditScope: TRANSACTION_EDIT_SCOPE_THIS_WEEK_OR_LATER,
|
||||
FirstDayOfWeek: core.WEEKDAY_MONDAY,
|
||||
}
|
||||
|
||||
now := time.Now()
|
||||
thisWeekFirstDatetime := time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, time.Local)
|
||||
|
||||
if thisWeekFirstDatetime.Weekday() == time.Sunday {
|
||||
thisWeekFirstDatetime = thisWeekFirstDatetime.Add(-6 * 24 * time.Hour)
|
||||
} else if thisWeekFirstDatetime.Weekday() != time.Monday {
|
||||
thisWeekFirstDatetime = thisWeekFirstDatetime.Add(time.Duration(1-thisWeekFirstDatetime.Weekday()) * 24 * time.Hour)
|
||||
}
|
||||
|
||||
lastWeekLastDatetime := thisWeekFirstDatetime.Add(-1 * time.Second)
|
||||
thisWeekLastDatetime := lastWeekLastDatetime.Add(24 * time.Hour)
|
||||
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(thisWeekFirstDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(thisWeekLastDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, false, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(lastWeekLastDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
}
|
||||
|
||||
func TestUserCanEditTransactionByTransactionTime_ScopeIsThisMonthOrLater(t *testing.T) {
|
||||
user := &User{
|
||||
TransactionEditScope: TRANSACTION_EDIT_SCOPE_THIS_MONTH_OR_LATER,
|
||||
}
|
||||
|
||||
now := time.Now()
|
||||
thisMonthFirstDatetime := time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, time.Local)
|
||||
lastMonthLastDatetime := thisMonthFirstDatetime.Add(-1 * time.Second)
|
||||
thisMonthLastDatetime := lastMonthLastDatetime.Add(24 * time.Hour)
|
||||
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(thisMonthFirstDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(thisMonthLastDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, false, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(lastMonthLastDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
}
|
||||
|
||||
func TestUserCanEditTransactionByTransactionTime_ScopeIsThisYearOrLater(t *testing.T) {
|
||||
user := &User{
|
||||
TransactionEditScope: TRANSACTION_EDIT_SCOPE_THIS_YEAR_OR_LATER,
|
||||
}
|
||||
|
||||
now := time.Now()
|
||||
thisYearFirstDatetime := time.Date(now.Year(), 1, 1, 0, 0, 0, 0, time.Local)
|
||||
lastYearLastDatetime := thisYearFirstDatetime.Add(-1 * time.Second)
|
||||
thisYearLastDatetime := lastYearLastDatetime.Add(24 * time.Hour)
|
||||
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(thisYearFirstDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, true, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(thisYearLastDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
assert.Equal(t, false, user.CanEditTransactionByTransactionTime(utils.GetMinTransactionTimeFromUnixTime(lastYearLastDatetime.Unix()), utils.GetServerTimezoneOffsetMinutes()))
|
||||
}
|
||||
Reference in New Issue
Block a user