~cytrogen/gstack

ref: 403637f0c894f1fd0ebbbb2f2728b439e607ff47 gstack/test/fixtures/review-eval-enum-diff.rb -rw-r--r-- 986 bytes
403637f0 — Garry Tan feat: rotating founder resources in /office-hours closing (v0.13.10.0) (#652) 10 days ago
                                                                                
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# Feature branch version: adds "returned" status but misses consumers
class Order < ApplicationRecord
  STATUSES = %w[pending processing shipped delivered returned].freeze

  validates :status, inclusion: { in: STATUSES }

  def display_status
    case status
    when 'pending'    then 'Awaiting processing'
    when 'processing' then 'Being prepared'
    when 'shipped'    then 'On the way'
    when 'delivered'  then 'Delivered'
    # BUG: 'returned' not handled — falls through to nil
    end
  end

  def can_cancel?
    # BUG: should 'returned' be cancellable? Not considered.
    %w[pending processing].include?(status)
  end

  def notify_customer
    case status
    when 'pending'    then OrderMailer.confirmation(self).deliver_later
    when 'shipped'    then OrderMailer.shipped(self).deliver_later
    when 'delivered'  then OrderMailer.delivered(self).deliver_later
    # BUG: 'returned' has no notification — customer won't know return was received
    end
  end
end