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

garbled.go

Blame
  • single_test.go 2.54 KiB
    ///////////////////////////////////////////////////////////////////////////////
    // Copyright © 2020 xx network SEZC                                          //
    //                                                                           //
    // Use of this source code is governed by a license that can be found in the //
    // LICENSE file                                                              //
    ///////////////////////////////////////////////////////////////////////////////
    
    package stoppable
    
    import (
    	"testing"
    	"time"
    )
    
    // Tests happy path of NewSingle().
    func TestNewSingle(t *testing.T) {
    	name := "test name"
    	single := NewSingle(name)
    
    	if single.name != name || single.running != 1 {
    		t.Errorf("NewSingle() returned Single with incorrect values."+
    			"\n\texpected:  name: %s  running: %d\n\treceived:  name: %s  running: %d",
    			name, 1, single.name, single.running)
    	}
    }
    
    // Tests happy path of Single.IsRunning().
    func TestSingle_IsRunning(t *testing.T) {
    	single := NewSingle("name")
    
    	if !single.IsRunning() {
    		t.Errorf("IsRunning() returned false when it should be running.")
    	}
    
    	single.running = 0
    	if single.IsRunning() {
    		t.Errorf("IsRunning() returned true when it should not be running.")
    	}
    }
    
    // Tests happy path of Single.Quit().
    func TestSingle_Quit(t *testing.T) {
    	single := NewSingle("name")
    
    	go func() {
    		time.Sleep(150 * time.Nanosecond)
    		single.quit <- struct{}{}
    	}()
    
    	timer := time.NewTimer(2 * time.Millisecond)
    	select {
    	case <-timer.C:
    		t.Errorf("Quit signal not received.")
    	case <-single.quit:
    	}
    }
    
    // Tests happy path of Single.Name().
    func TestSingle_Name(t *testing.T) {
    	name := "test name"
    	single := NewSingle(name)
    
    	if name != single.Name() {
    		t.Errorf("Name() returned the incorrect string."+
    			"\n\texpected: %s\n\treceived: %s", name, single.Name())
    	}
    }
    
    // Test happy path of Single.Close().
    func TestSingle_Close(t *testing.T) {
    	single := NewSingle("name")
    
    	go func() {
    		time.Sleep(150 * time.Nanosecond)
    		select {
    		case <-single.quit:
    		}
    	}()
    
    	err := single.Close(5 * time.Millisecond)
    	if err != nil {
    		t.Errorf("Close() returned an error: %v", err)
    	}
    }
    
    // Tests that Single.Close() returns an error when the timeout is reached.
    func TestSingle_Close_Error(t *testing.T) {
    	single := NewSingle("name")
    	expectedErr := single.name + " failed to close"
    
    	go func() {
    		time.Sleep(3 * time.Millisecond)
    		select {
    		case <-single.quit:
    		}
    	}()
    
    	err := single.Close(2 * time.Millisecond)
    	if err == nil {
    		t.Errorf("Close() did not return the expected error."+
    			"\n\texpected: %v\n\treceived: %v", expectedErr, err)
    	}
    }