How to use newColorable method of formatter Package

Best Ginkgo code snippet using formatter.newColorable

log.go

Source:log.go Github

copy

Full Screen

1package log2import (3 "errors"4 "fmt"5 "os"6 "path/filepath"7 "time"8 "github.com/mattn/go-colorable"9 log "github.com/sirupsen/logrus"10)11type logFileWriter struct {12 infoWriter *os.File13 debugWriter *os.File14 errorWriter *os.File15 warnWriter *os.File16 rootPath string17 fileDate string //日期18 entryLevel string19}20const (21 infoLevel = "info"22 debugLevel = "debug"23 errorLevel = "error"24 warnLevel = "warn"25)26var (27 fileWriter = &logFileWriter{rootPath: "./scopeLog", entryLevel: infoLevel}28 stdout = colorable.NewColorableStdout()29)30type LoggerFormat struct {31 logWriter *logFileWriter32}33func (s *LoggerFormat) Format(entry *log.Entry) ([]byte, error) {34 timestamp := time.Now().Local().Format("2006-01-02 15:04:05.000")35 var file string36 var length int37 if entry.Caller != nil {38 file = filepath.Base(entry.Caller.File)39 length = entry.Caller.Line40 }41 //d为1 表示高亮42 //red: (prefix=31,b=40,d=1)43 //green (f=32,b=40,d=1)44 //yellow (f=33,b=40,d=1)45 //cyan (f=34,b=40,d=1)46 var colorFomat string47 switch entry.Level {48 case log.DebugLevel:49 //cyan50 colorFomat = fmt.Sprintf("%c[%d;%d;%dm", 0x1B, 1, 1, 34)51 s.logWriter.entryLevel = debugLevel52 case log.InfoLevel:53 //green54 colorFomat = fmt.Sprintf("%c[%d;%d;%dm", 0x1B, 1, 1, 32)55 s.logWriter.entryLevel = infoLevel56 case log.ErrorLevel:57 //red [显示方式(1:高亮)、背景颜色(黑色:40)、颜色 ]58 colorFomat = fmt.Sprintf("%c[%d;%d;%dm", 0x1B, 1, 1, 31)59 s.logWriter.entryLevel = errorLevel60 case log.WarnLevel:61 //yellow62 colorFomat = fmt.Sprintf("%c[%d;%d;%dm", 0x1B, 1, 1, 33)63 s.logWriter.entryLevel = warnLevel64 }65 msg := fmt.Sprintf("%s[%s:] [%s:%d] %s \u001B[0m msg:%s \n", colorFomat, entry.Level.String(), file, length, timestamp, entry.Message)66 return []byte(msg), nil67}68func (p *logFileWriter) Write(data []byte) (n int, err error) {69 if p == nil {70 return 0, errors.New("logFileWriter is nil")71 }72 //判断是否需要切换日期73 fileDate := time.Now().Format("20060102")74 if p.fileDate != fileDate {75 switch p.entryLevel {76 case infoLevel:77 err = os.MkdirAll(fmt.Sprintf("%s/%s", p.rootPath, infoLevel), os.ModePerm)78 if err != nil {79 fmt.Errorf("%s\n", err.Error())80 return 0, err81 }82 infofileName := fmt.Sprintf("%s/%s/%s-%s.logger", p.rootPath, infoLevel, infoLevel, fileDate)83 p.infoWriter, err = os.OpenFile(infofileName, os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0600)84 checkError(err)85 writer := colorable.NewColorable(fileWriter.infoWriter)86 n, err = writer.Write(data)87 case errorLevel:88 err = os.MkdirAll(fmt.Sprintf("%s/%s", p.rootPath, errorLevel), os.ModePerm)89 if err != nil {90 fmt.Errorf("%s\n", err.Error())91 return 0, err92 }93 errorfileName := fmt.Sprintf("%s/%s/%s-%s.logger", p.rootPath, errorLevel, errorLevel, fileDate)94 p.errorWriter, err = os.OpenFile(errorfileName, os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0600)95 checkError(err)96 writer := colorable.NewColorable(fileWriter.errorWriter)97 n, err = writer.Write(data)98 case debugLevel:99 err = os.MkdirAll(fmt.Sprintf("%s/%s", p.rootPath, debugLevel), os.ModePerm)100 if err != nil {101 fmt.Errorf("%s\n", err.Error())102 return 0, err103 }104 debugfileName := fmt.Sprintf("%s/%s/%s-%s.logger", p.rootPath, debugLevel, debugLevel, fileDate)105 p.debugWriter, err = os.OpenFile(debugfileName, os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0600)106 checkError(err)107 writer := colorable.NewColorable(fileWriter.debugWriter)108 n, err = writer.Write(data)109 case warnLevel:110 err = os.MkdirAll(fmt.Sprintf("%s/%s", p.rootPath, warnLevel), os.ModePerm)111 if err != nil {112 fmt.Errorf("%s\n", err.Error())113 return 0, err114 }115 warnfileName := fmt.Sprintf("%s/%s/%s-%s.logger", p.rootPath, warnLevel, warnLevel, fileDate)116 p.warnWriter, err = os.OpenFile(warnfileName, os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0600)117 checkError(err)118 writer := colorable.NewColorable(fileWriter.warnWriter)119 n, err = writer.Write(data)120 default:121 fmt.Errorf("unexpected logger level")122 }123 }124 return125}126func checkError(err error) {127 if err != nil {128 fmt.Errorf("%s\n", err)129 return130 }131}132//初始化日志133func Init() {134 rootPath := "./scopeLog"135 log.SetLevel(log.DebugLevel)136 //创建目录137 err := os.MkdirAll(fmt.Sprintf("%s/%s", rootPath, infoLevel), os.ModePerm)138 checkError(err)139 err = os.MkdirAll(fmt.Sprintf("%s/%s", rootPath, errorLevel), os.ModePerm)140 checkError(err)141 err = os.MkdirAll(fmt.Sprintf("%s/%s", rootPath, debugLevel), os.ModePerm)142 checkError(err)143 err = os.MkdirAll(fmt.Sprintf("%s/%s", rootPath, warnLevel), os.ModePerm)144 checkError(err)145 log.SetFormatter(&LoggerFormat{146 logWriter: fileWriter,147 })148 log.SetReportCaller(true)149 log.SetOutput(fileWriter)150}...

Full Screen

Full Screen

formatter.go

Source:formatter.go Github

copy

Full Screen

...5 "regexp"6 "strings"7)8// ColorableStdOut and ColorableStdErr enable color output support on Windows9var ColorableStdOut = newColorable(os.Stdout)10var ColorableStdErr = newColorable(os.Stderr)11const COLS = 8012type ColorMode uint813const (14 ColorModeNone ColorMode = iota15 ColorModeTerminal16 ColorModePassthrough17)18var SingletonFormatter = New(ColorModeTerminal)19func F(format string, args ...interface{}) string {20 return SingletonFormatter.F(format, args...)21}22func Fi(indentation uint, format string, args ...interface{}) string {23 return SingletonFormatter.Fi(indentation, format, args...)24}...

Full Screen

Full Screen

newColorable

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 formatter := color.New(color.FgHiBlue)4 formatter.Printf("This is a %s5 log.SetOutput(colorable.NewColorable(formatter))6 log.Println("This is a formatted log entry")7}

Full Screen

Full Screen

newColorable

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 f := color.New(color.FgRed, color.Bold, color.Underline)4 fmt.Println(f.Sprintf("This is a %s", "formatted string"))5}6import (7func main() {8 f := color.New(color.FgRed, color.Bold, color.Underline)9 fmt.Println(f.Sprintf("This is a %s", "formatted string"))10}11import (12func main() {13 f := color.New(color.FgRed, color.Bold, color.Underline)14 fmt.Println(f.Sprintf("This is a %s", "formatted string"))15}16import (17func main() {18 f := color.New(color.FgRed, color.Bold, color.Underline)19 fmt.Println(f.Sprintf("This is a %s", "formatted string"))20}21import (22func main() {23 f := color.New(color.FgRed, color.Bold

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Run Ginkgo automation tests on LambdaTest cloud grid

Perform automation testing on 3000+ real desktop and mobile devices online.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful