-
Notifications
You must be signed in to change notification settings - Fork 483
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Replaced XCTAssertArray(Float|Double)EqualWithAccuracy(_:_:accuracy:)
…
#104
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for this, @regexident. The functionality this is providing is helpful and strongly-motivated, and really well-written. I was pleasantly surprised to see Matrix
conformance to ExpressibleByArrayLiteral
and Collection
in here too.
I only have one top-level comment (which may amount to bike-shedding, so apologies in advance if that's indeed the case):
The current spelling of XCTAssertEqual
is most similar to the built-in generic comparator assertion, but it most resembles XCTAssertEqualWithAccuracy
, which makes me wonder if it should be named closer t the latter. I think I prefer having accuracy
as a labeled parameter, rather than being implicit from the head of the function name, but then again, both of those are effectively bridged functions from C macros, so standard Swift API naming conventions seem to be out the window (which makes me wonder if it's worth distinguishing our custom Surge-specific assertion from the built-in XCT
ones...)
I don't have a very strong feeling any which way, but right now the spelling I think I most favor is something like XCTAssertEqualFloatingPointElementsWithAccuracy
for a top-level function, or validateEqualElements
if we decide to define a helper function in an extension on XCTestCase
.
What's your take with all of this, @regexident?
continue | ||
} | ||
|
||
let failureMessage = "XCTAssertEqualWithAccuracy failed: (\(actual)) is not equal to (\(expected)) +/- (\(accuracy))" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Mismatch reference to XCTAssertEqualWithAccuracy
in failure message.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Curiously enough XCTAssertEqual(_:_:accuracy:file:line:)
will produce an error message like seen above, referencing XCTAssertEqualWithAccuracy
. I copied it from an intentionally failed test.
import XCTest
@testable import Foobar
class FoobarTests: XCTestCase {
func testExample() {
// Test error: XCTAssertEqualWithAccuracy failed: ("1.0") is not equal to ("0.9") +/- ("0.01")
XCTAssertEqual(1.0, 0.9, accuracy: 0.01)
}
}
import XCTest
@testable import Foobar
class FoobarTests: XCTestCase {
func testExample() {
// Compiler warning:
//
// 'XCTAssertEqualWithAccuracy(_:_:accuracy:_:file:line:)'
// is deprecated: renamed to 'XCTAssertEqual(_:_:accuracy:file:line:)'
XCTAssertEqualWithAccuracy(1.0, 0.9, accuracy: 0.1)
}
} |
Commit 2363135 refactors the implementation of By default XCTest provides the following implementations:
Unfortunately all these do is call
… for scalar values.
… for vector values.
… for matrix values. In increasing dimensionality this becomes less and less human readable. The Surge-provides overloads of
The current implementation of these bring their own problems though: Instead of providing too much information in the failure message they provide too little: As such in current Surge a test like this … let actual: Vector<Float> = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
let expected: Vector<Float> = [0, 1, 2, 3, 42, 5, 6, 7, 8, 9]
XCTAssertEqual(actual, expected) … would simply fail with an error message like this …
Which is why I refactored it to fail with a neat index hint like this …
… in case of 1D vector-like input, or this …
… in case of 2D matrix-like input. Unfortunately this ergonomics improvement only applies to the Surge-provided higher-dimensional versions of Which is why I added explicit aliases The documentation explains the difference:
Long story short: With commit 2363135 your existing tests using Surge-provided asserts get improved ergonomics without any change necessary, while for those provided by Apple you need to use the alternative |
… with short-circuiting overload of
XCTAssertEqual(_:_:accuracy:)
The current version floods the console (especially
var n = 100_000
) with assertion failures, bringing Xcode to its knees.This modification short-circuits on first failure.
Unlike the current version it also preserves
#line
and#file
.It also overloads
XCTAssertEqual(_:_:accuracy:)
, eliminating the need forXCTAssertArray(Float|Double)EqualWithAccuracy(_:_:accuracy:)
.