Сбой: com.apple.root.default-qos

У меня довольно простое приложение, которое анализирует канал RSS и показывает его содержимое в виде таблицы. Он доступен в App Store. У меня есть Crashlytics crash отчетности интегрированы. Недавно я получил два отчета. Это немного сложно расшифровать.

Это произошло в iPhone 6 под управлением iOS 10.2.1.

введите описание изображения здесь

Это из iPhone 5 с iOS 10.2.1.

введите описание изображения здесь

Несмотря на то, что он говорит, что он сбой из-за нарушений конфиденциальности, я не получаю доступа к службам, требующим разрешения в моем приложении.

Также поиск по com.apple.root.default-qos заставляет меня думать, что это может иметь какое-то отношение к фоновым потокам. Единственное место, где я использую фоновый поток, - это проанализировать данные RSS-фида.

DispatchQueue.global(qos: .background).async {

    guard let data = try? Data(contentsOf: URL) else {
        return
    }

    do {
        let xmlDoc = try AEXMLDocument(xml: data)

        if let items = xmlDoc.root["channel"]["item"].all {
            self.posts.removeAll()

            for item in items {
                let title = item["title"].value ?? ""
                // ...
                self.posts.append(jobPost)
            }

            DispatchQueue.main.async {
                self.saveposts(self.posts)
                self.posts.sort { $0.publishDate > $1.publishDate }
                self.tableView.reloadData()
                UIApplication.shared.toggleNetworkActivityIndicator(show: false)
                self.toggleUI(enable: true)
                if self.refreshControl.isRefreshing { self.refreshControl.endRefreshing() }
            }

        }

    } catch let error as NSError {
        print("RSS parsing failed: \(error)")
        self.showErrorAlert(error)
        UIApplication.shared.toggleNetworkActivityIndicator(show: false)
        self.toggleUI(enable: true)
        if self.refreshControl.isRefreshing { self.refreshControl.endRefreshing() }
    }
}

Я протестировал этот код на своем iPhone 5 под управлением iOS 9.3.5 и симуляторах с iOS 10.2, но не произошел сбой.

Есть ли другой способ отследить эту проблему?

Ответ 1

Я бы дважды проверял все ваши разрешения. В моем случае, начиная с iOS10, вам нужны разрешения на сохранение материала для рулона камеры пользователя. В моем приложении я показывал общий листок по умолчанию, и всякий раз, когда пользователь выбирал "сохранить фотографию", приложение разбилось с одним из этих очень не полезных сообщений об ошибках. Я добавил

<key>NSPhotoLibraryAddUsageDescription</key>
    <string>Allow you to save charts and graphs from the app to your phone.</string>

к моим info.plist, clean и run. И все проблемы были решены.