Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pointfreeco/swift-issue-reporting
Report issues in your application and library code as Xcode runtime warnings, breakpoints, assertions, and do so in a testable manner.
https://github.com/pointfreeco/swift-issue-reporting
swift-testing xcode xctest
Last synced: 2 days ago
JSON representation
Report issues in your application and library code as Xcode runtime warnings, breakpoints, assertions, and do so in a testable manner.
- Host: GitHub
- URL: https://github.com/pointfreeco/swift-issue-reporting
- Owner: pointfreeco
- License: mit
- Created: 2021-03-17T14:04:37.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-12-21T20:48:36.000Z (23 days ago)
- Last Synced: 2025-01-04T13:23:08.835Z (9 days ago)
- Topics: swift-testing, xcode, xctest
- Language: Swift
- Homepage: https://www.pointfree.co
- Size: 2.18 MB
- Stars: 410
- Watchers: 12
- Forks: 66
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Swift Issue Reporting
[![CI](https://github.com/pointfreeco/xctest-dynamic-overlay/actions/workflows/ci.yml/badge.svg)](https://github.com/pointfreeco/swift-issue-reporting/actions/workflows/ci.yml)
[![](https://img.shields.io/endpoint?url=https%3A%2F%2Fswiftpackageindex.com%2Fapi%2Fpackages%2Fpointfreeco%2Fswift-issue-reporting%2Fbadge%3Ftype%3Dswift-versions)](https://swiftpackageindex.com/pointfreeco/swift-issue-reporting)
[![](https://img.shields.io/endpoint?url=https%3A%2F%2Fswiftpackageindex.com%2Fapi%2Fpackages%2Fpointfreeco%2Fswift-issue-reporting%2Fbadge%3Ftype%3Dplatforms)](https://swiftpackageindex.com/pointfreeco/swift-issue-reporting)Report issues in your application and library code as Xcode runtime warnings, breakpoints,
assertions, and do so in a testable manner.## Overview
This library provides robust tools for reporting issues in your application with a customizable
degree of granularity and severity. In its most basic form you use the `reportIssue` function
anywhere in your application to flag an issue in your code, such as a code path that you think
should never be executed:```swift
guard let lastItem = items.last
else {
reportIssue("'items' should never be empty.")
return
}
…
```By default, this will trigger an unobtrusive, purple runtime warning when running your app in Xcode
(simulator and device):
This provides a very visual way of seeing when an issue has occurred in your application without
stopping the app's execution or interrupting your workflow.The `reportIssue` tool can also be customized to allow for other ways of reporting issues. It can be
configured to trigger a breakpoint if you want to do some debugging when an issue is reported, or a
precondition or fatal error if you want to truly stop execution. And you can create your own custom
issue reporter to send issues to OSLog or an external server.Further, when running your code in a testing context (both Swift's native Testing framework as well
as XCTest), all reported issues become _test failures_. This helps you get test coverage that
problematic code paths are not executed, and makes it possible to build testing tools for libraries
that ship in the same target as the library itself.
Issue Reporting comes with a number of reporters, custom reporting functionality, and more. To learn
about these features, see
[Getting started](Sources/IssueReporting/Documentation.docc/Articles/GettingStarted.md).## Case studies
There are many popular libraries out there using Issue Reporting. To name a few:
* [**Perception**](https://github.com/pointfreeco/swift-perception) is a back-port of Swift's
Observation framework that can be deployed all the way back to the iOS 13 generation of devices,
but requires a special SwiftUI view to observe changes to objects annotated with the macro. When
the library detects this view is missing, it uses Issue Reporting to warn developers with a
trace pointing to the view.* [**Dependencies**](https://github.com/pointfreeco/swift-dependencies) is a general purpose
dependency injection library inspired by SwiftUI's environment. It uses Swift Issue Reporting to
notify users when they access dependencies without overridding them. This results in runtime
warnings when running in the simulator, and test failures when testing. It forces each test
to explicitly declare its dependencies, and when a new dependency is introduced to a feature,
existing tests will fail until they account for it.* [**The Composable Architecture**](https://github.com/pointfreeco/swift-composable-architecture)
comes with powerful testing tools that support both Swift Testing and XCTest out of the box
thanks to Swift Issue Reporting. In addition, the library is heavily instrumented with issue
reporting to help developers catch bugs in their code early.* [**Custom Dump**](https://github.com/pointfreeco/swift-custom-dump) is an improved version of
Swift's `dump` function, and a whole lot more. It provides well-formatted dumps of data types
that read like Swift code, as well as well-formatted diffs when data types are compared. It also
ships several test helpers powered by Swift Issue Reporting, including drop-in replacements for
`#expect(_ == _)` and `XCTAssertEqual` that render failures as concise diffs, as well as helpers
that allow you to assert against changes to data structures over time.* [**Swift Clocks**](https://github.com/pointfreeco/swift-clocks) and
[**Combine Schedulers**](https://github.com/pointfreeco/combine-schedulers) are sibling packages
that use issue reporting to drive their "test" and "unimplemented" clocks and schedulers. "Test"
clocks/schedulers allow you to _control time_ in tests, and will emit failures when expectations
aren't met. "Unimplemented" clocks/schedulers record unexpected usage as issues.Have another case study to share? [Let us know!](edit/main/README.md)
## Documentation
Full documentation can be found
[here](https://swiftpackageindex.com/pointfreeco/swift-issue-reporting/main/documentation).## License
This library is released under the MIT license. See [LICENSE](LICENSE) for details.