aboutsummaryrefslogtreecommitdiffstats
path: root/core/utils
diff options
context:
space:
mode:
authorMission Liao <mission.liao@dexon.org>2018-12-18 16:51:29 +0800
committerGitHub <noreply@github.com>2018-12-18 16:51:29 +0800
commiteaf271f8e4d16920d8575cf77c65ece2960444d0 (patch)
treef16137dc83613f306278141886a390de94f906a5 /core/utils
parent9f240d93507cdf03935ba7e4e3a7b226f150736d (diff)
downloadtangerine-consensus-eaf271f8e4d16920d8575cf77c65ece2960444d0.tar
tangerine-consensus-eaf271f8e4d16920d8575cf77c65ece2960444d0.tar.gz
tangerine-consensus-eaf271f8e4d16920d8575cf77c65ece2960444d0.tar.bz2
tangerine-consensus-eaf271f8e4d16920d8575cf77c65ece2960444d0.tar.lz
tangerine-consensus-eaf271f8e4d16920d8575cf77c65ece2960444d0.tar.xz
tangerine-consensus-eaf271f8e4d16920d8575cf77c65ece2960444d0.tar.zst
tangerine-consensus-eaf271f8e4d16920d8575cf77c65ece2960444d0.zip
misc: panic not ready (#374)
* Panic when config/crs not ready For those calls to Governace.Configuration and Governance.CRS without checking returns, replace those calls with these newly added helpers: - utils.GetConfigurationWithPanic - utils.GetCRSWithPanic They would check returns, and panic directly if not ready yet. * Fix a bug that config is not ready when syncing
Diffstat (limited to 'core/utils')
-rw-r--r--core/utils/utils.go61
1 files changed, 61 insertions, 0 deletions
diff --git a/core/utils/utils.go b/core/utils/utils.go
new file mode 100644
index 0000000..3e3803d
--- /dev/null
+++ b/core/utils/utils.go
@@ -0,0 +1,61 @@
+// This file is part of the dexon-consensus library.
+//
+// The dexon-consensus library is free software: you can redistribute it
+// and/or modify it under the terms of the GNU Lesser General Public License as
+// published by the Free Software Foundation, either version 3 of the License,
+// or (at your option) any later version.
+//
+// The dexon-consensus library is distributed in the hope that it will be
+// useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
+// General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public License
+// along with the dexon-consensus library. If not, see
+// <http://www.gnu.org/licenses/>.
+
+package utils
+
+import (
+ "fmt"
+
+ "github.com/dexon-foundation/dexon-consensus/common"
+ "github.com/dexon-foundation/dexon-consensus/core/types"
+)
+
+type configAccessor interface {
+ Configuration(round uint64) *types.Config
+}
+
+// GetConfigWithPanic is a helper to access configs, and panic when config for
+// that round is not ready yet.
+func GetConfigWithPanic(accessor configAccessor, round uint64,
+ logger common.Logger) *types.Config {
+ if logger != nil {
+ logger.Debug("Calling Governance.Configuration", "round", round)
+ }
+ c := accessor.Configuration(round)
+ if c == nil {
+ panic(fmt.Errorf("configuration is not ready %v", round))
+ }
+ return c
+}
+
+type crsAccessor interface {
+ CRS(round uint64) common.Hash
+}
+
+// GetCRSWithPanic is a helper to access CRS, and panic when CRS for that
+// round is not ready yet.
+func GetCRSWithPanic(accessor crsAccessor, round uint64,
+ logger common.Logger) common.Hash {
+ if logger != nil {
+ logger.Debug("Calling Governance.CRS", "round", round)
+ }
+ crs := accessor.CRS(round)
+ if (crs == common.Hash{}) {
+ panic(fmt.Errorf("CRS is not ready %v", round))
+ }
+ return crs
+
+}