diff options
author | Péter Szilágyi <peterke@gmail.com> | 2017-03-06 21:00:20 +0800 |
---|---|---|
committer | Felix Lange <fjl@users.noreply.github.com> | 2017-03-09 22:50:14 +0800 |
commit | df72e20cc521b43092b9e3cc684836d4d673e126 (patch) | |
tree | f158ca0f28a404f1798133daeddb8af9b0bbe920 /pow/ethash_algo_go1.8_test.go | |
parent | 023670f6bafcfed28c01857da215217a5dadfaa1 (diff) | |
download | dexon-df72e20cc521b43092b9e3cc684836d4d673e126.tar dexon-df72e20cc521b43092b9e3cc684836d4d673e126.tar.gz dexon-df72e20cc521b43092b9e3cc684836d4d673e126.tar.bz2 dexon-df72e20cc521b43092b9e3cc684836d4d673e126.tar.lz dexon-df72e20cc521b43092b9e3cc684836d4d673e126.tar.xz dexon-df72e20cc521b43092b9e3cc684836d4d673e126.tar.zst dexon-df72e20cc521b43092b9e3cc684836d4d673e126.zip |
pow: only support prime calculations on Go 1.8 and above
Diffstat (limited to 'pow/ethash_algo_go1.8_test.go')
-rw-r--r-- | pow/ethash_algo_go1.8_test.go | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/pow/ethash_algo_go1.8_test.go b/pow/ethash_algo_go1.8_test.go new file mode 100644 index 000000000..57e0b0b7a --- /dev/null +++ b/pow/ethash_algo_go1.8_test.go @@ -0,0 +1,46 @@ +// Copyright 2017 The go-ethereum Authors +// This file is part of the go-ethereum library. +// +// The go-ethereum 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 go-ethereum 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 go-ethereum library. If not, see <http://www.gnu.org/licenses/>. + +// +build go1.8 + +package pow + +import "testing" + +// Tests whether the dataset size calculator work correctly by cross checking the +// hard coded lookup table with the value generated by it. +func TestSizeCalculations(t *testing.T) { + var tests []uint64 + + // Verify all the cache sizes from the lookup table + defer func(sizes []uint64) { cacheSizes = sizes }(cacheSizes) + tests, cacheSizes = cacheSizes, []uint64{} + + for i, test := range tests { + if size := cacheSize(uint64(i*epochLength) + 1); size != test { + t.Errorf("cache %d: cache size mismatch: have %d, want %d", i, size, test) + } + } + // Verify all the dataset sizes from the lookup table + defer func(sizes []uint64) { datasetSizes = sizes }(datasetSizes) + tests, datasetSizes = datasetSizes, []uint64{} + + for i, test := range tests { + if size := datasetSize(uint64(i*epochLength) + 1); size != test { + t.Errorf("dataset %d: dataset size mismatch: have %d, want %d", i, size, test) + } + } +} |