Slight fixes to NewChannel and tests for st's Channel methods.

This commit is contained in:
Alex Bramley 2011-10-13 22:31:09 +01:00
parent 9163b9af7a
commit 6266eba245
2 changed files with 81 additions and 0 deletions

View File

@ -88,6 +88,10 @@ func (st *stateTracker) DelNick(n string) {
// Creates a new Channel, initialises it, and stores it so it // Creates a new Channel, initialises it, and stores it so it
// can be properly tracked for state management purposes. // can be properly tracked for state management purposes.
func (st *stateTracker) NewChannel(c string) *Channel { func (st *stateTracker) NewChannel(c string) *Channel {
if _, ok := st.chans[c]; ok {
logging.Warn("StateTracker.NewChannel(): %s already tracked", c)
return nil
}
ch := &Channel{Name: c, st: st} ch := &Channel{Name: c, st: st}
ch.initialise() ch.initialise()
st.chans[c] = ch st.chans[c] = ch

View File

@ -99,3 +99,80 @@ func TestDelNick(t *testing.T) {
t.Errorf("DelNick had unexpected side-effects.") t.Errorf("DelNick had unexpected side-effects.")
} }
} }
func TestNewChannel(t *testing.T) {
st := NewTracker()
if len(st.chans) != 0 {
t.Errorf("Channel list of new tracker is non-zero length.")
}
test1 := st.NewChannel("#test1")
if test1 == nil || test1.Name != "#test1" || test1.st != st {
t.Errorf("Channel object created incorrectly by NewChannel.")
}
if c, ok := st.chans["#test1"]; !ok || c != test1 || len(st.chans) != 1 {
t.Errorf("Channel object stored incorrectly by NewChannel.")
}
if fail := st.NewChannel("#test1"); fail != nil {
t.Errorf("Creating duplicate chan did not produce nil return.")
}
}
func TestGetChannel(t *testing.T) {
st := NewTracker()
test1 := &Channel{Name: "#test1", st: st}
st.chans["#test1"] = test1
if c := st.GetChannel("#test1"); c != test1 {
t.Errorf("Incorrect Channel returned by GetChannel.")
}
if c := st.GetChannel("#test2"); c != nil {
t.Errorf("Channel unexpectedly returned by GetChannel.")
}
if len(st.chans) != 1 {
t.Errorf("Channel list changed size during GetChannel.")
}
}
func TestDelChannel(t *testing.T) {
st := NewTracker()
test1 := &Channel{Name: "#test1", st: st}
st.chans["#test1"] = test1
st.DelChannel("#test1")
if _, ok := st.chans["#test1"]; ok {
t.Errorf("Channel test1 still exists after DelChannel.")
}
if len(st.chans) != 0 {
t.Errorf("Channel list still contains chans after DelChannel.")
}
st.chans["#test1"] = test1
st.DelChannel("test2")
if len(st.chans) != 1 {
t.Errorf("DelChannel had unexpected side-effects.")
}
}
func TestIsOn(t *testing.T) {
st := NewTracker()
nick1 := st.NewNick("test1")
chan1 := st.NewChannel("#test1")
if st.IsOn("#test1", "test1") {
t.Errorf("test1 is not on #test1 (yet)")
}
chan1.AddNick(nick1)
if !st.IsOn("#test1", "test1") {
t.Errorf("test1 is on #test1 (now)")
}
}