diff options
author | Azul <azul@leap.se> | 2013-07-01 09:55:54 +0200 |
---|---|---|
committer | Azul <azul@leap.se> | 2013-07-17 10:47:14 +0200 |
commit | a49c63eb117abf47ca1804493c25ae34804f8ee1 (patch) | |
tree | 4393c57948fecc23cbdf4f91051768bd8c4d5c3a | |
parent | d3e4489cc4833c196eeef77f4fe0680c3f7e7a09 (diff) |
test non braintree parts of customer, validate user
-rw-r--r-- | billing/app/models/customer.rb | 2 | ||||
-rw-r--r-- | billing/test/factories.rb | 11 | ||||
-rw-r--r-- | billing/test/unit/customer_test.rb | 47 |
3 files changed, 39 insertions, 21 deletions
diff --git a/billing/app/models/customer.rb b/billing/app/models/customer.rb index 161f763..7d35756 100644 --- a/billing/app/models/customer.rb +++ b/billing/app/models/customer.rb @@ -6,6 +6,8 @@ class Customer < CouchRest::Model::Base belongs_to :user property :braintree_customer_id + validates :user, presence: true + design do view :by_user_id view :by_braintree_customer_id diff --git a/billing/test/factories.rb b/billing/test/factories.rb new file mode 100644 index 0000000..8648847 --- /dev/null +++ b/billing/test/factories.rb @@ -0,0 +1,11 @@ +FactoryGirl.define do + + factory :customer do + user + + factory :braintree_customer do + braintree_customer_id { 1 } + end + end + +end diff --git a/billing/test/unit/customer_test.rb b/billing/test/unit/customer_test.rb index 4ed6392..abcf96a 100644 --- a/billing/test/unit/customer_test.rb +++ b/billing/test/unit/customer_test.rb @@ -1,38 +1,43 @@ require 'test_helper' class CustomerTest < ActiveSupport::TestCase - setup do - #cannot get this working with FakeBraintree becuase the methods in customer.rb try to find the customer in braintree itself. - - @user = FactoryGirl.build(:user) - @user.save - @customer = Customer.new(:user_id => @user.id) - result = Braintree::Customer.create() - @customer.braintree_customer_id = result.customer.id - @customer.save - @braintree_customer_data = Braintree::Customer.find(@customer.braintree_customer_id) + setup do + @customer = FactoryGirl.build(:customer) + end - result = Braintree::Customer.create(:credit_card => { :number => "5105105105105100", :expiration_date => "05/2012"}) + test "test set of attributes should be valid" do + @customer.valid? + assert_equal Hash.new, @customer.errors.messages end - teardown do - @user.destroy - @customer.destroy - Braintree::Customer.delete(@customer.braintree_customer_id) + test "customer belongs to user" do + assert_equal User, @customer.user.class end - test "default credit card" do - assert_nil @customer.default_credit_card(@braintree_customer_data) - Braintree::Customer.update(@customer.braintree_customer_id, :credit_card => { :number => "5105105105105100", :expiration_date => "05/2012" } ) - assert_not_nil @customer.default_credit_card - assert_equal @customer.default_credit_card.expiration_date, "05/2012" + test "user validation" do + @customer.user = nil + assert !@customer.valid? end + test "has no payment info" do + assert !@customer.braintree_customer_id + assert !@customer.has_payment_info? + end - test "single subscription" do + test "with no braintree data" do + skip "this is currently commented out in the model" + assert_equal @customer, @customer.with_braintree_data! + end + test "without default credit card" do + assert_nil @customer.default_credit_card + end + test "user with braintree id" do + @customer = FactoryGirl.build(:braintree_customer) + assert @customer.braintree_customer_id + assert @customer.has_payment_info? end end |