menu-balances #173
| @ -103,7 +103,7 @@ func (ls *LocalHandlerService) GetHandler(accountService remote.AccountServiceIn | ||||
| 	ls.DbRs.AddLocalFunc("verify_new_pin", ussdHandlers.VerifyNewPin) | ||||
| 	ls.DbRs.AddLocalFunc("confirm_pin_change", ussdHandlers.ConfirmPinChange) | ||||
| 	ls.DbRs.AddLocalFunc("quit_with_help", ussdHandlers.QuitWithHelp) | ||||
| 	ls.DbRs.AddLocalFunc("fetch_custodial_balances", ussdHandlers.FetchCustodialBalances) | ||||
| 	ls.DbRs.AddLocalFunc("fetch_community_balance", ussdHandlers.FetchCommunityBalance) | ||||
| 	ls.DbRs.AddLocalFunc("set_default_voucher", ussdHandlers.SetDefaultVoucher) | ||||
| 	ls.DbRs.AddLocalFunc("check_vouchers", ussdHandlers.CheckVouchers) | ||||
| 	ls.DbRs.AddLocalFunc("get_vouchers", ussdHandlers.GetVoucherList) | ||||
|  | ||||
| @ -822,42 +822,14 @@ func (h *Handlers) CheckBalance(ctx context.Context, sym string, input []byte) ( | ||||
| 	return res, nil | ||||
| } | ||||
| 
 | ||||
| func (h *Handlers) FetchCustodialBalances(ctx context.Context, sym string, input []byte) (resource.Result, error) { | ||||
| func (h *Handlers) FetchCommunityBalance(ctx context.Context, sym string, input []byte) (resource.Result, error) { | ||||
| 	var res resource.Result | ||||
| 
 | ||||
| 	flag_api_error, _ := h.flagManager.GetFlag("flag_api_call_error") | ||||
| 
 | ||||
| 	sessionId, ok := ctx.Value("SessionId").(string) | ||||
| 	if !ok { | ||||
| 		return res, fmt.Errorf("missing session") | ||||
| 	} | ||||
| 	symbol, _ := h.st.Where() | ||||
| 	balanceType := strings.Split(symbol, "_")[0] | ||||
| 
 | ||||
| 	store := h.userdataStore | ||||
| 	publicKey, err := store.ReadEntry(ctx, sessionId, common.DATA_PUBLIC_KEY) | ||||
| 	if err != nil { | ||||
| 		logg.ErrorCtxf(ctx, "failed to read publicKey entry with", "key", common.DATA_PUBLIC_KEY, "error", err) | ||||
| 		return res, err | ||||
| 	} | ||||
| 
 | ||||
| 	balanceResponse, err := h.accountService.CheckBalance(ctx, string(publicKey)) | ||||
| 	if err != nil { | ||||
| 		res.FlagSet = append(res.FlagSet, flag_api_error) | ||||
| 		return res, nil | ||||
| 	} | ||||
| 	res.FlagReset = append(res.FlagReset, flag_api_error) | ||||
| 
 | ||||
| 	balance := balanceResponse.Balance | ||||
| 
 | ||||
| 	switch balanceType { | ||||
| 	case "my": | ||||
| 		res.Content = fmt.Sprintf("Your balance is %s", balance) | ||||
| 	case "community": | ||||
| 		res.Content = fmt.Sprintf("Your community balance is %s", balance) | ||||
| 	default: | ||||
| 		break | ||||
| 	} | ||||
| 	code := codeFromCtx(ctx) | ||||
| 	l := gotext.NewLocale(translationDir, code) | ||||
| 	l.AddDomain("default") | ||||
| 	//TODO:
 | ||||
| 	//Check if the address is a community account,if then,get the actual balance
 | ||||
| 	res.Content = l.Get("Community Balance: 0.00") | ||||
| 	return res, nil | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -2,7 +2,6 @@ package ussd | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"log" | ||||
| 	"path" | ||||
| @ -1773,58 +1772,43 @@ func TestConfirmPin(t *testing.T) { | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func TestFetchCustodialBalances(t *testing.T) { | ||||
| 	fm, err := NewFlagManager(flagsPath) | ||||
| 	if err != nil { | ||||
| 		t.Logf(err.Error()) | ||||
| 	} | ||||
| 	flag_api_error, _ := fm.GetFlag("flag_api_call_error") | ||||
| func TestFetchCommunityBalance(t *testing.T) { | ||||
| 
 | ||||
| 	// Define test data
 | ||||
| 	sessionId := "session123" | ||||
| 	publicKey := "0X13242618721" | ||||
| 
 | ||||
| 	ctx, store := InitializeTestStore(t) | ||||
| 	ctx = context.WithValue(ctx, "SessionId", sessionId) | ||||
| 
 | ||||
| 	err = store.WriteEntry(ctx, sessionId, common.DATA_PUBLIC_KEY, []byte(publicKey)) | ||||
| 	if err != nil { | ||||
| 		t.Fatal(err) | ||||
| 	} | ||||
| 
 | ||||
| 	tests := []struct { | ||||
| 		name            string | ||||
| 		balanceResponse *models.BalanceResult | ||||
| 		expectedResult  resource.Result | ||||
| 		name           string | ||||
| 		languageCode   string | ||||
| 		expectedResult resource.Result | ||||
| 	}{ | ||||
| 		{ | ||||
| 			name: "Test when fetch custodial balances is not a success", | ||||
| 			balanceResponse: &models.BalanceResult{ | ||||
| 				Balance: "0.003 CELO", | ||||
| 				Nonce:   json.Number("0"), | ||||
| 			}, | ||||
| 			name: "Test community balance content when language is english", | ||||
| 			expectedResult: resource.Result{ | ||||
| 				FlagReset: []uint32{flag_api_error}, | ||||
| 				Content: "Community Balance: 0.00", | ||||
| 			}, | ||||
| 			languageCode: "eng", | ||||
| 		}, | ||||
| 	} | ||||
| 	for _, tt := range tests { | ||||
| 		t.Run(tt.name, func(t *testing.T) { | ||||
| 
 | ||||
| 			mockAccountService := new(mocks.MockAccountService) | ||||
| 			mockState := state.NewState(16) | ||||
| 
 | ||||
| 			h := &Handlers{ | ||||
| 				userdataStore:  store, | ||||
| 				flagManager:    fm.parser, | ||||
| 				st:             mockState, | ||||
| 				accountService: mockAccountService, | ||||
| 			} | ||||
| 
 | ||||
| 			// Set up the expected behavior of the mock
 | ||||
| 			mockAccountService.On("CheckBalance", string(publicKey)).Return(tt.balanceResponse, nil) | ||||
| 			ctx = context.WithValue(ctx, "SessionId", sessionId) | ||||
| 			ctx = context.WithValue(ctx, "Language", lang.Language{ | ||||
| 				Code: tt.languageCode, | ||||
| 			}) | ||||
| 
 | ||||
| 			// Call the method
 | ||||
| 			res, _ := h.FetchCustodialBalances(ctx, "fetch_custodial_balances", []byte("")) | ||||
| 			res, _ := h.FetchCommunityBalance(ctx, "fetch_community_balance", []byte("")) | ||||
| 
 | ||||
| 			//Assert that the result set to content is what was expected
 | ||||
| 			assert.Equal(t, res, tt.expectedResult, "Result should match expected result") | ||||
|  | ||||
| @ -103,7 +103,7 @@ | ||||
|                 }, | ||||
|                 { | ||||
|                     "input": "1234", | ||||
|                     "expectedContent": "Your balance is 0.003 CELO\n0:Back\n9:Quit" | ||||
|                     "expectedContent": "Balance: {balance}\n\n0:Back\n9:Quit" | ||||
|                 }, | ||||
|                 { | ||||
|                     "input": "0", | ||||
| @ -149,7 +149,7 @@ | ||||
|                 }, | ||||
|                 { | ||||
|                     "input": "1234", | ||||
|                     "expectedContent": "Your community balance is 0.003 CELO\n0:Back\n9:Quit" | ||||
|                     "expectedContent": "{balance}\n0:Back\n9:Quit" | ||||
|                 }, | ||||
|                 { | ||||
|                     "input": "0", | ||||
|  | ||||
| @ -1 +1 @@ | ||||
| Salio la kikundi | ||||
| {{.fetch_community_balance}} | ||||
| @ -1 +1 @@ | ||||
| {{.fetch_custodial_balances}} | ||||
| {{.fetch_community_balance}} | ||||
| @ -1,7 +1,7 @@ | ||||
| LOAD reset_incorrect 6 | ||||
| LOAD fetch_custodial_balances 0 | ||||
| LOAD fetch_community_balance 0 | ||||
| CATCH api_failure  flag_api_call_error  1 | ||||
| MAP fetch_custodial_balances | ||||
| MAP fetch_community_balance | ||||
| CATCH incorrect_pin flag_incorrect_pin 1 | ||||
| CATCH pin_entry flag_account_authorized 0 | ||||
| MOUT back 0 | ||||
|  | ||||
| @ -21,3 +21,6 @@ msgstr "Ombi lako la kumwalika %s kwa matandao wa Sarafu limetumwa." | ||||
| 
 | ||||
| msgid "Your request failed. Please try again later." | ||||
| msgstr "Ombi lako halikufaulu. Tafadhali jaribu tena baadaye." | ||||
| 
 | ||||
| msgid "Community Balance: 0.00" | ||||
| msgid "Salio la Kikundi: 0.00" | ||||
|  | ||||
| @ -1 +1 @@ | ||||
| {{.fetch_custodial_balances}} | ||||
| {{.check_balance}} | ||||
| @ -1,7 +1,7 @@ | ||||
| LOAD reset_incorrect 6 | ||||
| LOAD fetch_custodial_balances 0 | ||||
| LOAD check_balance 0 | ||||
| CATCH api_failure  flag_api_call_error  1 | ||||
| MAP fetch_custodial_balances | ||||
| MAP check_balance | ||||
| CATCH incorrect_pin flag_incorrect_pin 1 | ||||
| CATCH pin_entry flag_account_authorized 0 | ||||
| MOUT back 0 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user