wip-code-check #44
@ -4,9 +4,9 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"git.grassecon.net/urdt/ussd/internal/handlers/ussd/mocks"
|
"git.defalsify.org/vise.git/lang"
|
||||||
"git.grassecon.net/urdt/ussd/internal/models"
|
"git.grassecon.net/urdt/ussd/internal/models"
|
||||||
"git.grassecon.net/urdt/ussd/internal/utils"
|
|
||||||
"github.com/alecthomas/assert/v2"
|
"github.com/alecthomas/assert/v2"
|
||||||
"github.com/stretchr/testify/mock"
|
"github.com/stretchr/testify/mock"
|
||||||
)
|
)
|
||||||
@ -16,15 +16,6 @@ type MockAccountService struct {
|
|||||||
mock.Mock
|
mock.Mock
|
||||||
}
|
}
|
||||||
|
|
||||||
type MockFlagParser struct {
|
|
||||||
mock.Mock
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockFlagParser) GetFlag(key string) (uint32, error) {
|
|
||||||
args := m.Called(key)
|
|
||||||
return args.Get(0).(uint32), args.Error(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockAccountService) CreateAccount() (*models.AccountResponse, error) {
|
func (m *MockAccountService) CreateAccount() (*models.AccountResponse, error) {
|
||||||
args := m.Called()
|
args := m.Called()
|
||||||
return args.Get(0).(*models.AccountResponse), args.Error(1)
|
return args.Get(0).(*models.AccountResponse), args.Error(1)
|
||||||
@ -40,6 +31,58 @@ func (m *MockAccountService) CheckAccountStatus(trackingId string) (string, erro
|
|||||||
return args.String(0), args.Error(1)
|
return args.String(0), args.Error(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// MockDb is a mock implementation of the db.Db interface
|
||||||
|
type MockDb struct {
|
||||||
|
mock.Mock
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) SetPrefix(prefix uint8) {
|
||||||
|
m.Called(prefix)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) Prefix() uint8 {
|
||||||
|
args := m.Called()
|
||||||
|
return args.Get(0).(uint8)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) Safe() bool {
|
||||||
|
args := m.Called()
|
||||||
|
return args.Get(0).(bool)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) SetLanguage(language *lang.Language) {
|
||||||
|
m.Called(language)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) SetLock(uint8, bool) error {
|
||||||
|
args := m.Called()
|
||||||
|
return args.Error(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) Connect(ctx context.Context, connectionStr string) error {
|
||||||
|
args := m.Called(ctx, connectionStr)
|
||||||
|
return args.Error(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) SetSession(sessionId string) {
|
||||||
|
m.Called(sessionId)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) Put(ctx context.Context, key, value []byte) error {
|
||||||
|
args := m.Called(ctx, key, value)
|
||||||
|
return args.Error(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) Get(ctx context.Context, key []byte) ([]byte, error) {
|
||||||
|
args := m.Called(ctx, key)
|
||||||
|
return nil, args.Error(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockDb) Close() error {
|
||||||
|
args := m.Called(nil)
|
||||||
|
return args.Error(0)
|
||||||
|
}
|
||||||
|
|
||||||
// func TestCreateAccount(t *testing.T) {
|
// func TestCreateAccount(t *testing.T) {
|
||||||
// // Setup
|
// // Setup
|
||||||
// tempDir, err := os.MkdirTemp("", "test_create_account")
|
// tempDir, err := os.MkdirTemp("", "test_create_account")
|
||||||
@ -425,147 +468,121 @@ func (m *MockAccountService) CheckAccountStatus(trackingId string) (string, erro
|
|||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
|
|
||||||
// func TestSaveFirstname(t *testing.T) {
|
func TestSaveFirstname(t *testing.T) {
|
||||||
// // Create a new instance of MockAccountFileHandler
|
// Create a mock database
|
||||||
// mockFileHandler := new(mocks.MockAccountFileHandler)
|
mockDb := new(MockDb)
|
||||||
|
|
||||||
// // Define test cases
|
// Create a Handlers instance with the mock database
|
||||||
// tests := []struct {
|
h := &Handlers{
|
||||||
// name string
|
userdataStore: mockDb,
|
||||||
// input []byte
|
}
|
||||||
// existingData map[string]string
|
|
||||||
// writeError error
|
|
||||||
// expectedResult resource.Result
|
|
||||||
// expectedError error
|
|
||||||
// }{
|
|
||||||
// {
|
|
||||||
// name: "Successful Save",
|
|
||||||
// input: []byte("Joe"),
|
|
||||||
// existingData: map[string]string{"Name": "Joe"},
|
|
||||||
// writeError: nil,
|
|
||||||
// expectedResult: resource.Result{},
|
|
||||||
// expectedError: nil,
|
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// name: "Empty Input",
|
|
||||||
// input: []byte{},
|
|
||||||
// existingData: map[string]string{"OtherKey": "OtherValue"},
|
|
||||||
// writeError: nil,
|
|
||||||
// expectedError: nil,
|
|
||||||
// },
|
|
||||||
// }
|
|
||||||
|
|
||||||
// for _, tt := range tests {
|
// Create a context with a session ID
|
||||||
// t.Run(tt.name, func(t *testing.T) {
|
ctx := context.WithValue(context.Background(), "SessionId", "test-session")
|
||||||
// // Set up the mock expectations
|
|
||||||
// mockFileHandler.On("ReadAccountData").Return(tt.existingData, tt.expectedError)
|
|
||||||
// if tt.expectedError == nil && len(tt.input) > 0 {
|
|
||||||
// mockFileHandler.On("WriteAccountData", mock.MatchedBy(func(data map[string]string) bool {
|
|
||||||
// return data["FirstName"] == string(tt.input)
|
|
||||||
// })).Return(tt.writeError)
|
|
||||||
// } else if len(tt.input) == 0 {
|
|
||||||
// // For empty input, no WriteAccountData call should be made
|
|
||||||
// mockFileHandler.On("WriteAccountData", mock.Anything).Maybe().Return(tt.writeError)
|
|
||||||
// return
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // Create the Handlers instance with the mock file handler
|
tests := []struct {
|
||||||
// h := &Handlers{
|
name string
|
||||||
// accountFileHandler: mockFileHandler,
|
input []byte
|
||||||
// }
|
expectError bool
|
||||||
|
setupMock func(*MockDb)
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "Valid first name",
|
||||||
|
input: []byte("John"),
|
||||||
|
expectError: false,
|
||||||
|
setupMock: func(m *MockDb) {
|
||||||
|
m.On("SetPrefix", uint8(0x20)).Return(nil)
|
||||||
|
m.On("SetSession", "test-session").Return(nil)
|
||||||
|
m.On("Put", mock.Anything, mock.Anything, []byte("John")).Return(nil)
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Empty first name",
|
||||||
|
input: []byte{},
|
||||||
|
expectError: false, // Note: The function doesn't return an error for empty input
|
||||||
|
setupMock: func(m *MockDb) {},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
// // Call save location
|
for _, tt := range tests {
|
||||||
// result, err := h.SaveFirstname(context.Background(), "save_location", tt.input)
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
// Setup mock expectations
|
||||||
|
tt.setupMock(mockDb)
|
||||||
|
|
||||||
// if err != nil {
|
// Call the function
|
||||||
// t.Fatalf("Failed to save first name with error: %v", err)
|
_, err := h.SaveFirstname(ctx, "", tt.input)
|
||||||
// }
|
|
||||||
// savedData, err := h.accountFileHandler.ReadAccountData()
|
|
||||||
// if err == nil {
|
|
||||||
// //Assert that the input provided is what was saved into the file
|
|
||||||
// assert.Equal(t, string(tt.input), savedData["FirstName"])
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // Assert the results
|
if tt.expectError {
|
||||||
// assert.Equal(t, tt.expectedResult, result)
|
assert.Error(t, err)
|
||||||
// assert.Equal(t, tt.expectedError, err)
|
} else {
|
||||||
|
assert.NoError(t, err)
|
||||||
|
mockDb.AssertExpectations(t)
|
||||||
|
}
|
||||||
|
|
||||||
// // Assert all expectations were met
|
// Clear mock for the next test
|
||||||
// mockFileHandler.AssertExpectations(t)
|
mockDb.ExpectedCalls = nil
|
||||||
// })
|
mockDb.Calls = nil
|
||||||
// }
|
})
|
||||||
// }
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// func TestSaveFamilyName(t *testing.T) {
|
func TestSaveFamilyname(t *testing.T) {
|
||||||
// // Create a new instance of MockAccountFileHandler
|
// Create a mock database
|
||||||
// mockFileHandler := new(mocks.MockAccountFileHandler)
|
mockDb := new(MockDb)
|
||||||
|
|
||||||
// // Define test cases
|
// Create a Handlers instance with the mock database
|
||||||
// tests := []struct {
|
h := &Handlers{
|
||||||
// name string
|
userdataStore: mockDb,
|
||||||
// input []byte
|
}
|
||||||
// existingData map[string]string
|
|
||||||
// writeError error
|
|
||||||
// expectedResult resource.Result
|
|
||||||
// expectedError error
|
|
||||||
// }{
|
|
||||||
// {
|
|
||||||
// name: "Successful Save",
|
|
||||||
// input: []byte("Doe"),
|
|
||||||
// existingData: map[string]string{"FamilyName": "Doe"},
|
|
||||||
// writeError: nil,
|
|
||||||
// expectedResult: resource.Result{},
|
|
||||||
// expectedError: nil,
|
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// name: "Empty Input",
|
|
||||||
// input: []byte{},
|
|
||||||
// existingData: map[string]string{"FamilyName": "Doe"},
|
|
||||||
// writeError: nil,
|
|
||||||
// expectedError: nil,
|
|
||||||
// },
|
|
||||||
// }
|
|
||||||
|
|
||||||
// for _, tt := range tests {
|
// Create a context with a session ID
|
||||||
// t.Run(tt.name, func(t *testing.T) {
|
ctx := context.WithValue(context.Background(), "SessionId", "test-session")
|
||||||
// // Set up the mock expectations
|
|
||||||
// mockFileHandler.On("ReadAccountData").Return(tt.existingData, tt.expectedError)
|
|
||||||
// if tt.expectedError == nil && len(tt.input) > 0 {
|
|
||||||
// mockFileHandler.On("WriteAccountData", mock.MatchedBy(func(data map[string]string) bool {
|
|
||||||
// return data["FamilyName"] == string(tt.input)
|
|
||||||
// })).Return(tt.writeError)
|
|
||||||
// } else if len(tt.input) == 0 {
|
|
||||||
// // For empty input, no WriteAccountData call should be made
|
|
||||||
// mockFileHandler.On("WriteAccountData", mock.Anything).Maybe().Return(tt.writeError)
|
|
||||||
// return
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // Create the Handlers instance with the mock file handler
|
tests := []struct {
|
||||||
// h := &Handlers{
|
name string
|
||||||
// accountFileHandler: mockFileHandler,
|
input []byte
|
||||||
// }
|
expectError bool
|
||||||
|
setupMock func(*MockDb)
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "Valid family name",
|
||||||
|
input: []byte("Smith"),
|
||||||
|
expectError: false,
|
||||||
|
setupMock: func(m *MockDb) {
|
||||||
|
m.On("SetPrefix", uint8(0x20)).Return(nil)
|
||||||
|
m.On("SetSession", "test-session").Return(nil)
|
||||||
|
m.On("Put", mock.Anything, mock.Anything, []byte("Smith")).Return(nil)
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Empty family name",
|
||||||
|
input: []byte{},
|
||||||
|
expectError: true,
|
||||||
|
setupMock: func(m *MockDb) {},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
// // Call save familyname
|
for _, tt := range tests {
|
||||||
// result, err := h.SaveFamilyname(context.Background(), "save_familyname", tt.input)
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
// Setup mock expectations
|
||||||
|
tt.setupMock(mockDb)
|
||||||
|
|
||||||
// if err != nil {
|
// Call the function
|
||||||
// t.Fatalf("Failed to save family name with error: %v", err)
|
_, err := h.SaveFamilyname(ctx, "", tt.input)
|
||||||
// }
|
|
||||||
// savedData, err := h.accountFileHandler.ReadAccountData()
|
|
||||||
// if err == nil {
|
|
||||||
// //Assert that the input provided is what was saved into the file
|
|
||||||
// assert.Equal(t, string(tt.input), savedData["FamilyName"])
|
|
||||||
// }
|
|
||||||
|
|
||||||
// // Assert the results
|
if tt.expectError {
|
||||||
// assert.Equal(t, tt.expectedResult, result)
|
assert.Error(t, err)
|
||||||
// assert.Equal(t, tt.expectedError, err)
|
} else {
|
||||||
|
assert.NoError(t, err)
|
||||||
|
mockDb.AssertExpectations(t)
|
||||||
|
}
|
||||||
|
|
||||||
// // Assert all expectations were met
|
// Clear mock for the next test
|
||||||
// mockFileHandler.AssertExpectations(t)
|
mockDb.ExpectedCalls = nil
|
||||||
// })
|
mockDb.Calls = nil
|
||||||
// }
|
})
|
||||||
// }
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// func TestSaveYOB(t *testing.T) {
|
// func TestSaveYOB(t *testing.T) {
|
||||||
// // Create a new instance of MockAccountFileHandler
|
// // Create a new instance of MockAccountFileHandler
|
||||||
@ -986,60 +1003,3 @@ func (m *MockAccountService) CheckAccountStatus(trackingId string) (string, erro
|
|||||||
// })
|
// })
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
|
|
||||||
// Test SaveFirstname
|
|
||||||
func TestSaveFirstName(t *testing.T) {
|
|
||||||
// Create a new instance of MockDb
|
|
||||||
mockDb := new(mocks.MockDb)
|
|
||||||
k := utils.PackKey(utils.DATA_FAMILY_NAME, []byte("session123"))
|
|
||||||
// Define test cases
|
|
||||||
tests := []struct {
|
|
||||||
name string
|
|
||||||
ctxValue string
|
|
||||||
input []byte
|
|
||||||
mockPutError error
|
|
||||||
expectedError error
|
|
||||||
expectedCalls []mock.Call
|
|
||||||
}{
|
|
||||||
{
|
|
||||||
name: "Successful save",
|
|
||||||
ctxValue: "session123",
|
|
||||||
input: []byte("John"),
|
|
||||||
mockPutError: nil,
|
|
||||||
expectedError: nil,
|
|
||||||
expectedCalls: []mock.Call{
|
|
||||||
// Expect the SetPrefix and SetSession calls
|
|
||||||
*mockDb.On("SetPrefix", utils.DATA_FAMILY_NAME).Return(),
|
|
||||||
*mockDb.On("SetSession", "session123").Return(),
|
|
||||||
// Expect the Put call
|
|
||||||
*mockDb.On("Put", context.WithValue(context.Background(), "SessionId", "session123"), k, []byte("John")).Return(nil),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, tt := range tests {
|
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
|
||||||
// Set up the mock expectations
|
|
||||||
for _, call := range tt.expectedCalls {
|
|
||||||
call.Run(func(args mock.Arguments) {})
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create the Handlers instance with the mock db
|
|
||||||
h := &Handlers{
|
|
||||||
userdataStore: mockDb,
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create the context with the session ID
|
|
||||||
ctx := context.WithValue(context.Background(), "SessionId", tt.ctxValue)
|
|
||||||
|
|
||||||
// Call the method
|
|
||||||
_, err := h.SaveFamilyname(ctx, "save_familyname", []byte("John"))
|
|
||||||
|
|
||||||
// Assert the results
|
|
||||||
assert.Equal(t, tt.expectedError, err)
|
|
||||||
|
|
||||||
// Assert all expectations were met
|
|
||||||
mockDb.AssertExpectations(t)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user