{"id":47980,"date":"2025-06-05T16:27:29","date_gmt":"2025-06-05T20:27:29","guid":{"rendered":"https:\/\/mjtsai.com\/blog\/?p=47980"},"modified":"2025-06-05T16:27:29","modified_gmt":"2025-06-05T20:27:29","slug":"toothfairy-2-8-6","status":"publish","type":"post","link":"https:\/\/mjtsai.com\/blog\/2025\/06\/05\/toothfairy-2-8-6\/","title":{"rendered":"ToothFairy 2.8.6"},"content":{"rendered":"<p><a href=\"https:\/\/c-command.com\/blog\/2025\/06\/05\/toothfairy-2-8-6\/\">ToothFairy 2.8.6<\/a> is a maintenance update of my Bluetooth menu bar utility.<\/p>\n\n<p>Some interesting issues were:<\/p>\n\n<ul>\n\n<li><p>There&rsquo;s a new issue with macOS Sequoia where sometimes <code>IOBluetoothDevice<\/code> never sends a notification that a device has connected, even though the device has actually connected and <code>isConnected()<\/code> now returns <code>true<\/code>.<\/p><\/li>\n\n<li><p>Separately, sometimes the device connects (with no notification) but <code>isConnected()<\/code> remains <code>false<\/code>.<\/p><\/li>\n\n<li><p>There was a longstanding bug where we were modifying a view layout from a background thread. macOS is now detecting this and <code>_AssertAutoLayoutOnAllowedThreadsOnly()<\/code> raises an <code>NSInternalInconsistencyException<\/code>.<\/p><\/li>\n\n<li><p>I&rsquo;m having trouble testing my Mac App Store build because after <code>exit(173)<\/code> it will prompt me to log in with my sandbox account, but the verification code never arrives. I&rsquo;m not sure what Mac it&rsquo;s even supposedly going to&mdash;where can you access the device list for a sandbox account? This had been a problem for a long time, but there used to be an option to have it send the code via SMS to the phone number on my developer account. That seems to be gone.<\/p><\/li>\n\n<\/ul>\n\n<p>Previously:<\/p>\n<ul>\n<li><a href=\"https:\/\/mjtsai.com\/blog\/2024\/10\/18\/exit173-receipt-fetching-deprecated-on-sequoia\/\">exit(173) Receipt Fetching Deprecated on Sequoia<\/a><\/li>\n<li><a href=\"https:\/\/mjtsai.com\/blog\/2024\/10\/17\/toothfairy-2-8-5\/\">ToothFairy 2.8.5<\/a><\/li>\n<\/ul>","protected":false},"excerpt":{"rendered":"<p>ToothFairy 2.8.6 is a maintenance update of my Bluetooth menu bar utility. Some interesting issues were: There&rsquo;s a new issue with macOS Sequoia where sometimes IOBluetoothDevice never sends a notification that a device has connected, even though the device has actually connected and isConnected() now returns true. Separately, sometimes the device connects (with no notification) [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"apple_news_api_created_at":"2025-06-05T20:27:33Z","apple_news_api_id":"f8fe08be-b7db-476d-a6f6-39eb4683871b","apple_news_api_modified_at":"2025-06-05T20:27:33Z","apple_news_api_revision":"AAAAAAAAAAD\/\/\/\/\/\/\/\/\/\/w==","apple_news_api_share_url":"https:\/\/apple.news\/A-P4IvrfbR22m9jnrRoOHGw","apple_news_coverimage":0,"apple_news_coverimage_caption":"","apple_news_is_hidden":false,"apple_news_is_paid":false,"apple_news_is_preview":false,"apple_news_is_sponsored":false,"apple_news_maturity_rating":"","apple_news_metadata":"\"\"","apple_news_pullquote":"","apple_news_pullquote_position":"","apple_news_slug":"","apple_news_sections":"\"\"","apple_news_suppress_video_url":false,"apple_news_use_image_component":false,"footnotes":""},"categories":[2],"tags":[707,422,131,69,1361,30,32,39,2598,71,1687],"class_list":["post-47980","post","type-post","status-publish","format-standard","hentry","category-technology","tag-apple-id","tag-bluetooth","tag-bug","tag-cocoa","tag-itunes-connect-sandbox-testers","tag-mac","tag-macapp","tag-macappstore","tag-macos-15-sequoia","tag-programming","tag-toothfairy"],"apple_news_notices":[],"_links":{"self":[{"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/posts\/47980","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/comments?post=47980"}],"version-history":[{"count":1,"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/posts\/47980\/revisions"}],"predecessor-version":[{"id":47981,"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/posts\/47980\/revisions\/47981"}],"wp:attachment":[{"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/media?parent=47980"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/categories?post=47980"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/mjtsai.com\/blog\/wp-json\/wp\/v2\/tags?post=47980"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}