-
Notifications
You must be signed in to change notification settings - Fork 338
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
Encodable.jsonEncodedData
: fixed tests on iOS 17 due to inconsistent key ordering
#2607
Conversation
Codecov Report
@@ Coverage Diff @@
## main #2607 +/- ##
==========================================
- Coverage 86.29% 86.26% -0.03%
==========================================
Files 205 205
Lines 14334 14328 -6
==========================================
- Hits 12369 12360 -9
- Misses 1965 1968 +3 |
JSONEncoding
: add tests to cover Xcode 15 regressionJSONEncoding
: sort keys to ensure data consistency
That issue was closed, which confirms that we do indeed need to sort keys to ensure consistent results. |
These and a bunch of other tests are failing on Xcode 15 due to [a regression](swiftlang/swift#66466). To make the other failures more explicit, I've added new comparisons to ensure that both the `CustomerInfoResponse` and underlying `Data` are encoded equally. This breaks tests because we relying on being able to verify that the encoded `Data` saved to caches is consistent. A potential workaround (if they don't fix that regression) will be to force key ordering: ```diff diff --git i/Sources/LocalReceiptParsing/DataConverters/Codable+Extensions.swift w/Sources/LocalReceiptParsing/DataConverters/Codable+Extensions.swift index 025419d6..2d43b7a5 100644 --- i/Sources/LocalReceiptParsing/DataConverters/Codable+Extensions.swift +++ w/Sources/LocalReceiptParsing/DataConverters/Codable+Extensions.swift @@ -53,6 +53,7 @@ extension JSONEncoder { let encoder = JSONEncoder() encoder.keyEncodingStrategy = .convertToSnakeCase encoder.dateEncodingStrategy = .iso8601 + encoder.outputFormatting = .sortedKeys return encoder }() @@ -61,7 +62,7 @@ extension JSONEncoder { let encoder = JSONEncoder() encoder.keyEncodingStrategy = .convertToSnakeCase encoder.dateEncodingStrategy = .iso8601 - encoder.outputFormatting = .prettyPrinted + encoder.outputFormatting = [.sortedKeys, .prettyPrinted] return encoder }() ```
ee29e79
to
07f1342
Compare
JSONEncoding
: sort keys to ensure data consistencyEncodable.jsonEncodedData
: fixed tests on iOS 17 due to inconsistent key ordering
07f1342
to
d82ca8e
Compare
@tonidero mind taking another look? I reworked this PR to actually fix the issue, now that I got a response and we know it's not really a regression. |
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.
Looks good!
**This is an automatic release.** ### New Features * New `DebugViewController`: UIKit counterpart for SwiftUI's `debugRevenueCatOverlay` (#2631) via NachoSoto (@NachoSoto) * Created `PaywallExtensions`: `StoreView` and `SubscriptionStoreView` overloads for `Offering` (#2593) via NachoSoto (@NachoSoto) * Introduced `debugRevenueCatOverlay()`: new SwiftUI debug overlay (#2567) via NachoSoto (@NachoSoto) ### Bugfixes * Removed `preventPurchasePopupCallFromTriggeringCacheRefresh`, update caches on `willEnterForeground` (#2623) via NachoSoto (@NachoSoto) * Fixed `Catalyst` build with `Xcode 15 beta 1` (#2586) via NachoSoto (@NachoSoto) ### Dependency Updates * Bump danger from 9.3.0 to 9.3.1 (#2592) via dependabot[bot] (@dependabot[bot]) ### Other Changes * `StoreTransaction`: added new `Storefront` to API testers (#2634) via NachoSoto (@NachoSoto) * `DebugView`: added snapshot tests (#2630) via NachoSoto (@NachoSoto) * `verifyNoUnfinishedTransactions`/`verifyUnfinishedTransaction`: added missing `#file` parameter (#2625) via NachoSoto (@NachoSoto) * `PostReceiptDataOperation`: clean up cache key (#2628) via NachoSoto (@NachoSoto) * `PurchasesOrchestrator`: also get `Storefront` from SK1 (#2629) via NachoSoto (@NachoSoto) * `CI`: disable iOS 17 for now (#2627) via NachoSoto (@NachoSoto) * `Tests`: fixed crash on iOS 13 (#2624) via NachoSoto (@NachoSoto) * `StoreTransaction`: read `Storefront` from `StoreKit.Transaction` (#2611) via NachoSoto (@NachoSoto) * `StoreKitConfigTestCase`/`BaseStoreKitIntegrationTests`: also clear transactions after every test (#2616) via NachoSoto (@NachoSoto) * `ErrorCode.networkError`: improved description (#2610) via NachoSoto (@NachoSoto) * `PurchaseTester`: make CI job always point to current version (#2622) via NachoSoto (@NachoSoto) * Improved `finishAllUnfinishedTransactions` (#2615) via NachoSoto (@NachoSoto) * `StoreKitConfigTestCase`: improved `waitForStoreKitTestIfNeeded` (#2614) via NachoSoto (@NachoSoto) * `StoreKitConfigTestCase`: set `continueAfterFailure` to `false` (#2617) via NachoSoto (@NachoSoto) * `PaywallExtensions`: fixed compilation (#2613) via NachoSoto (@NachoSoto) * `CI`: added `iOS 17` job (#2591) via NachoSoto (@NachoSoto) * `Encodable.jsonEncodedData`: fixed tests on iOS 17 due to inconsistent key ordering (#2607) via NachoSoto (@NachoSoto) * `debugRevenueCatOverlay`: added ability to display new `SubscriptionStoreView` (#2595) via NachoSoto (@NachoSoto) * Refactor: extracted all log strings (#2600) via NachoSoto (@NachoSoto) * Changed tests to work around `URL` decoding differences in `iOS 17` (#2605) via NachoSoto (@NachoSoto) * Removed unnecessary `Strings.trimmedOrError` (#2601) via NachoSoto (@NachoSoto) * Fixed test compilation with `Xcode 15` (#2602) via NachoSoto (@NachoSoto) * Tests: added `iOS 17` snapshots (#2603) via NachoSoto (@NachoSoto) * `StoreProductDiscount`: added `description` (#2604) via NachoSoto (@NachoSoto) * `debugRevenueCatOverlay` improvements (#2594) via NachoSoto (@NachoSoto) * `Xcode 15`: fixed all documentation warnings (#2596) via NachoSoto (@NachoSoto) * `StoreKitObserverModeIntegrationTests`: fixed and disabled SK2 `testPurchaseInDevicePostsReceipt` (#2589) via NachoSoto (@NachoSoto) * `StoreKit2TransactionListener`: added log when receiving `Transactions.Updates` (#2588) via NachoSoto (@NachoSoto) * `Dictionary.MergeStrategy`: simplify implementation (#2587) via NachoSoto (@NachoSoto) * `Configuration.Builder`: fixed doc reference (#2583) via NachoSoto (@NachoSoto) * `APITesters`: available since iOS 11 (#2581) via NachoSoto (@NachoSoto)
A bunch of tests were failing on Xcode 15 due to a change in Swift, because we relying on being able to verify that the encoded
Data
saved to caches is consistent.Starting on Swift 5.9
JSONEncoder
has optimizations that mean we can't rely on it.To fix this, this PR does 2 things:
JSONEncoder.prettyPrinted
to have.sortedKeys
struct
, not the raw encodedData
Note that I didn't make
JSONEncoder.default
use.sortedKeys
because of the potential performance impact.Encodable.prettyPrintedData
is used in tests likeReceiptFetcherTests
(which this PR fixes) and for debug purposes, butEncodable.encodedJSON
is used everywhere.