()
| 212 | } |
| 213 | |
| 214 | func (l *JobLogger) Close() { |
| 215 | l.mu.Lock() |
| 216 | defer l.mu.Unlock() |
| 217 | |
| 218 | if l.isClosed { |
| 219 | return |
| 220 | } |
| 221 | |
| 222 | closer, ok := l.writer.(io.Closer) |
| 223 | if ok { |
| 224 | if err := closer.Close(); err != nil { |
| 225 | Errorf("failed to close writer, error: %s", err) |
| 226 | } |
| 227 | } |
| 228 | |
| 229 | if l.lumberjackLogger != nil { |
| 230 | if err := l.lumberjackLogger.Close(); err != nil { |
| 231 | Errorf("failed to close lumberjack logger, error: %s", err) |
| 232 | } |
| 233 | } |
| 234 | |
| 235 | err := l.logger.Sync() |
| 236 | if err != nil { |
| 237 | Errorf("failed to sync job logger, error: %s", err) |
| 238 | } |
| 239 | |
| 240 | l.isClosed = true |
| 241 | } |
| 242 | |
| 243 | func (l *JobLogger) Sync() { |
| 244 | l.mu.Lock() |
no test coverage detected