summaryrefslogtreecommitdiff
path: root/billing/test/integration/customer_creation_test.rb
diff options
context:
space:
mode:
authorjessib <jessib@riseup.net>2013-08-15 12:09:26 -0700
committerjessib <jessib@riseup.net>2013-08-15 12:09:26 -0700
commitd948614d3e2bc190b9c819e961b94c03d7a24fcd (patch)
tree3407cab5a167855668f57edc7a0a2d202ebce2ba /billing/test/integration/customer_creation_test.rb
parentd0a15a50e1fdf08f2283562453d4e803aa7b31c8 (diff)
Some notes on tests that don't work. (Failing tests are skipped though.)
Diffstat (limited to 'billing/test/integration/customer_creation_test.rb')
-rw-r--r--billing/test/integration/customer_creation_test.rb28
1 files changed, 25 insertions, 3 deletions
diff --git a/billing/test/integration/customer_creation_test.rb b/billing/test/integration/customer_creation_test.rb
index 532a5b5..9555ef1 100644
--- a/billing/test/integration/customer_creation_test.rb
+++ b/billing/test/integration/customer_creation_test.rb
@@ -18,22 +18,28 @@ class CustomerCreationTest < ActionDispatch::IntegrationTest
# Let's test both steps together with capybara
#
- # This test is nice and clean but also a bit fragil:
+ # This test is nice and clean but also a bit fragile:
# RackTest assumes all requests to be local. So we need
# BraintreeTestApp for the braintree transparent redirect to work.
+ #
+ # this mystifies me why this works. when i type the click_button line (and the
+ # customer.braintree_customer line) in the debugger, it gives a timeout,
+ # but it works fine embedded in the test.
test "create customer with braintree" do
visit '/'
click_link 'Billing Settings'
+ # i am a bit unclear why this works, as it seems there will be validation errors
assert_difference("Customer.count") do
- click_button 'Save Payment Info'
+ click_button 'Save Payment Info' # this gives me a timeout
end
-
assert customer = Customer.find_by_user_id(@user.id)
assert customer.braintree_customer
end
# We only test the confirmation here.
# The request to Braintree is triggered outside of rails
+ # In skippped test below, we see this works even if the attributes are
+ # for a broken customer
test "successfully confirms customer creation" do
response = post_transparent_redirect :create_customer_data,
customer: FactoryGirl.attributes_for(:braintree_customer),
@@ -48,6 +54,22 @@ class CustomerCreationTest < ActionDispatch::IntegrationTest
assert customer.braintree_customer
end
+
+ test "failed customer creation" do
+ skip "cannot get customer creation to fail"
+
+ FakeBraintree.decline_all_cards!
+ response = post_transparent_redirect :create_customer_data,
+ customer: FactoryGirl.attributes_for(:broken_customer),
+ redirect_url: confirm_customer_url
+
+ assert_no_difference("Customer.count") do
+ post response['Location'] #this gives me a timeout when run alone
+ end
+ assert_nil Customer.find_by_user_id(@user.id)
+
+ end
+
def post_transparent_redirect(type, data)
params = data.dup
params[:tr_data] = Braintree::TransparentRedirect.send(type, params)