Skip to content
Snippets Groups Projects
Select Git revision
  • 0f3adb84d3d78a1aa1e805c06a7c83221453341b
  • 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

remoteFilters_test.go

Blame
  • remoteFilters_test.go 2.71 KiB
    ////////////////////////////////////////////////////////////////////////////////
    // Copyright © 2022 xx foundation                                             //
    //                                                                            //
    // Use of this source code is governed by a license that can be found in the  //
    // LICENSE file.                                                              //
    ////////////////////////////////////////////////////////////////////////////////
    
    package cmix
    
    import (
    	jww "github.com/spf13/jwalterweatherman"
    	bloom "gitlab.com/elixxir/bloomfilter"
    	"gitlab.com/elixxir/comms/mixmessages"
    	"gitlab.com/xx_network/comms/connect"
    	"gitlab.com/xx_network/primitives/id"
    	"os"
    	"reflect"
    	"testing"
    )
    
    func TestMain(m *testing.M) {
    	jww.SetStdoutThreshold(jww.LevelDebug)
    	connect.TestingOnlyDisableTLS = true
    	os.Exit(m.Run())
    }
    
    // Unit test NewRemoteFilter.
    func TestNewRemoteFilter(t *testing.T) {
    	bloomFilter := &mixmessages.ClientBloom{
    		Filter:     nil,
    		FirstRound: 0,
    		RoundRange: 0,
    	}
    
    	rf := NewRemoteFilter(bloomFilter)
    	if !reflect.DeepEqual(rf.data, bloomFilter) {
    		t.Fatalf("RemoteFilter not initialized as expected."+
    			"\nexpected: %+v\nreceived: %+v", bloomFilter, rf.data)
    	}
    }
    
    // Unit test RemoteFilter.GetFilter.
    func TestRemoteFilter_GetFilter(t *testing.T) {
    	testFilter, err := bloom.InitByParameters(BloomFilterSize,
    		BloomFilterHashes)
    	if err != nil {
    		t.Fatalf("Cannot initialize bloom filter for setup: %+v", err)
    	}
    
    	data, err := testFilter.MarshalBinary()
    	if err != nil {
    		t.Fatalf("Cannot marshal filter for setup: %+v", err)
    	}
    
    	bloomFilter := &mixmessages.ClientBloom{
    		Filter:     data,
    		FirstRound: 0,
    		RoundRange: 0,
    	}
    
    	rf := NewRemoteFilter(bloomFilter)
    	retrievedFilter := rf.GetFilter()
    	if !reflect.DeepEqual(retrievedFilter, testFilter) {
    		t.Fatalf("Did not retrieve expected filter."+
    			"\nexpected: %+v\nreceived: %+v", testFilter, retrievedFilter)
    	}
    }
    
    // Unit test for RemoteFilter.FirstRound and RemoteFilter.LastRound.
    func TestRemoteFilter_FirstRound_LastRound(t *testing.T) {