What is TimberSwift?
A library to send all messages from either frameworks or the parent application to the parent application for consumption. This means the parent application will solely be responsible for sending to: The console, UI toasting, monitoring network activity, sending to Flurry / Google Analytics / Firebase / Crashlytics, some logging solution, or > /dev/null
.
- Logging
- Error, Warning, Debug, Info
- A console friendly message is passed to the parent application
- Errors are ALSO passed to a seperate method and are expected to be logged to an error logging solution such as Crashlytics non-fatal logging
- Analytics
- Set screen name for workflow
- Log an event
- User Messaging
- Toast messages
- Performance
- Measuring the time is takes between starting, incrementating, and stopping a trace.
- Networking
- Network Activity
github "MonsantoCo/TimberSwift" ~> 1.0.0
.package(url: "git@github.com:MonsantoCo/TimberSwift.git", from: "1.0.0")
timber.performance.startTrace(key: "Some Key", properties: ["Some": "Things for the trace"])
timber.performance.incrementTraceCounter(key: "Some Key")
timber.performance.stopTrace(key: "Some Key")
timber.log.debug("A message", properties: ["More": "Info"])
timber.log.info("A message", properties: ["More": "Info"])
timber.log.warning("A message", properties: ["More": "Info"])
timber.log.error("A message", errorType: .http(statusCode: 500), properties: ["Error": "Info"])
timber.userMessage.toast("Hi There", displayTime: 2.0, type: .success)
timber.analytics.setScreen(title: "The Main Map")
timber.analytics.recordEvent(title: "Downloading Everything", properties: ["Specific": "Info"])
timber.network.startedActivity()
timber.network.endedActivity()
The parent application should assign itself as the TimberApplicationDelegate as soon as possble to receive any and all messages from Timber objects.
func setScreen(title: String, source: Source)
func recordEvent(title: String, properties: [String: Any]?, source: Source)
func log(_ logMessage: LogMessage)
func log(_ error: TimberError)
func toast(_ message: String, displayTime: TimeInterval, type: ToastType, source: Source)
func startTrace(key: String, identifier: UUID?, properties: [String: Any]?, source: Source)
func incrementTraceCounter(key: String, identifier: UUID?, named: String, by count: Int, source: Source)
func stopTrace(key: String, identifier: UUID?, source: Source)
func networkActivityStarted(source: Source)
func networkActivityEnded(source: Source)
- Setup: Package Manager Example:
rm -rf *.xcodeproj || rm -rf .build || swift package resolve && swift package generate-xcodeproj && open *.xcodeproj
- Building: In the Target
TimberSwift
, select the tabSigning & Capabilities
and check the boxAutomatically manage signing
- Code Coverage: In the scheme menu, select
Edit Scheme...
, select theTest
item on the left, select the tabOptions
, and check the boxGather coverage for "all targets"
- Mocking: In the target
TimberSwiftTests
select the tabBuild Phases
and add aRun Script Phase
with the body$PROJECT_DIR/Scripts/parrot.sh
and move the item to the top of the Buld Phases just belowDependencies
. - Linting: In the target
TimberSwift
select the tabBuild Phases
and add aRun Script Phase
with the body$PROJECT_DIR/Scripts/swiftlint.sh
.