You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

66 lines
1.9 KiB

  1. // Copyright 2017-2018 DERO Project. All rights reserved.
  2. // Use of this source code in any form is governed by RESEARCH license.
  3. // license can be found in the LICENSE file.
  4. // GPG: 0F39 E425 8C65 3947 702A 8234 08B2 0360 A03A 9DE8
  5. //
  6. //
  7. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
  8. // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  9. // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
  10. // THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  11. // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  12. // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  13. // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  14. // STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  15. // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  16. package blockchain
  17. import "testing"
  18. // these tests have been taken from the test_math.h from epee tests
  19. func Test_Median(t *testing.T) {
  20. { // test with 0 elements
  21. var array []uint64
  22. if Median(array) != 0 {
  23. t.Errorf("Testing failed\n")
  24. }
  25. }
  26. { // test with 1 element
  27. array := []uint64{1}
  28. if Median(array) != 1 {
  29. t.Errorf("Testing failed\n")
  30. }
  31. }
  32. { // test with 2 element
  33. array := []uint64{1, 10}
  34. if Median(array) != 5 {
  35. t.Errorf("Testing failed\n")
  36. }
  37. }
  38. { // test with 3 element
  39. array := []uint64{0, 9, 3}
  40. if Median(array) != 3 {
  41. t.Errorf("Testing failed\n")
  42. }
  43. }
  44. { // test with 4 element
  45. array := []uint64{77, 9, 22, 60}
  46. if Median(array) != 41 {
  47. t.Errorf("Testing failed\n")
  48. }
  49. }
  50. { // test with 5 element
  51. array := []uint64{77, 9, 22, 60, 11}
  52. if Median(array) != 22 {
  53. t.Errorf("Testing failed\n")
  54. }
  55. }
  56. }