First off, you should only prompt your user once on whether they want to get push notifications or not. So tying that to a button and trying to run it every time is a bad UX decision. Only tie your Push Notification prompt to a button if the button actually does more stuff which would require Push Notifications to be enabled.
To register your user for push notifications, you should use the UIApplication
registerForRemoteNotifications
method. When this method runs, your user will be prompted on whether they want to receive push notifications - but only once! The setting they set will be considered definitive and your user will not be prompted again. If they want to start receiving push notifications, they have to change that in the app's settings. This is expected behavior and is how you should do it.
If you want to prompt the user only when they press a button, then remove any calls to registerForRemoteNotifications
from your app's startup code and call the method from the action tied to your button instead.
If you want to reset the push notification permissions for testing purposes, this is how Apple says it's possible:
Resetting the Push Notifications Permissions Alert on iOS
The first time a push-enabled app registers for push notifications, iOS asks the user if they wish to receive notifications for that app. Once the user has responded to this alert it is not presented again unless the device is restored or the app has been uninstalled for at least a day.
If you want to simulate a first-time run of your app, you can leave the app uninstalled for a day. You can achieve the latter without actually waiting a day by following these steps:
- Delete your app from the device.
- Turn the device off completely and turn it back on.
- Go to Settings > General > Date & Time and set the date ahead a day or more.
- Turn the device off completely again and turn it back on.