| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | package ethlog | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"io/ioutil" | 
					
						
							|  |  |  | 	"os" | 
					
						
							|  |  |  | 	"testing" | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type TestLogSystem struct { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	Output string | 
					
						
							|  |  |  | 	level  LogLevel | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (t *TestLogSystem) Println(v ...interface{}) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	t.Output += fmt.Sprintln(v...) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (t *TestLogSystem) Printf(format string, v ...interface{}) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	t.Output += fmt.Sprintf(format, v...) | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (t *TestLogSystem) SetLogLevel(i LogLevel) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	t.level = i | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (t *TestLogSystem) GetLogLevel() LogLevel { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	return t.level | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | func quote(s string) string { | 
					
						
							|  |  |  | 	return fmt.Sprintf("'%s'", s) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | func TestLoggerPrintln(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	logger := NewLogger("TEST") | 
					
						
							|  |  |  | 	testLogSystem := &TestLogSystem{level: WarnLevel} | 
					
						
							|  |  |  | 	AddLogSystem(testLogSystem) | 
					
						
							|  |  |  | 	logger.Errorln("error") | 
					
						
							|  |  |  | 	logger.Warnln("warn") | 
					
						
							|  |  |  | 	logger.Infoln("info") | 
					
						
							|  |  |  | 	logger.Debugln("debug") | 
					
						
							|  |  |  | 	Flush() | 
					
						
							|  |  |  | 	output := testLogSystem.Output | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | 	fmt.Println(quote(output)) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	if output != "[TEST] error\n[TEST] warn\n" { | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | 		t.Error("Expected logger output '[TEST] error\\n[TEST] warn\\n', got ", quote(testLogSystem.Output)) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestLoggerPrintf(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	logger := NewLogger("TEST") | 
					
						
							|  |  |  | 	testLogSystem := &TestLogSystem{level: WarnLevel} | 
					
						
							|  |  |  | 	AddLogSystem(testLogSystem) | 
					
						
							|  |  |  | 	logger.Errorf("error to %v\n", *testLogSystem) | 
					
						
							|  |  |  | 	logger.Warnf("warn") | 
					
						
							|  |  |  | 	logger.Infof("info") | 
					
						
							|  |  |  | 	logger.Debugf("debug") | 
					
						
							|  |  |  | 	Flush() | 
					
						
							|  |  |  | 	output := testLogSystem.Output | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | 	fmt.Println(quote(output)) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	if output != "[TEST] error to { 2}\n[TEST] warn" { | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | 		t.Error("Expected logger output '[TEST] error to { 2}\\n[TEST] warn', got ", quote(testLogSystem.Output)) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestMultipleLogSystems(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	logger := NewLogger("TEST") | 
					
						
							|  |  |  | 	testLogSystem0 := &TestLogSystem{level: ErrorLevel} | 
					
						
							|  |  |  | 	testLogSystem1 := &TestLogSystem{level: WarnLevel} | 
					
						
							|  |  |  | 	AddLogSystem(testLogSystem0) | 
					
						
							|  |  |  | 	AddLogSystem(testLogSystem1) | 
					
						
							|  |  |  | 	logger.Errorln("error") | 
					
						
							|  |  |  | 	logger.Warnln("warn") | 
					
						
							|  |  |  | 	Flush() | 
					
						
							|  |  |  | 	output0 := testLogSystem0.Output | 
					
						
							|  |  |  | 	output1 := testLogSystem1.Output | 
					
						
							|  |  |  | 	if output0 != "[TEST] error\n" { | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | 		t.Error("Expected logger 0 output '[TEST] error\\n', got ", quote(testLogSystem0.Output)) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if output1 != "[TEST] error\n[TEST] warn\n" { | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | 		t.Error("Expected logger 1 output '[TEST] error\\n[TEST] warn\\n', got ", quote(testLogSystem1.Output)) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestFileLogSystem(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	logger := NewLogger("TEST") | 
					
						
							|  |  |  | 	filename := "test.log" | 
					
						
							|  |  |  | 	file, _ := os.OpenFile(filename, os.O_RDWR|os.O_CREATE, os.ModePerm) | 
					
						
							|  |  |  | 	testLogSystem := NewStdLogSystem(file, 0, WarnLevel) | 
					
						
							|  |  |  | 	AddLogSystem(testLogSystem) | 
					
						
							|  |  |  | 	logger.Errorf("error to %s\n", filename) | 
					
						
							|  |  |  | 	logger.Warnln("warn") | 
					
						
							|  |  |  | 	Flush() | 
					
						
							|  |  |  | 	contents, _ := ioutil.ReadFile(filename) | 
					
						
							|  |  |  | 	output := string(contents) | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | 	fmt.Println(quote(output)) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	if output != "[TEST] error to test.log\n[TEST] warn\n" { | 
					
						
							| 
									
										
										
										
											2014-07-07 10:59:16 +02:00
										 |  |  | 		t.Error("Expected contents of file 'test.log': '[TEST] error to test.log\\n[TEST] warn\\n', got ", quote(output)) | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		os.Remove(filename) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestNoLogSystem(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2014-06-26 18:45:57 +01:00
										 |  |  | 	logger := NewLogger("TEST") | 
					
						
							|  |  |  | 	logger.Warnln("warn") | 
					
						
							|  |  |  | 	Flush() | 
					
						
							| 
									
										
										
										
											2014-06-23 12:49:04 +01:00
										 |  |  | } |