mirror of
https://github.com/wnagrodzki/SwiftLogger.git
synced 2025-04-06 12:31:51 +02:00
Rename FileRotate to LogrotateImpl. Move Logrotate to Logrotate.swift
This commit is contained in:
parent
bdbd615ea4
commit
81393b67da
4 changed files with 36 additions and 36 deletions
|
@ -16,11 +16,11 @@
|
|||
2EBF4B4C2122AF53008E4117 /* NullLogger.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EBF4B492122AF53008E4117 /* NullLogger.swift */; };
|
||||
2EBF4B572122B598008E4117 /* DiskLogger.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EBF4B542122B598008E4117 /* DiskLogger.swift */; };
|
||||
2EBF4B582122B598008E4117 /* SizeLimitedFile.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EBF4B552122B598008E4117 /* SizeLimitedFile.swift */; };
|
||||
2EBF4B592122B598008E4117 /* FileRotate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EBF4B562122B598008E4117 /* FileRotate.swift */; };
|
||||
2EBF4B592122B598008E4117 /* Logrotate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EBF4B562122B598008E4117 /* Logrotate.swift */; };
|
||||
2ED077D721329CA30058EEFC /* LoggetTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ED077D621329CA30058EEFC /* LoggetTests.swift */; };
|
||||
2ED077D92132A4820058EEFC /* AgregateLoggerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ED077D82132A4820058EEFC /* AgregateLoggerTests.swift */; };
|
||||
2ED077DB2132B0320058EEFC /* FileSystem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ED077DA2132B0320058EEFC /* FileSystem.swift */; };
|
||||
2ED103E12135C61100EB3683 /* FileRotateTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ED103E02135C61100EB3683 /* FileRotateTests.swift */; };
|
||||
2ED103E12135C61100EB3683 /* LogrotateTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ED103E02135C61100EB3683 /* LogrotateTests.swift */; };
|
||||
2ED103E32135D3FB00EB3683 /* SizeLimitedFileTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ED103E22135D3FB00EB3683 /* SizeLimitedFileTests.swift */; };
|
||||
2ED103E52138553B00EB3683 /* DiskLoggerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ED103E42138553B00EB3683 /* DiskLoggerTests.swift */; };
|
||||
/* End PBXBuildFile section */
|
||||
|
@ -59,11 +59,11 @@
|
|||
2EBF4B492122AF53008E4117 /* NullLogger.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = NullLogger.swift; sourceTree = "<group>"; };
|
||||
2EBF4B542122B598008E4117 /* DiskLogger.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = DiskLogger.swift; sourceTree = "<group>"; };
|
||||
2EBF4B552122B598008E4117 /* SizeLimitedFile.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = SizeLimitedFile.swift; sourceTree = "<group>"; };
|
||||
2EBF4B562122B598008E4117 /* FileRotate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = FileRotate.swift; sourceTree = "<group>"; };
|
||||
2EBF4B562122B598008E4117 /* Logrotate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Logrotate.swift; sourceTree = "<group>"; };
|
||||
2ED077D621329CA30058EEFC /* LoggetTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LoggetTests.swift; sourceTree = "<group>"; };
|
||||
2ED077D82132A4820058EEFC /* AgregateLoggerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AgregateLoggerTests.swift; sourceTree = "<group>"; };
|
||||
2ED077DA2132B0320058EEFC /* FileSystem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FileSystem.swift; sourceTree = "<group>"; };
|
||||
2ED103E02135C61100EB3683 /* FileRotateTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FileRotateTests.swift; sourceTree = "<group>"; };
|
||||
2ED103E02135C61100EB3683 /* LogrotateTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LogrotateTests.swift; sourceTree = "<group>"; };
|
||||
2ED103E22135D3FB00EB3683 /* SizeLimitedFileTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SizeLimitedFileTests.swift; sourceTree = "<group>"; };
|
||||
2ED103E42138553B00EB3683 /* DiskLoggerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DiskLoggerTests.swift; sourceTree = "<group>"; };
|
||||
2EDA8AE8213ACCFF00FE5840 /* README.md */ = {isa = PBXFileReference; lastKnownFileType = net.daringfireball.markdown; path = README.md; sourceTree = "<group>"; };
|
||||
|
@ -96,7 +96,7 @@
|
|||
2ED077D82132A4820058EEFC /* AgregateLoggerTests.swift */,
|
||||
2ED103E42138553B00EB3683 /* DiskLoggerTests.swift */,
|
||||
2ED103E22135D3FB00EB3683 /* SizeLimitedFileTests.swift */,
|
||||
2ED103E02135C61100EB3683 /* FileRotateTests.swift */,
|
||||
2ED103E02135C61100EB3683 /* LogrotateTests.swift */,
|
||||
2E58D35E21316C3500BEF81A /* Info.plist */,
|
||||
);
|
||||
path = UnitTests;
|
||||
|
@ -147,7 +147,7 @@
|
|||
children = (
|
||||
2EBF4B542122B598008E4117 /* DiskLogger.swift */,
|
||||
2EBF4B552122B598008E4117 /* SizeLimitedFile.swift */,
|
||||
2EBF4B562122B598008E4117 /* FileRotate.swift */,
|
||||
2EBF4B562122B598008E4117 /* Logrotate.swift */,
|
||||
2ED077DA2132B0320058EEFC /* FileSystem.swift */,
|
||||
);
|
||||
path = DiskLogger;
|
||||
|
@ -249,7 +249,7 @@
|
|||
2ED103E32135D3FB00EB3683 /* SizeLimitedFileTests.swift in Sources */,
|
||||
2ED103E52138553B00EB3683 /* DiskLoggerTests.swift in Sources */,
|
||||
2ED077D92132A4820058EEFC /* AgregateLoggerTests.swift in Sources */,
|
||||
2ED103E12135C61100EB3683 /* FileRotateTests.swift in Sources */,
|
||||
2ED103E12135C61100EB3683 /* LogrotateTests.swift in Sources */,
|
||||
2ED077D721329CA30058EEFC /* LoggetTests.swift in Sources */,
|
||||
);
|
||||
runOnlyForDeploymentPostprocessing = 0;
|
||||
|
@ -265,7 +265,7 @@
|
|||
2EBF4B4B2122AF53008E4117 /* ConsoleLogger.swift in Sources */,
|
||||
2ED077DB2132B0320058EEFC /* FileSystem.swift in Sources */,
|
||||
2EBF4B4A2122AF53008E4117 /* AgregateLogger.swift in Sources */,
|
||||
2EBF4B592122B598008E4117 /* FileRotate.swift in Sources */,
|
||||
2EBF4B592122B598008E4117 /* Logrotate.swift in Sources */,
|
||||
2EBF4B452122ACD6008E4117 /* LogStringConvertible.swift in Sources */,
|
||||
);
|
||||
runOnlyForDeploymentPostprocessing = 0;
|
||||
|
|
|
@ -35,20 +35,6 @@ protocol SizeLimitedFileFactory {
|
|||
func makeInstance(fileURL: URL, fileSizeLimit: UInt64) throws -> SizeLimitedFile
|
||||
}
|
||||
|
||||
/// Allows log files rotation.
|
||||
protocol Logrotate {
|
||||
|
||||
/// Rotates log files `rotations` number of times.
|
||||
///
|
||||
/// First deletes file at `<fileURL>.<rotations>`.
|
||||
/// Next moves files located at:
|
||||
///
|
||||
/// `<fileURL>, <fileURL>.1, <fileURL>.2 ... <fileURL>.<rotations - 1>`
|
||||
///
|
||||
/// to `<fileURL>.1, <fileURL>.2 ... <fileURL>.<rotations>`
|
||||
func rotate() throws
|
||||
}
|
||||
|
||||
protocol LogrotateFactory {
|
||||
|
||||
/// Returns newly initialized Logrotate instance.
|
||||
|
@ -151,7 +137,7 @@ public final class DiskLogger: Logger {
|
|||
|
||||
private class FileRotateFactory: LogrotateFactory {
|
||||
func makeInstance(fileURL: URL, rotations: Int) -> Logrotate {
|
||||
return FileRotate(fileURL: fileURL, rotations: rotations, fileSystem: FileManager.default)
|
||||
return LogrotateImpl(fileURL: fileURL, rotations: rotations, fileSystem: FileManager.default)
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -24,7 +24,21 @@
|
|||
|
||||
import Foundation
|
||||
|
||||
final class FileRotate {
|
||||
/// Allows log files rotation.
|
||||
protocol Logrotate {
|
||||
|
||||
/// Rotates log files `rotations` number of times.
|
||||
///
|
||||
/// First deletes file at `<fileURL>.<rotations>`.
|
||||
/// Next moves files located at:
|
||||
///
|
||||
/// `<fileURL>, <fileURL>.1, <fileURL>.2 ... <fileURL>.<rotations - 1>`
|
||||
///
|
||||
/// to `<fileURL>.1, <fileURL>.2 ... <fileURL>.<rotations>`
|
||||
func rotate() throws
|
||||
}
|
||||
|
||||
final class LogrotateImpl {
|
||||
|
||||
private let fileURL: URL
|
||||
private let rotations: Int
|
||||
|
@ -43,7 +57,7 @@ final class FileRotate {
|
|||
}
|
||||
}
|
||||
|
||||
extension FileRotate: Logrotate {
|
||||
extension LogrotateImpl: Logrotate {
|
||||
|
||||
func rotate() throws {
|
||||
let range = 1...rotations
|
|
@ -25,7 +25,7 @@
|
|||
import XCTest
|
||||
@testable import Logger
|
||||
|
||||
class FileRotateTests: XCTestCase {
|
||||
class LogrotateTests: XCTestCase {
|
||||
|
||||
let logURL = URL(fileURLWithPath: "/var/log/application.log")
|
||||
let log1URL = URL(fileURLWithPath: "/var/log/application.log.1")
|
||||
|
@ -34,7 +34,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_1rotation_0files() {
|
||||
let fileSystem = FileSystemMock(files: [])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -44,7 +44,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_1rotation_1file() {
|
||||
let fileSystem = FileSystemMock(files: [logURL])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -54,7 +54,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_1rotation_2files() {
|
||||
let fileSystem = FileSystemMock(files: [logURL, log1URL])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -64,7 +64,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_1rotation_3files() {
|
||||
let fileSystem = FileSystemMock(files: [logURL, log1URL, log2URL])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -74,7 +74,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_2rotations_0files() {
|
||||
let fileSystem = FileSystemMock(files: [])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -84,7 +84,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_2rotations_1file() {
|
||||
let fileSystem = FileSystemMock(files: [logURL])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -94,7 +94,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_2rotations_2files() {
|
||||
let fileSystem = FileSystemMock(files: [logURL, log1URL])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -104,7 +104,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_2rotations_3files() {
|
||||
let fileSystem = FileSystemMock(files: [logURL, log1URL, log2URL])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -114,7 +114,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func test_2rotations_4files() {
|
||||
let fileSystem = FileSystemMock(files: [logURL, log1URL, log2URL, log3URL])
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 2, fileSystem: fileSystem)
|
||||
try? logrotate.rotate()
|
||||
|
||||
let actual = fileSystem.files
|
||||
|
@ -124,7 +124,7 @@ class FileRotateTests: XCTestCase {
|
|||
|
||||
func testErrorPropagation() {
|
||||
let fileSystem = BrokenFileSystem()
|
||||
let logrotate = FileRotate(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
let logrotate = LogrotateImpl(fileURL: logURL, rotations: 1, fileSystem: fileSystem)
|
||||
|
||||
XCTAssertThrowsError(try logrotate.rotate(), "An error when removing or moving an item") { (error) in
|
||||
XCTAssertTrue(error is BrokenFileSystem.IOError)
|
Loading…
Add table
Reference in a new issue