Compare commits

..

83 Commits

Author SHA1 Message Date
Carlosokumu
fc85bd7eed return an event channel for the test engine 2024-10-09 14:06:16 +03:00
Carlosokumu
5869324c16 remove unused variable 2024-10-09 14:03:36 +03:00
Carlosokumu
1d67fb694b use regex for vm output and expected content 2024-10-09 12:18:56 +03:00
Carlosokumu
3d409a7a59 remove blank line 2024-10-08 22:44:07 +03:00
Carlosokumu
22047ba703 update account service initialization based on the tag 2024-10-08 22:43:11 +03:00
Carlosokumu
8751c4f5bd use just one driver for the tests 2024-10-08 22:19:48 +03:00
Carlosokumu
fc935535f9 remove deprecated code 2024-10-08 22:19:21 +03:00
Carlosokumu
ef4846b11f move online,offline and test engine into the testutil package 2024-10-08 22:18:44 +03:00
Carlosokumu
827b99e48d Revert "add dummy vouchers list"
This reverts commit 188cb573dd.
2024-10-07 20:36:02 +03:00
Carlosokumu
e09c1e1e98 Revert "add dummy vouchers list"
This reverts commit 188cb573dd.
2024-10-07 20:35:18 +03:00
Carlosokumu
87c6029199 Revert "add dummy vouchers list"
This reverts commit 188cb573dd.
2024-10-07 20:33:02 +03:00
Carlosokumu
992dd0bd54 factor out setup test 2024-10-07 19:05:36 +03:00
Carlosokumu
4cd7c742ef factor out tested groups 2024-10-07 18:36:34 +03:00
Carlosokumu
0d18eec39f remove debug message 2024-10-07 16:55:07 +03:00
Carlosokumu
bb009fa1e2 add group test cases 2024-10-07 16:43:13 +03:00
Carlosokumu
2ffe749c9d add driver to group tests 2024-10-07 16:42:48 +03:00
Carlosokumu
0a92444ae8 add group tests 2024-10-07 16:41:45 +03:00
Carlosokumu
2703e6d1df add tags to toggle between online and offline tests 2024-10-05 21:47:17 +03:00
Carlosokumu
86ba03b375 update tests 2024-10-04 17:04:33 +03:00
Carlosokumu
f91480f3de pass account service as a param 2024-10-04 16:58:47 +03:00
Carlosokumu
79a127cea9 pass account service as a parameter 2024-10-04 16:58:18 +03:00
Carlosokumu
6178425355 create a mocked account service 2024-10-04 16:57:25 +03:00
Carlosokumu
09bf266644 pass account service 2024-10-04 16:56:23 +03:00
Carlosokumu
bf1df95af1 pass account service implementation 2024-10-04 16:53:52 +03:00
Carlosokumu
9647d29bd7 resolve failing test 2024-10-04 11:17:19 +03:00
Carlosokumu
64cc9bc752 Merge remote-tracking branch 'refs/remotes/origin/menu-traversals' into menu-traversals 2024-10-04 11:13:58 +03:00
Carlosokumu
ddfd9d4e89 fix failing test 2024-10-04 11:11:41 +03:00
alfred-mk
b7d93c2249 use a UUID for the sessionId 2024-10-03 17:47:48 +03:00
Carlosokumu
a1201e2525 Merge remote-tracking branch 'remotes/origin/master' into menu-traversals 2024-10-03 17:13:40 +03:00
alfred-mk
d6cd2766df add a Random SessionID for each test run 2024-10-03 16:54:30 +03:00
Carlosokumu
e2316b38a8 reset account authorized and perform clean quit on view profile test 2024-10-03 14:55:25 +03:00
alfred-mk
d94037d499 combine the invalid PIN case and remove unused tests 2024-10-03 14:07:36 +03:00
Carlosokumu
0f2ec2f2bd reset authorized flag,update test data file 2024-10-03 13:47:31 +03:00
alfred-mk
089691db4c remove combined test 2024-10-03 12:51:46 +03:00
alfred-mk
1b8c8a12c0 combine the invalid PIN case 2024-10-03 12:51:03 +03:00
alfred-mk
c965d3083d renamed sym to symbol to avoid confusion 2024-10-03 11:53:46 +03:00
alfred-mk
59aa4eae77 removed unused code 2024-10-03 11:45:56 +03:00
alfred-mk
587cfb5a36 use the pp.csv from the scriptDir 2024-10-03 11:45:37 +03:00
alfred-mk
d94758c32c moved the test to test_engine folder 2024-10-03 11:44:34 +03:00
alfred-mk
0fa4a81826 updated the TestAuthorize 2024-10-03 11:42:41 +03:00
alfred-mk
73013f53bb added engine Finish 2024-10-02 15:52:55 +03:00
alfred-mk
986f3979fb use a dynamic public_key 2024-10-02 15:50:52 +03:00
Carlosokumu
96ec3919b2 update test data file 2024-10-02 14:39:48 +03:00
Carlosokumu
079529ebac Merge remote-tracking branch 'refs/remotes/origin/menu-traversals' into menu-traversals 2024-10-02 14:32:08 +03:00
alfred-mk
94bf4ffaa6 combine some test cases and rename the account creation test 2024-10-02 14:28:21 +03:00
alfred-mk
24380e1449 update the templates 2024-10-02 14:25:29 +03:00
Carlosokumu
7f6405d356 Merge remote-tracking branch 'refs/remotes/origin/menu-traversals' into menu-traversals 2024-10-02 13:54:00 +03:00
alfred-mk
2a1e48e5e8 update the test_data with expected output 2024-10-02 13:31:47 +03:00
alfred-mk
6b8f62fbc6 code cleanup - removed unused new lines 2024-10-02 13:26:19 +03:00
alfred-mk
948a9d3a93 allow one to go back during the change PIN 2024-10-02 13:24:03 +03:00
Carlosokumu
01476d5408 update tests 2024-10-02 13:22:00 +03:00
Carlosokumu
ab02a8882a update tests 2024-10-02 12:10:32 +03:00
Carlosokumu
74fa2c3d65 update tests 2024-10-02 11:23:34 +03:00
Carlosokumu
204ce3ce56 update tests 2024-10-02 10:18:04 +03:00
Carlosokumu
abbf22086f update tests 2024-10-02 09:55:56 +03:00
Carlosokumu
6eec9571c7 update test 2024-10-02 09:01:27 +03:00
Carlosokumu
7c0ae80bbf Merge remote-tracking branch 'refs/remotes/origin/menu-traversals' into menu-traversals 2024-10-01 23:23:22 +03:00
Carlosokumu
1ff2c3602f update tests 2024-10-01 23:21:29 +03:00
alfred-mk
a0ef57ca15 add Change PIN test 2024-10-01 21:43:52 +03:00
Carlosokumu
dddb7d7309 merge 2024-10-01 16:54:44 +03:00
Carlosokumu
c5b2348f5e add tests 2024-10-01 16:54:16 +03:00
alfred-mk
48c608ad4d add Help and Quit menu tests 2024-10-01 15:36:59 +03:00
alfred-mk
14218ffb88 add a dynamic value 2024-10-01 14:50:45 +03:00
alfred-mk
3e74c1d939 test with all invalid inputs 2024-10-01 13:26:47 +03:00
alfred-mk
285002738f added send_with_invalid_recipient test 2024-10-01 13:15:05 +03:00
lash
f267aa2b41 Delete connstr in threadgdbm global channel map on close 2024-10-01 00:18:54 +01:00
Carlosokumu
1b2c6933e1 clean up test 2024-09-30 22:27:37 +03:00
Carlosokumu
94d1271dbb update 2024-09-30 22:22:00 +03:00
alfred-mk
f3f276c549 check the status of cont 2024-09-30 22:12:49 +03:00
alfred-mk
9eb35ec52d added en.Finish 2024-09-30 22:00:28 +03:00
alfred-mk
be165e5033 added tests and test cases 2024-09-30 19:55:13 +03:00
Carlosokumu
e7a3de526c remove log 2024-09-30 18:09:53 +03:00
Carlosokumu
cf5b4ec744 call finish on engine 2024-09-30 18:05:20 +03:00
Carlosokumu
80ce141b80 reference correct test data file 2024-09-30 13:31:49 +03:00
Carlosokumu
170d075545 update tests 2024-09-30 13:25:38 +03:00
Carlosokumu
4aad23ab30 update tests 2024-09-30 13:21:17 +03:00
Carlosokumu
7d1db50294 update 2024-09-27 16:26:00 +03:00
Carlosokumu
afe98b8695 setup traversal tests 2024-09-27 15:02:29 +03:00
Carlosokumu
ece80b31f6 start menu traversal tests setup 2024-09-26 21:27:54 +03:00
alfred-mk
221db4e998 return a numbered list of vouchers 2024-09-25 16:06:06 +03:00
alfred-mk
0e376e0d9e include back and quit 2024-09-25 16:03:08 +03:00
Carlosokumu
7aa44caea2 add voucher nodes 2024-09-25 15:57:23 +03:00
Carlosokumu
188cb573dd add dummy vouchers list 2024-09-25 13:27:13 +03:00
29 changed files with 52 additions and 47 deletions

View File

@@ -15,9 +15,9 @@ import (
"git.defalsify.org/vise.git/engine"
"git.defalsify.org/vise.git/logging"
"git.defalsify.org/vise.git/resource"
"git.grassecon.net/urdt/ussd/internal/handlers/server"
"git.grassecon.net/urdt/ussd/internal/handlers"
"git.grassecon.net/urdt/ussd/internal/handlers/server"
httpserver "git.grassecon.net/urdt/ussd/internal/http"
"git.grassecon.net/urdt/ussd/internal/storage"
)

View File

@@ -14,8 +14,8 @@ import (
"git.defalsify.org/vise.git/resource"
"git.grassecon.net/urdt/ussd/internal/handlers"
"git.grassecon.net/urdt/ussd/internal/storage"
"git.grassecon.net/urdt/ussd/internal/handlers/server"
"git.grassecon.net/urdt/ussd/internal/storage"
)
var (
@@ -95,6 +95,7 @@ func main() {
lhs, err := handlers.NewLocalHandlerService(pfp, true, dbResource, cfg, rs)
lhs.SetDataStore(&userdataStore)
accountService := server.AccountService{}
hl, err := lhs.GetHandler(&accountService)

View File

@@ -16,9 +16,9 @@ import (
"git.defalsify.org/vise.git/resource"
"git.grassecon.net/urdt/ussd/internal/handlers"
"git.grassecon.net/urdt/ussd/internal/handlers/server"
httpserver "git.grassecon.net/urdt/ussd/internal/http"
"git.grassecon.net/urdt/ussd/internal/storage"
"git.grassecon.net/urdt/ussd/internal/handlers/server"
)
var (
@@ -90,7 +90,6 @@ func main() {
}
accountService := server.AccountService{}
hl, err := lhs.GetHandler(&accountService)
if err != nil {
fmt.Fprintf(os.Stderr, err.Error())

View File

@@ -13,12 +13,13 @@ type Step struct {
}
func (s *Step) MatchesExpectedContent(content []byte) (bool, error) {
pattern := regexp.QuoteMeta(s.ExpectedContent)
pattern := `.*\?.*|.*`
re, err := regexp.Compile(pattern)
if err != nil {
return false, err
}
if re.Match([]byte(content)) {
// Check if the content matches the regex pattern
if re.Match(content) {
return true, nil
}
return false, nil
@@ -37,8 +38,7 @@ type TestCase struct {
}
func (s *TestCase) MatchesExpectedContent(content []byte) (bool, error) {
pattern := regexp.QuoteMeta(s.ExpectedContent)
re, err := regexp.Compile(pattern)
re, err := regexp.Compile(s.ExpectedContent)
if err != nil {
return false, err
}

View File

@@ -6,8 +6,8 @@ import (
"git.defalsify.org/vise.git/engine"
"git.defalsify.org/vise.git/persist"
"git.defalsify.org/vise.git/resource"
"git.grassecon.net/urdt/ussd/internal/handlers/ussd"
"git.grassecon.net/urdt/ussd/internal/handlers/server"
"git.grassecon.net/urdt/ussd/internal/handlers/ussd"
)
type HandlerService interface {
@@ -54,7 +54,7 @@ func (ls *LocalHandlerService) SetDataStore(db *db.Db) {
}
func (ls *LocalHandlerService) GetHandler(accountService server.AccountServiceInterface) (*ussd.Handlers, error) {
ussdHandlers, err := ussd.NewHandlers(ls.Parser, *ls.UserdataStore,accountService)
ussdHandlers, err := ussd.NewHandlers(ls.Parser, *ls.UserdataStore, accountService)
if err != nil {
return nil, err
}

View File

@@ -18,7 +18,7 @@ type AccountServiceInterface interface {
type AccountService struct {
}
type TestAccountService struct {
type MockAccountService struct {
}
// CheckAccountStatus retrieves the status of an account transaction based on the provided tracking ID.
@@ -49,7 +49,9 @@ func (as *AccountService) CheckAccountStatus(trackingId string) (string, error)
if err != nil {
return "", err
}
status := trackResp.Result.Transaction.Status
return status, nil
}
@@ -106,7 +108,7 @@ func (as *AccountService) CreateAccount() (*models.AccountResponse, error) {
return &accountResp, nil
}
func (tas *TestAccountService) CreateAccount() (*models.AccountResponse, error) {
func (mas *MockAccountService) CreateAccount() (*models.AccountResponse, error) {
return &models.AccountResponse{
Ok: true,
Result: struct {
@@ -121,7 +123,7 @@ func (tas *TestAccountService) CreateAccount() (*models.AccountResponse, error)
}, nil
}
func (tas *TestAccountService) CheckBalance(publicKey string) (string, error) {
func (mas *MockAccountService) CheckBalance(publicKey string) (string, error) {
balanceResponse := &models.BalanceResponse{
Ok: true,
@@ -137,6 +139,6 @@ func (tas *TestAccountService) CheckBalance(publicKey string) (string, error) {
return balanceResponse.Result.Balance, nil
}
func (tas *TestAccountService) CheckAccountStatus(trackingId string) (string, error) {
func (mas *MockAccountService) CheckAccountStatus(trackingId string) (string, error) {
return "SUCCESS", nil
}

View File

@@ -502,7 +502,7 @@ func (h *Handlers) Authorize(ctx context.Context, sym string, input []byte) (res
if err != nil {
return res, err
}
if len(input) == 4 {
if len(input) > 1 {
if bytes.Equal(input, AccountPin) {
if h.st.MatchFlag(flag_account_authorized, false) {
res.FlagReset = append(res.FlagReset, flag_incorrect_pin)

View File

@@ -836,7 +836,10 @@ func TestAuthorize(t *testing.T) {
{
name: "Test with pin that is not a 4 digit",
input: []byte("1235aqds"),
expectedResult: resource.Result{},
expectedResult: resource.Result{
FlagReset: []uint32{flag_account_authorized},
FlagSet: []uint32{flag_incorrect_pin},
},
},
}

View File

@@ -79,12 +79,8 @@ func TestEngine(sessionId string) (engine.Engine, func(), chan bool) {
os.Exit(1)
}
if AccountService == nil {
AccountService = &server.AccountService{}
}
switch AccountService.(type) {
case *server.TestAccountService:
case *server.MockAccountService:
go func() {
eventChannel <- false
}()

View File

@@ -1,4 +1,3 @@
//go:build !online
// +build !online
package testutil
@@ -7,6 +6,8 @@ import (
"git.grassecon.net/urdt/ussd/internal/handlers/server"
)
var (
AccountService server.AccountServiceInterface = &server.TestAccountService{}
)
var AccountService server.AccountServiceInterface
func init() {
AccountService = &server.MockAccountService{}
}

View File

@@ -5,6 +5,8 @@ package testutil
import "git.grassecon.net/urdt/ussd/internal/handlers/server"
var (
AccountService server.AccountServiceInterface
)
var AccountService server.AccountServiceInterface
func init() {
AccountService = &server.AccountService{}
}

View File

@@ -2,5 +2,4 @@ CATCH invalid_pin flag_valid_pin 0
MOUT back 0
HALT
INCMP _ 0
INCMP pin_reset_success *
INCMP pin_reset_success *

View File

@@ -1 +1 @@
Thibitisha PIN yako mpya:
Thibitisha PIN yako mpya:

View File

@@ -18,4 +18,4 @@ INCMP select_gender 3
INCMP enter_yob 4
INCMP enter_location 5
INCMP enter_offerings 6
INCMP view_profile 7
INCMP view_profile 7

View File

@@ -1 +1 @@
Weka jina la familia
Weka jina la familia

View File

@@ -7,6 +7,3 @@ HALT
RELOAD save_firstname
INCMP _ 0
INCMP pin_entry *

View File

@@ -1 +1,2 @@
PIN mpya na udhibitisho wa pin mpya hazilingani.Tafadhali jaribu tena.Kwa usaidizi piga simu +254757628885.
PIN mpya na udhibitisho wa PIN mpya hazilingani. Tafadhali jaribu tena.
Kwa usaidizi piga simu +254757628885.

View File

@@ -0,0 +1 @@
My vouchers

View File

@@ -0,0 +1,6 @@
MOUT select_voucher 1
MOUT voucher_details 2
MOUT back 0
HALT
INCMP _ 0
INCMP select_voucher 1

View File

@@ -8,5 +8,3 @@ LOAD verify_new_pin 8
RELOAD verify_new_pin
CATCH incorrect_pin flag_incorrect_pin 1
INCMP confirm_pin_change *

View File

@@ -1 +1 @@
Weka PIN mpya ya nne nambari:
Weka PIN mpya ya nne nambari:

View File

@@ -1 +1 @@
Weka PIN yako ya zamani:
Weka PIN yako ya zamani:

View File

@@ -5,4 +5,3 @@ MOUT back 0
HALT
INCMP _ 0
INCMP old_pin 1

View File

@@ -1 +1 @@
The PIN is not a match. Try again
The PIN is not a match. Try again

View File

@@ -1 +1 @@
Ombi lako la kubadili PIN limefanikiwa
Ombi lako la kubadili PIN limefanikiwa

View File

@@ -1 +1 @@
Ombi la Kuweka wasifu limefanikiwa
Ombi la Kuweka wasifu limefanikiwa

View File

@@ -0,0 +1 @@
Select voucher

View File

@@ -0,0 +1 @@
Voucher details

View File

@@ -160,7 +160,6 @@ func TestSendWithInvalidInputs(t *testing.T) {
// Replace placeholder {public_key} with the actual dynamic public key
expectedContent := bytes.Replace([]byte(step.ExpectedContent), []byte("{public_key}"), []byte(publicKey), -1)
step.ExpectedContent = string(expectedContent)
match, err := step.MatchesExpectedContent(b)
if err != nil {
t.Fatalf("Error compiling regex for step '%s': %v", step.Input, err)
@@ -339,7 +338,6 @@ func TestMyAccount_MyAddress(t *testing.T) {
publicKey := extractPublicKey(b)
expectedContent := bytes.Replace([]byte(step.ExpectedContent), []byte("{public_key}"), []byte(publicKey), -1)
step.ExpectedContent = string(expectedContent)
match, err := step.MatchesExpectedContent(b)
if err != nil {
t.Fatalf("Error compiling regex for step '%s': %v", step.Input, err)