mirror of
https://github.com/JetSetIlly/Gopher2600.git
synced 2024-05-20 13:48:02 -04:00
65 lines
1.9 KiB
Go
65 lines
1.9 KiB
Go
// This file is part of Gopher2600.
|
|
//
|
|
// Gopher2600 is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Gopher2600 is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Gopher2600. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package logger_test
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/jetsetilly/gopher2600/logger"
|
|
"github.com/jetsetilly/gopher2600/test"
|
|
)
|
|
|
|
func TestLogger(t *testing.T) {
|
|
tw := &test.Writer{}
|
|
|
|
logger.Write(tw)
|
|
test.ExpectEquality(t, tw.Compare(""), true)
|
|
|
|
logger.Log("test", "this is a test")
|
|
logger.Write(tw)
|
|
test.ExpectEquality(t, tw.Compare("test: this is a test\n"), true)
|
|
|
|
// clear the test.Writer buffer before continuing, makes comparisons easier
|
|
// to manage
|
|
tw.Clear()
|
|
|
|
logger.Log("test2", "this is another test")
|
|
logger.Write(tw)
|
|
test.ExpectEquality(t, tw.Compare("test: this is a test\ntest2: this is another test\n"), true)
|
|
|
|
// asking for too many entries in a Tail() should be okay
|
|
tw.Clear()
|
|
logger.Tail(tw, 100)
|
|
fmt.Println(tw)
|
|
test.ExpectEquality(t, tw.Compare("test: this is a test\ntest2: this is another test\n"), true)
|
|
|
|
// asking for exactly the correct number of entries is okay
|
|
tw.Clear()
|
|
logger.Tail(tw, 2)
|
|
test.ExpectEquality(t, tw.Compare("test: this is a test\ntest2: this is another test\n"), true)
|
|
|
|
// asking for fewer entries is okay too
|
|
tw.Clear()
|
|
logger.Tail(tw, 1)
|
|
test.ExpectEquality(t, tw.Compare("test2: this is another test\n"), true)
|
|
|
|
// and no entries
|
|
tw.Clear()
|
|
logger.Tail(tw, 0)
|
|
test.ExpectEquality(t, tw.Compare(""), true)
|
|
}
|