got a little further - still failing
This commit is contained in:
@@ -43,6 +43,7 @@ else:
|
||||
)
|
||||
)
|
||||
|
||||
|
||||
from rowers.models import Rower,PaidPlan
|
||||
from rowers.utils import ProcessorCustomerError
|
||||
|
||||
@@ -208,6 +209,9 @@ def update_subscription(rower,data,method='up'):
|
||||
def create_subscription(rower,data):
|
||||
planid = data['plan']
|
||||
plan = PaidPlan.objects.get(id=planid)
|
||||
print plan
|
||||
print data
|
||||
raise ValueError
|
||||
nonce_from_the_client = data['payment_method_nonce']
|
||||
amount = data['amount']
|
||||
|
||||
@@ -217,22 +221,18 @@ def create_subscription(rower,data):
|
||||
"payment_method_nonce": nonce_from_the_client
|
||||
})
|
||||
|
||||
print 'aap'
|
||||
|
||||
if result.is_success:
|
||||
payment_method_token = result.payment_method.token
|
||||
else:
|
||||
return False,0
|
||||
|
||||
print 'noot'
|
||||
|
||||
result = gateway.subscription.create({
|
||||
"payment_method_token": payment_method_token,
|
||||
"plan_id": plan.external_id
|
||||
})
|
||||
|
||||
if result.is_success:
|
||||
print 'mies'
|
||||
rower.paidplan = plan
|
||||
rower.planexpires = result.subscription.billing_period_end_date
|
||||
rower.teamplanexpires = result.subscription.billing_period_end_date
|
||||
|
||||
@@ -172,6 +172,7 @@ class MockStravalibClient():
|
||||
def update_activity(*args, **kwargs):
|
||||
return StravaActivity()
|
||||
|
||||
def mocked_gateway(*args, **kwargs):
|
||||
class gatewayresult():
|
||||
def __init__(self,*args,**kwargs):
|
||||
self.is_success = kwargs.pop('is_success',True)
|
||||
@@ -180,6 +181,9 @@ class gatewayresult():
|
||||
self.payment_method = payment_method()
|
||||
self.subscription = vsubscription()
|
||||
|
||||
def __unicode__():
|
||||
return "mockedgatewayresult"
|
||||
|
||||
class credit_card():
|
||||
def __init__(self, *args, **kwargs):
|
||||
self.subscriptions = [vsubscription()]
|
||||
@@ -242,10 +246,11 @@ class vtransaction():
|
||||
|
||||
class vsubscription():
|
||||
def update(*args, **kwargs):
|
||||
print 'aap vsubscription'
|
||||
return gatewayresult(is_success=True)
|
||||
|
||||
def cancel(*args, **kwargs):
|
||||
return gatewayresult()
|
||||
return gatewayresult(is_success=True)
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
self.id = 121
|
||||
@@ -257,13 +262,14 @@ class vsubscription():
|
||||
|
||||
class subscription():
|
||||
def create(*args, **kwargs):
|
||||
print 'aap subscription'
|
||||
return gatewayresult(is_success=True)
|
||||
|
||||
def update(*args, **kwargs):
|
||||
return gatewayresult(is_success=True)
|
||||
|
||||
def cancel(*args, **kwargs):
|
||||
return gatewayresult()
|
||||
return gatewayresult(is_success=True)
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
self.id = 121
|
||||
|
||||
@@ -19,46 +19,54 @@ class PaymentTest(TestCase):
|
||||
country = faker.country(),
|
||||
)
|
||||
|
||||
p = PaidPlan(
|
||||
# settings.DEBUG = True
|
||||
|
||||
p1 = PaidPlan(
|
||||
shortname='free',
|
||||
name='Basic',
|
||||
external_id='a',
|
||||
price=0,
|
||||
clubsize=0,
|
||||
paymentprocessor='braintree',
|
||||
paymenttype='single',
|
||||
)
|
||||
|
||||
p.save()
|
||||
p1.save()
|
||||
|
||||
p = PaidPlan(
|
||||
p2 = PaidPlan(
|
||||
shortname='pro_recurring',
|
||||
name='Pro (recurring)',
|
||||
external_id='b',
|
||||
price=15,
|
||||
clubsize=0,
|
||||
paymentprocessor='braintree',
|
||||
paymenttype='single',
|
||||
)
|
||||
|
||||
p.save()
|
||||
p2.save()
|
||||
|
||||
p = PaidPlan(
|
||||
p3 = PaidPlan(
|
||||
shortname='pro_single',
|
||||
name='Pro (single)',
|
||||
external_id='c',
|
||||
price=20,
|
||||
clubsize=0,
|
||||
paymentprocessor='braintree',
|
||||
paymenttype='single',
|
||||
)
|
||||
|
||||
p.save()
|
||||
p3.save()
|
||||
|
||||
self.c = Client()
|
||||
self.password = faker.word()
|
||||
self.u.set_password(self.password)
|
||||
self.u.save()
|
||||
|
||||
@patch('rowers.braintreestuff.braintree.BraintreeGateway',side_effect=MockBraintreeGateway)
|
||||
def test_billing_view(self,mock_gateway):
|
||||
# def tearDown(self):
|
||||
# settings.DEBUG = False
|
||||
|
||||
@patch('rowers.braintreestuff.gateway',side_effect=mocked_gateway)
|
||||
def test_billing_view(self,MockBraintreeGateway):
|
||||
login = self.c.login(username=self.u.username, password=self.password)
|
||||
self.assertTrue(login)
|
||||
|
||||
@@ -99,8 +107,8 @@ class PaymentTest(TestCase):
|
||||
expected_url = expected_url,
|
||||
status_code=302,target_status_code=200)
|
||||
|
||||
@patch('rowers.braintreestuff.braintree.BraintreeGateway',side_effect=MockBraintreeGateway)
|
||||
def test_upgrade_view(self,mock_gateway):
|
||||
@patch('rowers.braintreestuff.gateway',side_effect=mocked_gateway)
|
||||
def test_upgrade_view(self,MockBraintreeGateway):
|
||||
self.r.country = 'NL'
|
||||
self.r.customer_id = 34
|
||||
self.r.subscription_id = 34
|
||||
@@ -146,8 +154,8 @@ class PaymentTest(TestCase):
|
||||
expected_url = expected_url,
|
||||
status_code=302,target_status_code=200)
|
||||
|
||||
@patch('rowers.braintreestuff.braintree.BraintreeGateway',side_effect=MockBraintreeGateway)
|
||||
def test_down_view(self,mock_gateway):
|
||||
@patch('rowers.braintreestuff.gateway',side_effect=mocked_gateway)
|
||||
def test_down_view(self,MockBraintreeGateway):
|
||||
self.r.country = 'NL'
|
||||
self.r.customer_id = 34
|
||||
self.r.subscription_id = 34
|
||||
@@ -196,8 +204,8 @@ class PaymentTest(TestCase):
|
||||
expected_url = expected_url,
|
||||
status_code=302,target_status_code=200)
|
||||
|
||||
@patch('rowers.braintreestuff.braintree.BraintreeGateway',side_effect=MockBraintreeGateway)
|
||||
def test_planstop_view(self,mock_gateway):
|
||||
@patch('rowers.braintreestuff.gateway',side_effect=mocked_gateway)
|
||||
def test_planstop_view(self,MockBraintreeGateway):
|
||||
self.r.country = 'NL'
|
||||
self.r.customer_id = 34
|
||||
self.r.subscription_id = 34
|
||||
@@ -218,8 +226,8 @@ class PaymentTest(TestCase):
|
||||
self.assertEqual(response.status_code,200)
|
||||
|
||||
|
||||
@patch('rowers.braintreestuff.braintree.BraintreeGateway',side_effect=MockBraintreeGateway)
|
||||
def test_planstobasic_view(self,mock_gateway):
|
||||
@patch('rowers.braintreestuff.gateway',side_effect=mocked_gateway)
|
||||
def test_planstobasic_view(self,MockBraintreeGateway):
|
||||
self.r.country = 'NL'
|
||||
self.r.customer_id = 34
|
||||
self.r.subscription_id = 34
|
||||
@@ -242,8 +250,8 @@ class PaymentTest(TestCase):
|
||||
expected_url = '/rowers/me/cancelsubscriptions/',
|
||||
status_code=302,target_status_code=200)
|
||||
|
||||
@patch('rowers.braintreestuff.braintree.BraintreeGateway',side_effect=MockBraintreeGateway)
|
||||
def test_checkouts_view(self,mock_gateway):
|
||||
@patch('rowers.braintreestuff.gateway',side_effect=mocked_gateway)
|
||||
def test_checkouts_view(self,MockBraintreeGateway):
|
||||
|
||||
plans = PaidPlan.objects.all().order_by('price')
|
||||
plan = plans[1]
|
||||
|
||||
@@ -1040,7 +1040,7 @@ def ispromember(user):
|
||||
if not user.is_anonymous():
|
||||
try:
|
||||
r = Rower.objects.get(user=user)
|
||||
except Rower.DoesNotExists:
|
||||
except Rower.DoesNotExist:
|
||||
r = Rower(user=user)
|
||||
r.save()
|
||||
|
||||
@@ -1381,6 +1381,7 @@ def checkouts_view(request):
|
||||
form = BillingForm(request.POST)
|
||||
if form.is_valid():
|
||||
data = form.cleaned_data
|
||||
print r
|
||||
success,amount = braintreestuff.create_subscription(r,data)
|
||||
if success:
|
||||
messages.info(request,"Your payment has succeeded and your plan has been updated")
|
||||
|
||||
Reference in New Issue
Block a user