From da3852bdb260d0cce5e2db651752f36a09b6850d Mon Sep 17 00:00:00 2001 From: YashK Date: Tue, 28 Nov 2023 15:23:21 +0530 Subject: [PATCH 1/2] fix: conversion of hex to decimal --- utils/math.go | 2 +- utils/math_test.go | 65 ++++++++++++++++++++++++++++++++-------------- 2 files changed, 46 insertions(+), 21 deletions(-) diff --git a/utils/math.go b/utils/math.go index b379b625a..52d08092a 100644 --- a/utils/math.go +++ b/utils/math.go @@ -43,7 +43,7 @@ func ConvertHexToBigFloat(hexString string) (*big.Float, error) { log.Errorf("Error in converting hex value %v to uint64: %v", hexValue, err) return big.NewFloat(0), err } - return big.NewFloat(math.Float64frombits(hexValueUint64)), nil + return big.NewFloat(float64(hexValueUint64)), nil } func MultiplyWithPower(num *big.Float, power int8) *big.Int { diff --git a/utils/math_test.go b/utils/math_test.go index d43ea74f5..4ae917b4e 100644 --- a/utils/math_test.go +++ b/utils/math_test.go @@ -1,7 +1,6 @@ package utils import ( - "math" "math/big" "razor/utils/mocks" "reflect" @@ -982,30 +981,56 @@ func TestConvertHexToBigFloat(t *testing.T) { tests := []struct { name string hexString string - expected *big.Float - expectErr bool + want *big.Float + wantErr bool }{ - {"Valid hexadecimal without prefix", "3FF0000000000000", big.NewFloat(1), false}, - {"Valid hexadecimal with prefix", "0x3FF0000000000000", big.NewFloat(1), false}, - {"Invalid hexadecimal string", "0xInvalid", big.NewFloat(0), true}, - {"Empty hexadecimal string", "", big.NewFloat(0), true}, - {"Valid hex representation of PI", "0x400921FB54442D18", big.NewFloat(3.141592653589793), false}, - {"Valid hex without 0x prefix", "400921FB54442D18", big.NewFloat(3.141592653589793), false}, - {"Zero value", "0x0000000000000000", big.NewFloat(0.0), false}, - {"Positive infinity", "0x7FF0000000000000", big.NewFloat(math.Inf(1)), false}, - {"Negative infinity", "0xFFF0000000000000", big.NewFloat(math.Inf(-1)), false}, - {"Invalid hex value", "0xGGGGGGGGGGGGGGGG", big.NewFloat(0), true}, + { + name: "Valid hexadecimal with prefix", + hexString: "0x000000000000000000000000000000000000000000000000000000007751b728", + want: big.NewFloat(2001844008), + wantErr: false, + }, + { + name: "Valid hexadecimal without prefix", + hexString: "3FF0000000000000", + want: big.NewFloat(4607182418800017408), + wantErr: false, + }, + { + name: "Invalid hexadecimal string", + hexString: "0xInvalid", + want: big.NewFloat(0), + wantErr: true, + }, + { + name: "Large Hex String", + hexString: "0xFFFFFFFFFFFFFFFF", + want: big.NewFloat(18446744073709551615), + wantErr: false, + }, + { + name: "No Prefix Hex String", + hexString: "1a", + want: big.NewFloat(26), + wantErr: false, + }, + { + name: "Empty hexadecimal string", + hexString: "", + want: big.NewFloat(0), + wantErr: true, + }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { - result, err := ConvertHexToBigFloat(tt.hexString) - if tt.expectErr && err == nil { - t.Errorf("Expected an error but got none") - } else if !tt.expectErr && err != nil { - t.Errorf("Did not expect an error but got: %v", err) - } else if result.Cmp(tt.expected) != 0 { - t.Errorf("Expected %v but got %v", tt.expected, result) + got, err := ConvertHexToBigFloat(tt.hexString) + if (err != nil) != tt.wantErr { + t.Errorf("ConvertHexToBigFloat() error = %v, wantErr %v", err, tt.wantErr) + return + } + if !reflect.DeepEqual(got, tt.want) { + t.Errorf("ConvertHexToBigFloat() = %v, want %v", got, tt.want) } }) } From f85ece11cc9b431a3d3c20ef315f48ae2a6955b7 Mon Sep 17 00:00:00 2001 From: YashK Date: Tue, 28 Nov 2023 15:47:25 +0530 Subject: [PATCH 2/2] fix: convertToNumber tests fixed --- utils/math_test.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/utils/math_test.go b/utils/math_test.go index 4ae917b4e..60d73faaa 100644 --- a/utils/math_test.go +++ b/utils/math_test.go @@ -111,10 +111,10 @@ func TestConvertToNumber(t *testing.T) { { name: "Test hex value", args: args{ - num: "3FEF5C28F5C28F5C", + num: "0x000000000000000000000000000000000000000000000000002388bcf02787f1", returnType: "hex", }, - want: big.NewFloat(0.98), + want: big.NewFloat(10001969249224689), wantErr: false, }, {