Skip to content
Snippets Groups Projects
Select Git revision
  • 24eb354b1d6fd83d63447e6d4dbcfd5d9fed8fb1
  • release default protected
  • 11-22-implement-kv-interface-defined-in-collectiveversionedkvgo
  • hotfix/TestHostPool_UpdateNdf_AddFilter
  • XX-4719/announcementChannels
  • xx-4717/logLevel
  • jonah/noob-channel
  • master protected
  • XX-4707/tagDiskJson
  • xx-4698/notification-retry
  • hotfix/notifylockup
  • syncNodes
  • hotfix/localCB
  • XX-4677/NewChanManagerMobile
  • XX-4689/DmSync
  • duplicatePrefix
  • XX-4601/HavenInvites
  • finalizedUICallbacks
  • XX-4673/AdminKeySync
  • debugNotifID
  • anne/test
  • v4.7.5
  • v4.7.4
  • v4.7.3
  • v4.7.2
  • v4.7.1
  • v4.6.3
  • v4.6.1
  • v4.5.0
  • v4.4.4
  • v4.3.11
  • v4.3.8
  • v4.3.7
  • v4.3.6
  • v4.3.5
  • v4.2.0
  • v4.3.0
  • v4.3.4
  • v4.3.3
  • v4.3.2
  • v4.3.1
41 results

mutateTimestamp_test.go

  • user avatar
    Benjamin Wenger authored
    e442a896
    History
    mutateTimestamp_test.go 1.40 KiB
    ////////////////////////////////////////////////////////////////////////////////
    // Copyright © 2022 xx foundation                                             //
    //                                                                            //
    // Use of this source code is governed by a license that can be found in the  //
    // LICENSE file                                                               //
    ////////////////////////////////////////////////////////////////////////////////
    
    package channels
    
    import (
    	"math/rand"
    	"testing"
    	"time"
    
    	"gitlab.com/elixxir/crypto/channel"
    )
    
    // withinMutationWindow is a utility test function to check if a mutated
    // timestamp is within the allowable window
    func withinMutationWindow(raw, mutated time.Time) bool {
    	lowerBound := raw.Add(-time.Duration(halfTenMsInNs))
    	upperBound := raw.Add(time.Duration(halfTenMsInNs))
    
    	return mutated.After(lowerBound) && mutated.Before(upperBound)
    }
    
    func abs(n int64) int64 {
    	if n < 0 {
    		return -n
    	}
    	return n
    }
    
    func TestMutateTimestampDeltaAverage(t *testing.T) {
    	samples := 10000
    	t1 := time.Now()
    	sum := int64(0)
    
    	rng := rand.New(rand.NewSource(time.Now().UnixNano()))
    
    	for i := 0; i < samples; i++ {
    		var msgID channel.MessageID
    		rng.Read(msgID[:])
    		t2 := mutateTimestamp(t1, msgID)
    		delta := t2.Sub(t1)
    		sum += abs(int64(delta))
    	}
    
    	avg := sum / int64(samples)
    	diff := abs(avg - 2502865)
    	if diff > 30000 {
    		t.Fatal()
    	}
    }