12 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	Reboot Testing Procedure for DailyNotification Plugin
Overview
This document provides a comprehensive procedure for testing notification recovery after device reboots. The DailyNotification plugin implements a robust reboot recovery system that restores scheduled notifications after system events.
Prerequisites
- Android device or emulator with ADB enabled
 - DailyNotification app installed
 - ADB tools installed on development machine
 - Notification permissions granted
 - Boot receiver permissions granted
 
Reboot Recovery System
How It Works
- 
Boot Receiver Registration: The
BootReceiveris registered inAndroidManifest.xmlto listen for:BOOT_COMPLETED- Device boot completionMY_PACKAGE_REPLACED- App updatePACKAGE_REPLACED- Any package update
 - 
Recovery Process: When triggered, the boot receiver:
- Initializes the 
DailyNotificationRebootRecoveryManager - Loads stored notification data from SharedPreferences
 - Reschedules all pending notifications
 - Validates notification integrity
 
 - Initializes the 
 - 
Data Persistence: Notification data is stored in:
- SharedPreferences for notification content
 - AlarmManager for scheduling
 - Internal storage for recovery metadata
 
 
Manual Reboot Testing Procedure
Test 1: Basic Reboot Recovery
Objective: Verify notifications are restored after device reboot
Steps:
- 
Schedule Notification:
# Launch app adb shell am start -n com.timesafari.dailynotification/.MainActivity- Tap "Test Notification" button
 - Verify notification scheduled for 5 minutes from now
 - Note the scheduled time
 
 - 
Verify Alarm is Scheduled:
# Check scheduled alarms adb shell "dumpsys alarm | grep timesafari"- Should show scheduled alarm with correct timestamp
 
 - 
Reboot Device:
# Reboot device adb reboot- Wait for device to fully boot (2-3 minutes)
 - Wait for boot animation to complete
 
 - 
Verify Recovery:
# Check if app recovered notifications adb logcat -d | grep -i "bootreceiver\|recovery"- Look for "Device boot completed - restoring notifications"
 - Look for "Notification recovery completed successfully"
 
 - 
Verify Alarm Restored:
# Check if alarm was restored adb shell "dumpsys alarm | grep timesafari"- Should show the same scheduled alarm
 
 - 
Wait for Notification:
- Wait for the originally scheduled time
 - Check notification panel for the test notification
 
 
Expected Result: Notification appears at the originally scheduled time
Test 2: App Update Recovery
Objective: Verify notifications are restored after app update
Steps:
- 
Schedule Notification:
- Schedule a notification for 5 minutes from now
 - Verify it's scheduled correctly
 
 - 
Update App:
# Build and install updated app cd android && ./gradlew assembleDebug adb install -r app/build/outputs/apk/debug/app-debug.apk - 
Verify Recovery:
# Check recovery logs adb logcat -d | grep -i "package.*replaced\|recovery"- Look for "Our app was updated - restoring notifications"
 
 - 
Verify Alarm Restored:
# Check if alarm was restored adb shell "dumpsys alarm | grep timesafari" - 
Wait for Notification:
- Wait for the scheduled time
 - Verify notification appears
 
 
Expected Result: Notification appears after app update
Test 3: Multiple Notifications Recovery
Objective: Verify multiple notifications are restored correctly
Steps:
- 
Schedule Multiple Notifications:
- Schedule 3-4 notifications at different times
 - Note all scheduled times
 
 - 
Reboot Device:
adb reboot - 
Verify All Recovered:
# Check all alarms adb shell "dumpsys alarm | grep timesafari"- Should show all scheduled alarms
 
 - 
Test Each Notification:
- Wait for each scheduled time
 - Verify each notification appears
 
 
Expected Result: All notifications appear at their scheduled times
Automated Reboot Testing
Bash Script for Reboot Testing
#!/bin/bash
# reboot-test.sh
set -e
APP_PACKAGE="com.timesafari.dailynotification"
APP_ACTIVITY=".MainActivity"
echo "🔄 Starting Reboot Recovery Test"
echo "================================"
# Function to wait for device
wait_for_device() {
    echo "⏳ Waiting for device to be ready..."
    adb wait-for-device
    sleep 10  # Additional wait for boot completion
}
# Function to schedule notification
schedule_notification() {
    echo "📅 Scheduling test notification..."
    adb shell am start -n $APP_PACKAGE/$APP_ACTIVITY
    sleep 3
    
    echo "⚠️  Manual step: Schedule notification in app"
    echo "   - Tap 'Test Notification' button"
    echo "   - Wait for 'Notification scheduled' message"
    read -p "Press Enter when notification is scheduled..."
}
# Function to check recovery logs
check_recovery_logs() {
    echo "🔍 Checking recovery logs..."
    if adb logcat -d | grep -q "Notification recovery completed successfully"; then
        echo "✅ Recovery completed successfully"
        return 0
    else
        echo "❌ Recovery not found in logs"
        return 1
    fi
}
# Function to check scheduled alarms
check_scheduled_alarms() {
    echo "⏰ Checking scheduled alarms..."
    if adb shell "dumpsys alarm | grep timesafari" | grep -q "RTC_WAKEUP"; then
        echo "✅ Alarms scheduled correctly"
        return 0
    else
        echo "❌ No alarms found"
        return 1
    fi
}
# Main test
main() {
    # Step 1: Schedule notification
    schedule_notification
    
    # Step 2: Verify initial scheduling
    if check_scheduled_alarms; then
        echo "✅ Initial scheduling successful"
    else
        echo "❌ Initial scheduling failed"
        exit 1
    fi
    
    # Step 3: Reboot device
    echo "🔄 Rebooting device..."
    adb reboot
    wait_for_device
    
    # Step 4: Check recovery
    if check_recovery_logs; then
        echo "✅ Recovery successful"
    else
        echo "❌ Recovery failed"
        exit 1
    fi
    
    # Step 5: Verify alarms restored
    if check_scheduled_alarms; then
        echo "✅ Alarms restored successfully"
    else
        echo "❌ Alarms not restored"
        exit 1
    fi
    
    echo "🎉 Reboot recovery test completed successfully!"
    echo "⏰ Wait for the scheduled notification to appear"
}
main
Python Script for Reboot Testing
#!/usr/bin/env python3
"""
Reboot Recovery Test Script
"""
import subprocess
import time
import sys
class RebootTester:
    def __init__(self):
        self.package = "com.timesafari.dailynotification"
        self.activity = f"{self.package}/.MainActivity"
    
    def run_command(self, command):
        """Run ADB command"""
        return subprocess.run(f"adb {command}", shell=True, capture_output=True, text=True)
    
    def wait_for_device(self):
        """Wait for device to be ready"""
        print("⏳ Waiting for device...")
        self.run_command("wait-for-device")
        time.sleep(10)  # Additional wait for boot completion
    
    def schedule_notification(self):
        """Schedule notification (manual step)"""
        print("📅 Scheduling notification...")
        self.run_command(f"shell am start -n {self.activity}")
        time.sleep(3)
        
        print("⚠️  Manual step: Schedule notification in app")
        input("Press Enter when notification is scheduled...")
    
    def check_recovery_logs(self):
        """Check if recovery was successful"""
        result = self.run_command("logcat -d")
        return "Notification recovery completed successfully" in result.stdout
    
    def check_scheduled_alarms(self):
        """Check if alarms are scheduled"""
        result = self.run_command('shell "dumpsys alarm | grep timesafari"')
        return "RTC_WAKEUP" in result.stdout
    
    def reboot_device(self):
        """Reboot the device"""
        print("🔄 Rebooting device...")
        self.run_command("reboot")
        self.wait_for_device()
    
    def run_test(self):
        """Run complete reboot test"""
        print("🔄 Starting Reboot Recovery Test")
        print("=" * 40)
        
        # Schedule notification
        self.schedule_notification()
        
        # Verify initial scheduling
        if self.check_scheduled_alarms():
            print("✅ Initial scheduling successful")
        else:
            print("❌ Initial scheduling failed")
            return False
        
        # Reboot device
        self.reboot_device()
        
        # Check recovery
        if self.check_recovery_logs():
            print("✅ Recovery successful")
        else:
            print("❌ Recovery failed")
            return False
        
        # Verify alarms restored
        if self.check_scheduled_alarms():
            print("✅ Alarms restored successfully")
        else:
            print("❌ Alarms not restored")
            return False
        
        print("🎉 Reboot recovery test completed!")
        return True
if __name__ == "__main__":
    tester = RebootTester()
    if tester.run_test():
        sys.exit(0)
    else:
        sys.exit(1)
ADB Commands for Reboot Testing
Device Management
# Reboot device
adb reboot
# Wait for device to be ready
adb wait-for-device
# Check if device is ready
adb shell getprop sys.boot_completed
Recovery Monitoring
# Monitor recovery logs in real-time
adb logcat | grep -i "bootreceiver\|recovery"
# Check recovery logs
adb logcat -d | grep -i "bootreceiver\|recovery"
# Check boot receiver registration
adb shell "dumpsys package com.timesafari.dailynotification | grep -A10 -B10 receiver"
Alarm Verification
# Check scheduled alarms before reboot
adb shell "dumpsys alarm | grep timesafari"
# Check scheduled alarms after reboot
adb shell "dumpsys alarm | grep timesafari"
# Check exact alarm permissions
adb shell "dumpsys alarm | grep SCHEDULE_EXACT_ALARM"
Troubleshooting Reboot Recovery
Common Issues
1. Boot Receiver Not Triggered
Symptoms: No recovery logs after reboot Solutions:
- Check boot receiver registration in manifest
 - Verify 
BOOT_COMPLETEDpermission is granted - Check if device supports boot receiver (some OEMs disable it)
 
2. Recovery Fails
Symptoms: Recovery logs show errors Solutions:
- Check SharedPreferences data integrity
 - Verify notification content is valid
 - Check alarm scheduling permissions
 
3. Alarms Not Restored
Symptoms: No alarms after recovery Solutions:
- Check exact alarm permissions
 - Verify alarm scheduling logic
 - Check battery optimization settings
 
Debug Commands
# Check boot receiver status
adb shell "dumpsys package com.timesafari.dailynotification | grep -A5 -B5 receiver"
# Check recovery manager logs
adb logcat -d | grep -i "rebootrecovery"
# Check notification storage
adb shell "run-as com.timesafari.dailynotification ls -la /data/data/com.timesafari.dailynotification/shared_prefs/"
# Check alarm manager state
adb shell "dumpsys alarm | head -20"
Best Practices
Testing Environment
- Use physical device for most accurate results
 - Test on multiple Android versions
 - Test on different OEMs (Samsung, Huawei, etc.)
 - Test with different battery optimization settings
 
Test Data
- Use realistic notification content
 - Test with multiple notifications
 - Test with different time intervals
 - Test with various notification priorities
 
Documentation
- Record test results with timestamps
 - Screenshot notification appearances
 - Log any errors or unexpected behavior
 - Document device-specific issues
 
Success Criteria
✅ Test Passes When:
- Boot receiver is triggered after reboot
 - Recovery logs show successful restoration
 - Alarms are rescheduled correctly
 - Notifications appear at scheduled times
 - Multiple notifications are handled correctly
 
❌ Test Fails When:
- Boot receiver is not triggered
 - Recovery fails with errors
 - Alarms are not restored
 - Notifications don't appear
 - App crashes during recovery
 
Conclusion
The reboot recovery system ensures that scheduled notifications survive device reboots and app updates. Regular testing of this functionality is crucial for maintaining reliable notification delivery in production environments.
For questions or issues, refer to the troubleshooting section or check the plugin logs using the provided ADB commands.