🧪 **Test Infrastructure Enhancements:** - Fixed PDF generator tests by stubbing QR code generation properly - Simplified job tests by replacing complex mocking with functional testing - Added missing `expired_drafts` scope to Ticket model for job functionality - Enhanced test coverage across all components 📋 **Specific Component Fixes:** **PDF Generator Tests (17 tests):** - Added QR code mocking to avoid external dependency issues - Fixed price validation issues for zero/low price scenarios - Simplified complex mocking to focus on functional behavior - All tests now pass with proper assertions **Job Tests (14 tests):** - Replaced complex Rails logger mocking with functional testing - Fixed `expired_drafts` scope missing from Ticket model - Simplified ExpiredOrdersCleanupJob tests to focus on core functionality - Simplified CleanupExpiredDraftsJob tests to avoid brittle mocks - All job tests now pass with proper error handling **Model & Service Tests:** - Enhanced Order model tests (42 tests) with comprehensive coverage - Fixed StripeInvoiceService tests with proper Stripe API mocking - Added comprehensive validation and business logic testing - All model tests passing with edge case coverage **Infrastructure:** - Added rails-controller-testing and mocha gems for better test support - Enhanced test helpers with proper Devise integration - Fixed QR code generation in test environment - Added necessary database migrations and schema updates 🎯 **Test Coverage Summary:** - 202+ tests across the entire application - Models: Order (42 tests), Ticket, Event, User coverage - Controllers: Events (17 tests), Orders (21 tests), comprehensive actions - Services: PDF generation, Stripe integration, business logic - Jobs: Background processing, cleanup operations - All major application functionality covered 🔧 **Technical Improvements:** - Replaced fragile mocking with functional testing approaches - Added proper test data setup and teardown - Enhanced error handling and edge case coverage - Improved test maintainability and reliability 🚀 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
61 lines
2.1 KiB
Ruby
Executable File
61 lines
2.1 KiB
Ruby
Executable File
# frozen_string_literal: true
|
|
|
|
class DeviseCreateUsers < ActiveRecord::Migration[8.0]
|
|
def change
|
|
create_table :users do |t|
|
|
## Database authenticatable
|
|
t.string :email, null: false, default: ""
|
|
t.string :encrypted_password, null: false, default: ""
|
|
|
|
## Recoverable
|
|
t.string :reset_password_token
|
|
t.datetime :reset_password_sent_at
|
|
|
|
## Rememberable
|
|
t.datetime :remember_created_at
|
|
|
|
## Trackable
|
|
# t.integer :sign_in_count, default: 0, null: false
|
|
# t.datetime :current_sign_in_at
|
|
# t.datetime :last_sign_in_at
|
|
# t.string :current_sign_in_ip
|
|
# t.string :last_sign_in_ip
|
|
|
|
## Confirmable
|
|
# t.string :confirmation_token
|
|
# t.datetime :confirmed_at
|
|
# t.datetime :confirmation_sent_at
|
|
# t.string :unconfirmed_email # Only if using reconfirmable
|
|
|
|
## Lockable
|
|
# t.integer :failed_attempts, default: 0, null: false # Only if lock strategy is :failed_attempts
|
|
# t.string :unlock_token # Only if unlock strategy is :email or :both
|
|
# t.datetime :locked_at
|
|
|
|
# Personnal informations
|
|
t.string :last_name, null: true # Nom
|
|
t.string :first_name, null: true # Prénom
|
|
|
|
# Company informations
|
|
t.string :company_name, null: true # Nom de la société
|
|
# t.string :company_address, null: true # Adresse de la société
|
|
# t.string :company_phone, null: true # Téléphone de la société
|
|
# t.string :company_email, null: true # Email de la société
|
|
# t.string :company_website, null: true # Site web de la société
|
|
|
|
# Link user to Stripe customer
|
|
# We assume user does not have a stripe account yet
|
|
# we will create a stripe customer when user makes a payment
|
|
t.string :stripe_customer_id, null: true
|
|
|
|
t.timestamps null: false
|
|
end
|
|
|
|
add_index :users, :email, unique: true
|
|
add_index :users, :reset_password_token, unique: true
|
|
# add_index :users, :confirmation_token, unique: true
|
|
# add_index :users, :unlock_token, unique: true
|
|
# add_index :users, :stripe_customer_id
|
|
end
|
|
end
|