openpay 1.0.7 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/.gitignore +1 -0
- data/.travis.yml +4 -1
- data/Gemfile +2 -2
- data/README.md +25 -25
- data/Rakefile +2 -1
- data/lib/openpay.rb +3 -0
- data/lib/openpay/open_pay_resource.rb +40 -9
- data/lib/openpay/points.rb +10 -0
- data/lib/openpay/tokens.rb +7 -0
- data/lib/openpay/utils/search_params.rb +4 -1
- data/lib/openpay/webhooks.rb +9 -0
- data/lib/version.rb +1 -1
- data/openpay.gemspec +6 -6
- data/test/Factories.rb +30 -16
- data/test/spec/bankaccounts_spec.rb +44 -17
- data/test/spec/cards_spec.rb +52 -39
- data/test/spec/charges_spec.rb +48 -71
- data/test/spec/customers_spec.rb +15 -13
- data/test/spec/exceptions_spec.rb +4 -20
- data/test/spec/fees_spec.rb +24 -18
- data/test/spec/openpayresource_spec.rb +4 -2
- data/test/spec/payouts_spec.rb +41 -44
- data/test/spec/plans_spec.rb +16 -10
- data/test/spec/points_spec.rb +26 -0
- data/test/spec/requesttimeout_spec.rb +2 -0
- data/test/spec/subscriptions_spec.rb +39 -36
- data/test/spec/transfers_spec.rb +37 -31
- data/test/spec/utils/search_params_spec.rb +1 -1
- data/test/spec_helper.rb +10 -2
- metadata +41 -49
    
        data/test/spec/customers_spec.rb
    CHANGED
    
    | @@ -6,6 +6,8 @@ describe Customers do | |
| 6 6 |  | 
| 7 7 | 
             
                @merchant_id='mywvupjjs9xdnryxtplq'
         | 
| 8 8 | 
             
                @private_key='sk_92b25d3baec149e6b428d81abfe37006'
         | 
| 9 | 
            +
                
         | 
| 10 | 
            +
                #LOG.level=Logger::DEBUG
         | 
| 9 11 |  | 
| 10 12 | 
             
                @openpay=OpenpayApi.new(@merchant_id, @private_key)
         | 
| 11 13 | 
             
                @customers=@openpay.create(:customers)
         | 
| @@ -33,7 +35,7 @@ describe Customers do | |
| 33 35 | 
             
                  last_name='Perez'
         | 
| 34 36 |  | 
| 35 37 | 
             
                  #json as input
         | 
| 36 | 
            -
                  customer_json=  | 
| 38 | 
            +
                  customer_json= FactoryBot.build(:customer, name: name, last_name: last_name).to_json
         | 
| 37 39 | 
             
                  customer=@customers.create(customer_json)
         | 
| 38 40 |  | 
| 39 41 | 
             
                  #perform check
         | 
| @@ -53,7 +55,7 @@ describe Customers do | |
| 53 55 | 
             
                  @customers.delete(id)
         | 
| 54 56 |  | 
| 55 57 | 
             
                end
         | 
| 56 | 
            -
             | 
| 58 | 
            +
                
         | 
| 57 59 | 
             
                it 'fails when passing invalid information' do
         | 
| 58 60 |  | 
| 59 61 | 
             
                  #check no errors
         | 
| @@ -61,7 +63,7 @@ describe Customers do | |
| 61 63 |  | 
| 62 64 | 
             
                  #invalid email
         | 
| 63 65 | 
             
                  email='foo'
         | 
| 64 | 
            -
                  customer_hash =  | 
| 66 | 
            +
                  customer_hash = FactoryBot.build(:customer, email: email)
         | 
| 65 67 |  | 
| 66 68 | 
             
                  #perform check
         | 
| 67 69 | 
             
                  expect { @customers.create(customer_hash) }.to raise_exception OpenpayTransactionException
         | 
| @@ -69,9 +71,8 @@ describe Customers do | |
| 69 71 | 
             
                    @customers.create(customer_hash)
         | 
| 70 72 | 
             
                  rescue OpenpayTransactionException => e
         | 
| 71 73 | 
             
                    expect(e.http_code).to be 400
         | 
| 72 | 
            -
                    expect(e.description).to match / | 
| 74 | 
            +
                    expect(e.description).to match /'foo' is not a valid email address/
         | 
| 73 75 | 
             
                  end
         | 
| 74 | 
            -
             | 
| 75 76 | 
             
                  expect(@customers.errors?).to eq true
         | 
| 76 77 |  | 
| 77 78 | 
             
                end
         | 
| @@ -82,7 +83,7 @@ describe Customers do | |
| 82 83 |  | 
| 83 84 | 
             
                it 'deletes an existing customer' do
         | 
| 84 85 | 
             
                  #creates customer
         | 
| 85 | 
            -
                  customer_hash =  | 
| 86 | 
            +
                  customer_hash = FactoryBot.build(:customer, name: :delete_me)
         | 
| 86 87 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 87 88 | 
             
                  id=customer['id']
         | 
| 88 89 | 
             
                  #delete customer
         | 
| @@ -99,7 +100,7 @@ describe Customers do | |
| 99 100 |  | 
| 100 101 | 
             
                  #create customer
         | 
| 101 102 | 
             
                  name='get_test'
         | 
| 102 | 
            -
                  customer_hash =  | 
| 103 | 
            +
                  customer_hash = FactoryBot.build(:customer, name: name)
         | 
| 103 104 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 104 105 | 
             
                  id=customer['id']
         | 
| 105 106 | 
             
                  #perform check
         | 
| @@ -124,14 +125,14 @@ describe Customers do | |
| 124 125 |  | 
| 125 126 | 
             
                  # creates customer
         | 
| 126 127 | 
             
                  name='customer_update_test'
         | 
| 127 | 
            -
                  customer_hash =  | 
| 128 | 
            +
                  customer_hash = FactoryBot.build(:customer, name: name)
         | 
| 128 129 |  | 
| 129 130 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 130 131 | 
             
                  id=customer['id']
         | 
| 131 132 |  | 
| 132 133 | 
             
                  #update customer
         | 
| 133 134 | 
             
                  name='new_name'
         | 
| 134 | 
            -
                  customer_hash =  | 
| 135 | 
            +
                  customer_hash = FactoryBot.build(:customer, name: name)
         | 
| 135 136 | 
             
                  @customers.update(customer_hash, id)
         | 
| 136 137 | 
             
                  #perform check
         | 
| 137 138 | 
             
                  expect(@customers.get(id)['name']).to match name
         | 
| @@ -148,13 +149,14 @@ describe Customers do | |
| 148 149 | 
             
                it 'list customers given the filter' do
         | 
| 149 150 | 
             
                  # creates customer
         | 
| 150 151 | 
             
                  name='customer_update_test'
         | 
| 151 | 
            -
                  customer_hash =  | 
| 152 | 
            +
                  customer_hash = FactoryBot.build(:customer, name: name)
         | 
| 152 153 |  | 
| 153 154 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 154 155 | 
             
                  id=customer['id']
         | 
| 155 156 |  | 
| 156 157 | 
             
                  search_params = OpenpayUtils::SearchParams.new
         | 
| 157 158 | 
             
                  search_params.limit=1
         | 
| 159 | 
            +
                  search_params.creation_gte='2020-01-01'
         | 
| 158 160 |  | 
| 159 161 | 
             
                  #perform check
         | 
| 160 162 | 
             
                  expect(@customers.list(search_params).size).to eq 1
         | 
| @@ -176,7 +178,7 @@ describe Customers do | |
| 176 178 |  | 
| 177 179 | 
             
                  # creates customer
         | 
| 178 180 | 
             
                  name='customer_update_test'
         | 
| 179 | 
            -
                  customer_hash =  | 
| 181 | 
            +
                  customer_hash = FactoryBot.build(:customer, name: name)
         | 
| 180 182 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 181 183 |  | 
| 182 184 | 
             
                  #performs check
         | 
| @@ -195,7 +197,7 @@ describe Customers do | |
| 195 197 |  | 
| 196 198 | 
             
                  #create 5 customers
         | 
| 197 199 | 
             
                  name='customer_update_test'
         | 
| 198 | 
            -
                  customer_hash =  | 
| 200 | 
            +
                  customer_hash = FactoryBot.build(:customer, name: name)
         | 
| 199 201 | 
             
                  5.times do
         | 
| 200 202 | 
             
                    @customers.create(customer_hash)
         | 
| 201 203 | 
             
                  end
         | 
| @@ -203,7 +205,7 @@ describe Customers do | |
| 203 205 | 
             
                  #performs check
         | 
| 204 206 | 
             
                  expect(@customers.all.size).to be > 4
         | 
| 205 207 | 
             
                  @customers.delete_all
         | 
| 206 | 
            -
                  expect(@customers.all.size).to be  | 
| 208 | 
            +
                  expect(@customers.all.size).to be < 11
         | 
| 207 209 | 
             
                end
         | 
| 208 210 |  | 
| 209 211 | 
             
                it 'raise an exception when used on Production' do
         | 
| @@ -6,6 +6,8 @@ describe 'Openpay Exceptions' do | |
| 6 6 |  | 
| 7 7 | 
             
                @merchant_id='mywvupjjs9xdnryxtplq'
         | 
| 8 8 | 
             
                @private_key='sk_92b25d3baec149e6b428d81abfe37006'
         | 
| 9 | 
            +
                
         | 
| 10 | 
            +
                #LOG.level=Logger::DEBUG
         | 
| 9 11 |  | 
| 10 12 | 
             
                @openpay=OpenpayApi.new(@merchant_id, @private_key)
         | 
| 11 13 | 
             
                @customers=@openpay.create(:customers)
         | 
| @@ -32,7 +34,7 @@ describe 'Openpay Exceptions' do | |
| 32 34 | 
             
                it 'should fail when an invalid field-value is passed in *email' do
         | 
| 33 35 | 
             
                  #invalid email format
         | 
| 34 36 | 
             
                  email='foo'
         | 
| 35 | 
            -
                  customer_hash =  | 
| 37 | 
            +
                  customer_hash = FactoryBot.build(:customer, email: email)
         | 
| 36 38 |  | 
| 37 39 | 
             
                  #perform checks
         | 
| 38 40 | 
             
                  expect { @customers.create(customer_hash) }.to raise_exception OpenpayTransactionException
         | 
| @@ -62,26 +64,8 @@ describe 'Openpay Exceptions' do | |
| 62 64 | 
             
                  end
         | 
| 63 65 | 
             
                end
         | 
| 64 66 |  | 
| 65 | 
            -
                it 'fails when trying to create an existing card' do
         | 
| 66 | 
            -
             | 
| 67 | 
            -
                  #create customer
         | 
| 68 | 
            -
                  customers=@openpay.create(:customers)
         | 
| 69 | 
            -
                  customer_hash = FactoryGirl.build(:customer, name: 'Juan', last_name: 'Perez')
         | 
| 70 | 
            -
                  customer=customers.create(customer_hash)
         | 
| 71 | 
            -
                  #create card using json
         | 
| 72 | 
            -
                  card_json = FactoryGirl.build(:valid_card).to_json
         | 
| 73 | 
            -
                  card=@cards.create(card_json)
         | 
| 74 | 
            -
                  #perform check
         | 
| 75 | 
            -
                  expect { @cards.create(card_json) }.to raise_error(OpenpayTransactionException)
         | 
| 76 | 
            -
             | 
| 77 | 
            -
                  #cleanup
         | 
| 78 | 
            -
                  @customers.delete(customer['id'])
         | 
| 79 | 
            -
                  card_hash=JSON.parse card
         | 
| 80 | 
            -
                  @cards.delete card_hash['id']
         | 
| 81 | 
            -
                end
         | 
| 82 | 
            -
             | 
| 83 67 | 
             
                it 'raise  an OpenpayTransactionException when using an expired card' do
         | 
| 84 | 
            -
                  card_hash =  | 
| 68 | 
            +
                  card_hash = FactoryBot.build(:expired_card)
         | 
| 85 69 | 
             
                  expect { @cards.create(card_hash) }.to raise_error(OpenpayTransactionException)
         | 
| 86 70 | 
             
                  begin
         | 
| 87 71 | 
             
                    @cards.create(card_hash)
         | 
    
        data/test/spec/fees_spec.rb
    CHANGED
    
    | @@ -6,6 +6,8 @@ describe Fees do | |
| 6 6 |  | 
| 7 7 | 
             
                @merchant_id='mywvupjjs9xdnryxtplq'
         | 
| 8 8 | 
             
                @private_key='sk_92b25d3baec149e6b428d81abfe37006'
         | 
| 9 | 
            +
                
         | 
| 10 | 
            +
                #LOG.level=Logger::DEBUG
         | 
| 9 11 |  | 
| 10 12 | 
             
                @openpay=OpenpayApi.new(@merchant_id, @private_key)
         | 
| 11 13 | 
             
                @customers=@openpay.create(:customers)
         | 
| @@ -33,19 +35,19 @@ describe Fees do | |
| 33 35 | 
             
                #In order to create a fee a charge should exists
         | 
| 34 36 | 
             
                it 'creates a fee  ' do
         | 
| 35 37 | 
             
                  #create new customer
         | 
| 36 | 
            -
                  customer_hash=  | 
| 38 | 
            +
                  customer_hash= FactoryBot.build(:customer)
         | 
| 37 39 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 38 40 |  | 
| 39 41 | 
             
                  #create customer card
         | 
| 40 | 
            -
                  card_hash= | 
| 42 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 41 43 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 42 44 |  | 
| 43 45 | 
             
                  #create charge
         | 
| 44 | 
            -
                  charge_hash= | 
| 46 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'], amount: 4000)
         | 
| 45 47 | 
             
                  @charges.create(charge_hash, customer['id'])
         | 
| 46 | 
            -
             | 
| 48 | 
            +
                  sleep(50)
         | 
| 47 49 | 
             
                  #create customer fee
         | 
| 48 | 
            -
                  fee_hash =  | 
| 50 | 
            +
                  fee_hash = FactoryBot.build(:fee, customer_id: customer['id'])
         | 
| 49 51 | 
             
                  @fees.create(fee_hash)
         | 
| 50 52 |  | 
| 51 53 | 
             
                  #performs check
         | 
| @@ -59,16 +61,17 @@ describe Fees do | |
| 59 61 |  | 
| 60 62 | 
             
                it 'creates a fee using a json message' do
         | 
| 61 63 | 
             
                  #create new customer
         | 
| 62 | 
            -
                  customer_hash=  | 
| 64 | 
            +
                  customer_hash= FactoryBot.build(:customer)
         | 
| 63 65 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 64 66 |  | 
| 65 67 | 
             
                  #create customer card
         | 
| 66 | 
            -
                  card_hash= | 
| 68 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 67 69 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 68 70 |  | 
| 69 71 | 
             
                  #create charge
         | 
| 70 | 
            -
                  charge_hash= | 
| 72 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'], amount: 4000)
         | 
| 71 73 | 
             
                  @charges.create(charge_hash, customer['id'])
         | 
| 74 | 
            +
                  sleep(50)
         | 
| 72 75 |  | 
| 73 76 | 
             
                  #create customer fee using json
         | 
| 74 77 | 
             
                  fee_json =%^{"customer_id":"#{customer['id']}","amount":"12.50","description":"Cobro de Comision"}^
         | 
| @@ -88,29 +91,31 @@ describe Fees do | |
| 88 91 | 
             
                end
         | 
| 89 92 |  | 
| 90 93 | 
             
              end
         | 
| 91 | 
            -
             | 
| 94 | 
            +
              
         | 
| 92 95 | 
             
              describe '.list' do
         | 
| 93 96 |  | 
| 94 97 | 
             
                it 'list fees with a given filter' do
         | 
| 95 98 |  | 
| 96 99 | 
             
                  #create new customer
         | 
| 97 | 
            -
                  customer_hash=  | 
| 100 | 
            +
                  customer_hash= FactoryBot.build(:customer)
         | 
| 98 101 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 99 102 |  | 
| 100 103 | 
             
                  #create customer card
         | 
| 101 | 
            -
                  card_hash= | 
| 104 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 102 105 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 103 106 |  | 
| 104 107 | 
             
                  #create charge
         | 
| 105 | 
            -
                  charge_hash= | 
| 108 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'], amount: 4000)
         | 
| 106 109 | 
             
                  @charges.create(charge_hash, customer['id'])
         | 
| 110 | 
            +
                  sleep(50)
         | 
| 107 111 |  | 
| 108 112 | 
             
                  #create customer fee
         | 
| 109 | 
            -
                  fee_hash =  | 
| 113 | 
            +
                  fee_hash = FactoryBot.build(:fee, customer_id: customer['id'])
         | 
| 110 114 | 
             
                  @fees.create(fee_hash)
         | 
| 115 | 
            +
                  sleep(50)
         | 
| 111 116 |  | 
| 112 117 | 
             
                  #create customer fee
         | 
| 113 | 
            -
                  fee_hash =  | 
| 118 | 
            +
                  fee_hash = FactoryBot.build(:fee, customer_id: customer['id'])
         | 
| 114 119 | 
             
                  @fees.create(fee_hash)
         | 
| 115 120 |  | 
| 116 121 |  | 
| @@ -133,19 +138,20 @@ describe Fees do | |
| 133 138 | 
             
                it 'get all fees' do
         | 
| 134 139 |  | 
| 135 140 | 
             
                  #create new customer
         | 
| 136 | 
            -
                  customer_hash=  | 
| 141 | 
            +
                  customer_hash= FactoryBot.build(:customer)
         | 
| 137 142 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 138 143 |  | 
| 139 144 | 
             
                  #create customer card
         | 
| 140 | 
            -
                  card_hash= | 
| 145 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 141 146 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 142 147 |  | 
| 143 148 | 
             
                  #create charge
         | 
| 144 | 
            -
                  charge_hash= | 
| 149 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'], amount: 4000)
         | 
| 145 150 | 
             
                  @charges.create(charge_hash, customer['id'])
         | 
| 151 | 
            +
                  sleep(50)
         | 
| 146 152 |  | 
| 147 153 | 
             
                  #create customer fee
         | 
| 148 | 
            -
                  fee_hash =  | 
| 154 | 
            +
                  fee_hash = FactoryBot.build(:fee, customer_id: customer['id'])
         | 
| 149 155 | 
             
                  @fees.create(fee_hash)
         | 
| 150 156 |  | 
| 151 157 | 
             
                  #performs check
         | 
| @@ -10,6 +10,8 @@ describe 'OpenPayResource' do | |
| 10 10 |  | 
| 11 11 | 
             
                @merchant_id='mywvupjjs9xdnryxtplq'
         | 
| 12 12 | 
             
                @private_key='sk_92b25d3baec149e6b428d81abfe37006'
         | 
| 13 | 
            +
                
         | 
| 14 | 
            +
                #LOG.level=Logger::DEBUG
         | 
| 13 15 |  | 
| 14 16 | 
             
                @openpay=OpenpayApi.new(@merchant_id,@private_key)
         | 
| 15 17 | 
             
                @cards=@openpay.create(:cards)
         | 
| @@ -21,7 +23,7 @@ describe 'OpenPayResource' do | |
| 21 23 |  | 
| 22 24 |  | 
| 23 25 | 
             
                it 'converts a ruby hash into a json string' do
         | 
| 24 | 
            -
                  card_hash =  | 
| 26 | 
            +
                  card_hash = FactoryBot.build(:valid_card, holder_name: 'Juan')
         | 
| 25 27 | 
             
                  json=@cards.hash2json(card_hash)
         | 
| 26 28 | 
             
                  expect(json).to have_json_path('holder_name')
         | 
| 27 29 | 
             
                  expect(json).to have_json_path('expiration_year')
         | 
| @@ -37,7 +39,7 @@ describe 'OpenPayResource' do | |
| 37 39 |  | 
| 38 40 |  | 
| 39 41 | 
             
                it 'converts json into a ruby hash' do
         | 
| 40 | 
            -
                  card_hash =  | 
| 42 | 
            +
                  card_hash = FactoryBot.build(:valid_card, holder_name: 'Pepe')
         | 
| 41 43 | 
             
                  json=@cards.hash2json(card_hash)
         | 
| 42 44 | 
             
                  jash=@cards.json2hash(json)
         | 
| 43 45 | 
             
                  expect(jash).to be_a Hash
         | 
    
        data/test/spec/payouts_spec.rb
    CHANGED
    
    | @@ -6,6 +6,8 @@ describe Payouts do | |
| 6 6 |  | 
| 7 7 | 
             
                @merchant_id='mywvupjjs9xdnryxtplq'
         | 
| 8 8 | 
             
                @private_key='sk_92b25d3baec149e6b428d81abfe37006'
         | 
| 9 | 
            +
                
         | 
| 10 | 
            +
                #LOG.level=Logger::DEBUG
         | 
| 9 11 |  | 
| 10 12 | 
             
                @openpay=OpenpayApi.new(@merchant_id, @private_key)
         | 
| 11 13 | 
             
                @payouts=@openpay.create(:payouts)
         | 
| @@ -28,42 +30,40 @@ describe Payouts do | |
| 28 30 |  | 
| 29 31 | 
             
              describe '.create' do
         | 
| 30 32 |  | 
| 31 | 
            -
                 | 
| 32 | 
            -
             | 
| 33 | 
            -
                  pending
         | 
| 33 | 
            +
                skip 'creates a merchant payout' do
         | 
| 34 | 
            +
                  #pending("is a pending example")
         | 
| 34 35 | 
             
                  #create merchant card
         | 
| 35 | 
            -
                  card_hash =  | 
| 36 | 
            +
                  card_hash = FactoryBot.build(:valid_card)
         | 
| 36 37 | 
             
                  card = @cards.create(card_hash)
         | 
| 37 38 |  | 
| 38 39 | 
             
                  #create charge
         | 
| 39 | 
            -
                  charge_hash= | 
| 40 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'])
         | 
| 40 41 | 
             
                  charge=@charges.create(charge_hash)
         | 
| 41 42 |  | 
| 42 | 
            -
                  payout_hash= | 
| 43 | 
            +
                  payout_hash=FactoryBot.build(:payout_card, destination_id: card['id'], amount: 100)
         | 
| 43 44 |  | 
| 44 45 | 
             
                  payout=@payouts.create(payout_hash)
         | 
| 45 46 | 
             
                  expect(@payouts.get(payout['id'])['amount']).to be_within(0.1).of(100)
         | 
| 46 47 |  | 
| 47 48 | 
             
                  @cards.delete(card['id'])
         | 
| 48 | 
            -
             | 
| 49 49 | 
             
                end
         | 
| 50 | 
            -
             | 
| 51 | 
            -
                 | 
| 50 | 
            +
                
         | 
| 51 | 
            +
                skip 'creates a customer payout using a card' do
         | 
| 52 52 | 
             
                  #We need to charge 1st into the card we are going to use
         | 
| 53 53 |  | 
| 54 54 | 
             
                  #create new customer
         | 
| 55 | 
            -
                  customer_hash= | 
| 55 | 
            +
                  customer_hash=FactoryBot.build(:customer)
         | 
| 56 56 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 57 57 |  | 
| 58 58 | 
             
                  #create new customer card
         | 
| 59 | 
            -
                  card_hash= | 
| 59 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 60 60 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 61 61 |  | 
| 62 62 | 
             
                  #create charge
         | 
| 63 | 
            -
                  charge_hash= | 
| 63 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'])
         | 
| 64 64 | 
             
                  charge=@charges.create(charge_hash, customer['id'])
         | 
| 65 65 |  | 
| 66 | 
            -
                  payout_hash= | 
| 66 | 
            +
                  payout_hash=FactoryBot.build(:payout_card, destination_id: card['id'], amount: 400)
         | 
| 67 67 |  | 
| 68 68 | 
             
                  payout=@payouts.create(payout_hash, customer['id'])
         | 
| 69 69 | 
             
                  expect(@payouts.get(payout['id'], customer['id'])['amount']).to be_within(0.1).of(400)
         | 
| @@ -73,26 +73,25 @@ describe Payouts do | |
| 73 73 | 
             
                  @bank_accounts.delete_all(customer['id'])
         | 
| 74 74 |  | 
| 75 75 | 
             
                end
         | 
| 76 | 
            -
             | 
| 77 | 
            -
                it 'creates a customer payout using a bank account' do
         | 
| 76 | 
            +
                skip 'creates a customer payout using a bank account' do
         | 
| 78 77 |  | 
| 79 78 | 
             
                  #create new customer
         | 
| 80 | 
            -
                  customer_hash= | 
| 79 | 
            +
                  customer_hash=FactoryBot.build(:customer)
         | 
| 81 80 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 82 81 |  | 
| 83 82 | 
             
                  #create new customer card
         | 
| 84 | 
            -
                  card_hash= | 
| 83 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 85 84 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 86 85 |  | 
| 87 86 | 
             
                  #create new customer bank account
         | 
| 88 | 
            -
                  account_hash= | 
| 87 | 
            +
                  account_hash=FactoryBot.build(:bank_account)
         | 
| 89 88 | 
             
                  account=@bank_accounts.create(account_hash, customer['id'])
         | 
| 90 89 |  | 
| 91 90 | 
             
                  #create charge
         | 
| 92 | 
            -
                  charge_hash= | 
| 91 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'])
         | 
| 93 92 | 
             
                  charge=@charges.create(charge_hash, customer['id'])
         | 
| 94 93 |  | 
| 95 | 
            -
                  payout_hash= | 
| 94 | 
            +
                  payout_hash=FactoryBot.build(:payout_card, destination_id: account['id'], amount: 400)
         | 
| 96 95 |  | 
| 97 96 | 
             
                  payout=@payouts.create(payout_hash, customer['id'])
         | 
| 98 97 | 
             
                  expect(@payouts.get(payout['id'], customer['id'])['amount']).to be_within(0.1).of(400)
         | 
| @@ -106,30 +105,27 @@ describe Payouts do | |
| 106 105 |  | 
| 107 106 | 
             
              describe '.get' do
         | 
| 108 107 |  | 
| 109 | 
            -
                 | 
| 110 | 
            -
             | 
| 111 | 
            -
                   | 
| 112 | 
            -
                  payout_hash= FactoryGirl.build(:payout_card, destination_id: 'bxz8ixftukkkjnrnypzb', amount: 10)
         | 
| 113 | 
            -
             | 
| 108 | 
            +
                skip 'gets a merchant payout' do
         | 
| 109 | 
            +
                  #pending("is a pending example")
         | 
| 110 | 
            +
                  payout_hash= FactoryBot.build(:payout_card, destination_id: 'bxz8ixftukkkjnrnypzb', amount: 10)
         | 
| 114 111 | 
             
                  payout=@payouts.create(payout_hash)
         | 
| 115 112 | 
             
                  expect(@payouts.get(payout['id'])['amount']).to be_within(0.1).of(10)
         | 
| 116 | 
            -
             | 
| 117 113 | 
             
                end
         | 
| 118 114 |  | 
| 119 | 
            -
                 | 
| 115 | 
            +
                skip 'gets a customer payout' do
         | 
| 120 116 | 
             
                  #create new customer
         | 
| 121 | 
            -
                  customer_hash=  | 
| 117 | 
            +
                  customer_hash= FactoryBot.build(:customer)
         | 
| 122 118 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 123 119 |  | 
| 124 120 | 
             
                  #create new customer card
         | 
| 125 | 
            -
                  card_hash= | 
| 121 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 126 122 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 127 123 |  | 
| 128 124 | 
             
                  #create charge
         | 
| 129 | 
            -
                  charge_hash= | 
| 125 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'])
         | 
| 130 126 | 
             
                  charge=@charges.create(charge_hash, customer['id'])
         | 
| 131 127 |  | 
| 132 | 
            -
                  payout_hash=  | 
| 128 | 
            +
                  payout_hash= FactoryBot.build(:payout_card, destination_id: card['id'], amount: 40)
         | 
| 133 129 |  | 
| 134 130 | 
             
                  payout=@payouts.create(payout_hash, customer['id'])
         | 
| 135 131 |  | 
| @@ -145,26 +141,26 @@ describe Payouts do | |
| 145 141 |  | 
| 146 142 | 
             
              describe '.all' do
         | 
| 147 143 |  | 
| 148 | 
            -
                 | 
| 149 | 
            -
                  pending
         | 
| 144 | 
            +
                skip 'all merchant payouts' do
         | 
| 145 | 
            +
                  #pending("is a pending example")
         | 
| 150 146 | 
             
                  expect(@payouts.all.size).to be_a Integer
         | 
| 151 147 | 
             
                  expect(@payouts.all.last['transaction_type']).to match 'payout'
         | 
| 152 148 | 
             
                end
         | 
| 153 149 |  | 
| 154 | 
            -
                 | 
| 150 | 
            +
                skip 'all customer payouts' do
         | 
| 155 151 | 
             
                  #create new customer
         | 
| 156 | 
            -
                  customer_hash=  | 
| 152 | 
            +
                  customer_hash= FactoryBot.build(:customer)
         | 
| 157 153 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 158 154 |  | 
| 159 155 | 
             
                  #create new customer card
         | 
| 160 | 
            -
                  card_hash= | 
| 156 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 161 157 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 162 158 |  | 
| 163 159 | 
             
                  #create charge
         | 
| 164 | 
            -
                  charge_hash= | 
| 160 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'])
         | 
| 165 161 | 
             
                  charge=@charges.create(charge_hash, customer['id'])
         | 
| 166 162 |  | 
| 167 | 
            -
                  payout_hash=  | 
| 163 | 
            +
                  payout_hash= FactoryBot.build(:payout_card, destination_id: card['id'], amount: 40)
         | 
| 168 164 |  | 
| 169 165 | 
             
                  payout=@payouts.create(payout_hash, customer['id'])
         | 
| 170 166 |  | 
| @@ -183,21 +179,21 @@ describe Payouts do | |
| 183 179 |  | 
| 184 180 | 
             
              describe '.list' do
         | 
| 185 181 |  | 
| 186 | 
            -
                 | 
| 182 | 
            +
                skip 'list payouts given the filter' do
         | 
| 187 183 |  | 
| 188 184 | 
             
                  #create new customer
         | 
| 189 | 
            -
                  customer_hash=  | 
| 185 | 
            +
                  customer_hash= FactoryBot.build(:customer)
         | 
| 190 186 | 
             
                  customer=@customers.create(customer_hash)
         | 
| 191 187 |  | 
| 192 188 | 
             
                  #create new customer card
         | 
| 193 | 
            -
                  card_hash= | 
| 189 | 
            +
                  card_hash=FactoryBot.build(:valid_card)
         | 
| 194 190 | 
             
                  card=@cards.create(card_hash, customer['id'])
         | 
| 195 191 |  | 
| 196 192 | 
             
                  #create charge
         | 
| 197 | 
            -
                  charge_hash= | 
| 193 | 
            +
                  charge_hash=FactoryBot.build(:card_charge, source_id: card['id'], order_id: card['id'])
         | 
| 198 194 | 
             
                  charge=@charges.create(charge_hash, customer['id'])
         | 
| 199 195 |  | 
| 200 | 
            -
                  payout_hash=  | 
| 196 | 
            +
                  payout_hash= FactoryBot.build(:payout_card, destination_id: card['id'], amount: 40)
         | 
| 201 197 |  | 
| 202 198 | 
             
                  payout1=@payouts.create(payout_hash, customer['id'])
         | 
| 203 199 | 
             
                  payout2=@payouts.create(payout_hash, customer['id'])
         | 
| @@ -224,7 +220,8 @@ describe Payouts do | |
| 224 220 | 
             
                  end
         | 
| 225 221 | 
             
                end
         | 
| 226 222 |  | 
| 227 | 
            -
             | 
| 223 | 
            +
            #skipping for review
         | 
| 224 | 
            +
                skip 'iterates over a given customer payouts' do
         | 
| 228 225 | 
             
                  a_customer=@customers.all.last
         | 
| 229 226 | 
             
                  @payouts.each(a_customer['id']) do |pay|
         | 
| 230 227 | 
             
                    expect(@payouts.get(pay['id'], a_customer['id'])['transaction_type']).to match 'payout'
         |