Files
pwap/mobile
Claude 7d21e5c074 test(mobile): add comprehensive test infrastructure and initial test suite
Implemented complete testing setup with Jest and React Native Testing Library:

## Test Infrastructure

**Files Created:**
1. `mobile/jest.config.js` - Jest configuration with:
   - jest-expo preset for React Native/Expo
   - Module name mapping for @pezkuwi/* (shared library)
   - Transform ignore patterns for node_modules
   - Coverage thresholds: 70% statements, 60% branches, 70% functions/lines
   - Test match pattern: **/__tests__/**/*.test.(ts|tsx|js)

2. `mobile/jest.setup.js` - Test setup with mocks:
   - expo-linear-gradient mock
   - expo-secure-store mock (async storage operations)
   - expo-local-authentication mock (biometric auth)
   - @react-native-async-storage/async-storage mock
   - @polkadot/api mock (blockchain API)
   - Supabase mock (auth and database)
   - Console warning/error suppression in tests

3. `mobile/package.json` - Added test scripts:
   - `npm test` - Run all tests
   - `npm run test:watch` - Watch mode for development
   - `npm run test:coverage` - Generate coverage report

---

## Test Suites

### 1. Context Tests

**File:** `mobile/src/contexts/__tests__/AuthContext.test.tsx`

Tests for AuthContext (7 test cases):
-  Provides auth context with initial state
-  Signs in with email/password
-  Handles sign in errors correctly
-  Signs up new user with profile creation
-  Signs out user
-  Checks admin status
-  Proper async handling and state updates

**Coverage Areas:**
- Context initialization
- Sign in/sign up flows
- Error handling
- Supabase integration
- State management

---

### 2. Component Tests

**File:** `mobile/src/components/__tests__/ErrorBoundary.test.tsx`

Tests for ErrorBoundary (5 test cases):
-  Renders children when no error occurs
-  Renders error UI when child throws error
-  Displays "Try Again" button on error
-  Renders custom fallback if provided
-  Calls onError callback when error occurs

**Coverage Areas:**
- Error catching mechanism
- Fallback UI rendering
- Custom error handlers
- Component recovery

---

### 3. Integration Tests

**File:** `mobile/__tests__/App.test.tsx`

Integration tests for App component (3 test cases):
-  Renders App component successfully
-  Shows loading indicator during i18n initialization
-  Wraps app in ErrorBoundary (provider hierarchy)

**Coverage Areas:**
- App initialization
- Provider hierarchy validation
- Loading states
- Error boundary integration

---

## Test Statistics

**Total Test Files:** 3
**Total Test Cases:** 15
**Coverage Targets:** 70% (enforced by Jest config)

### Test Distribution:
- Context Tests: 7 cases (AuthContext)
- Component Tests: 5 cases (ErrorBoundary)
- Integration Tests: 3 cases (App)

---

## Mocked Dependencies

All external dependencies properly mocked for reliable testing:
-  Expo modules (LinearGradient, SecureStore, LocalAuth)
-  AsyncStorage
-  Polkadot.js API
-  Supabase client
-  React Native components
-  i18n initialization

---

## Running Tests

```bash
# Run all tests
npm test

# Watch mode (for development)
npm run test:watch

# Coverage report
npm run test:coverage
```

---

## Future Test Additions

Recommended areas for additional test coverage:
- [ ] PolkadotContext tests (wallet connection, blockchain queries)
- [ ] Screen component tests (SignIn, SignUp, Governance, etc.)
- [ ] Blockchain transaction tests (mocked pallet calls)
- [ ] Navigation tests
- [ ] E2E tests with Detox

---

## Notes

- All tests use React Native Testing Library best practices
- Async operations properly handled with waitFor()
- Mocks configured for deterministic test results
- Coverage thresholds enforced at 70%
- Tests run in isolation with proper cleanup
2025-11-22 04:29:23 +00:00
..

Pezkuwi Mobile App

Status: Core Features Complete - Ready for Testing

World-class mobile application for Pezkuwi blockchain with advanced multi-language support.

🌟 Key Features

Implemented

Multi-Language Support (6 Languages)

  • EN - English
  • TR - Türkçe (Turkish)
  • KMR - Kurmancî (Kurdish - Kurmanji)
  • CKB - سۆرانی (Kurdish - Sorani)
  • AR - العربية (Arabic)
  • FA - فارسی (Persian/Farsi)

Language System:

  • User selects language on welcome screen
  • Selected language is persistent across the entire app
  • NO hard-coded language strings
  • Settings screen allows language change anytime
  • RTL support for Arabic, Sorani, and Persian
  • All text dynamically translated using i18next

Authentication Flow

  • Welcome screen with beautiful language picker
  • Sign In screen (fully localized)
  • Sign Up screen (fully localized)
  • Smooth navigation between screens
  • Kurdistan flag colors throughout

Main Dashboard

  • Modern, professional UI
  • Quick access to all features
  • Balance display (0.00 HEZ)
  • Staking stats
  • Rewards tracking
  • Active proposals counter
  • Navigation to: Wallet, Staking, Governance, DEX, History, Settings

Settings Screen

  • Language selection (change anytime)
  • Theme settings
  • Notification preferences
  • Security settings
  • About section
  • Logout functionality

Pending Features

  • Polkadot.js mobile wallet integration
  • Live blockchain data (proposals, staking, treasury)
  • Biometric authentication
  • Push notifications
  • Transaction history
  • Governance voting
  • DEX/Swap functionality

🛠 Technology Stack

  • Framework: React Native with Expo
  • Language: TypeScript
  • Navigation: React Navigation v6
  • i18n: react-i18next
  • Storage: AsyncStorage (for language preference)
  • UI: Custom components with Kurdistan colors
  • State Management: React Context API

🎨 Design System

Kurdistan Flag Colors:

  • Kesk (Green): #00A94F - Primary color
  • Sor (Red): #EE2A35 - Accent color
  • Zer (Gold): #FFD700 - Secondary accent
  • Spi (White): #FFFFFF - Backgrounds
  • Reş (Black): #000000 - Text

📱 Screens

  1. WelcomeScreen - Language selection with Kurdistan gradient
  2. SignInScreen - Beautiful login form
  3. SignUpScreen - Registration with validation
  4. DashboardScreen - Main app hub
  5. SettingsScreen - Full control including language change

🚀 Getting Started

Installation

cd mobile
npm install

Run on iOS

npm run ios

Run on Android

npm run android

Run on Web (for testing)

npm run web

📂 Project Structure

mobile/
├── src/
│   ├── i18n/
│   │   ├── index.ts           # i18n configuration
│   │   └── locales/           # Translation files (6 languages)
│   ├── screens/
│   │   ├── WelcomeScreen.tsx
│   │   ├── SignInScreen.tsx
│   │   ├── SignUpScreen.tsx
│   │   ├── DashboardScreen.tsx
│   │   └── SettingsScreen.tsx
│   ├── navigation/
│   │   └── AppNavigator.tsx   # Navigation logic
│   ├── contexts/
│   │   └── LanguageContext.tsx # Language management
│   ├── theme/
│   │   └── colors.ts           # Kurdistan colors
│   └── types/
├── App.tsx                     # Main app entry
└── package.json

🌍 Language System Details

How It Works:

  1. App starts → User sees Welcome screen
  2. User selects language (EN/TR/KMR/CKB/AR/FA)
  3. Language choice is saved to AsyncStorage
  4. ALL app text uses t('key') from i18next
  5. User can change language in Settings anytime
  6. NO hard-coded strings anywhere

RTL Support:

  • CKB (Sorani), AR (Arabic), FA (Persian) are RTL
  • Layout automatically adapts for RTL languages
  • App restart may be required for full RTL switch

🔮 Next Steps

  1. Polkadot.js Integration

    • Wallet connection
    • Transaction signing
    • Account management
  2. Live Blockchain Data

    • Connect to Pezkuwi RPC
    • Real-time proposals
    • Staking info
    • Treasury data
  3. Advanced Features

    • Biometric login (Face ID/Touch ID)
    • Push notifications
    • QR code scanning
    • Transaction history

📝 Development Notes

  • Uses shared code from ../shared/ directory
  • Maintains consistency with web app UX
  • Follows mobile-first design principles
  • Comprehensive error handling
  • Professional logging

🎯 Mission Accomplished

This mobile app is built with ZERO hard-coded language. Every single text element is dynamically translated based on user's language selection. The app truly speaks the user's language - whether they're Turkish, Kurdish, Arab, Persian, or English speaker.

Kurdistan colors shine throughout - from the gradient welcome screen to every button and card.


Built with ❤️ for Pezkuwi Blockchain